Always pass script path to external editor
Previously you had to set the Exec Flags manually, reading the documentation to find out what placeholders to use. As most editors should support having the file path passed as the last argument, we default to doing this if no custom {file} flag is defined. We also default the Exec Flags to "{file}" and the placeholder text gives some documentation. Fixes #29662.
This commit is contained in:
parent
629bc10d80
commit
4a757a2d96
|
@ -1969,10 +1969,11 @@ bool ScriptEditor::edit(const RES &p_resource, int p_line, int p_col, bool p_gra
|
||||||
String flags = EditorSettings::get_singleton()->get("text_editor/external/exec_flags");
|
String flags = EditorSettings::get_singleton()->get("text_editor/external/exec_flags");
|
||||||
|
|
||||||
List<String> args;
|
List<String> args;
|
||||||
|
bool has_file_flag = false;
|
||||||
|
String script_path = ProjectSettings::get_singleton()->globalize_path(p_resource->get_path());
|
||||||
|
|
||||||
if (flags.size()) {
|
if (flags.size()) {
|
||||||
String project_path = ProjectSettings::get_singleton()->get_resource_path();
|
String project_path = ProjectSettings::get_singleton()->get_resource_path();
|
||||||
String script_path = ProjectSettings::get_singleton()->globalize_path(p_resource->get_path());
|
|
||||||
|
|
||||||
flags = flags.replacen("{line}", itos(p_line > 0 ? p_line : 0));
|
flags = flags.replacen("{line}", itos(p_line > 0 ? p_line : 0));
|
||||||
flags = flags.replacen("{col}", itos(p_col));
|
flags = flags.replacen("{col}", itos(p_col));
|
||||||
|
@ -1994,6 +1995,9 @@ bool ScriptEditor::edit(const RES &p_resource, int p_line, int p_col, bool p_gra
|
||||||
} else if (flags[i] == '\0' || (!inside_quotes && flags[i] == ' ')) {
|
} else if (flags[i] == '\0' || (!inside_quotes && flags[i] == ' ')) {
|
||||||
|
|
||||||
String arg = flags.substr(from, num_chars);
|
String arg = flags.substr(from, num_chars);
|
||||||
|
if (arg.find("{file}") != -1) {
|
||||||
|
has_file_flag = true;
|
||||||
|
}
|
||||||
|
|
||||||
// do path replacement here, else there will be issues with spaces and quotes
|
// do path replacement here, else there will be issues with spaces and quotes
|
||||||
arg = arg.replacen("{project}", project_path);
|
arg = arg.replacen("{project}", project_path);
|
||||||
|
@ -2008,6 +2012,11 @@ bool ScriptEditor::edit(const RES &p_resource, int p_line, int p_col, bool p_gra
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Default to passing script path if no {file} flag is specified.
|
||||||
|
if (!has_file_flag) {
|
||||||
|
args.push_back(script_path);
|
||||||
|
}
|
||||||
|
|
||||||
Error err = OS::get_singleton()->execute(path, args, false);
|
Error err = OS::get_singleton()->execute(path, args, false);
|
||||||
if (err == OK)
|
if (err == OK)
|
||||||
return false;
|
return false;
|
||||||
|
@ -3428,7 +3437,8 @@ ScriptEditorPlugin::ScriptEditorPlugin(EditorNode *p_node) {
|
||||||
EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::INT, "text_editor/open_scripts/list_script_names_as", PROPERTY_HINT_ENUM, "Name,Parent Directory And Name,Full Path"));
|
EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::INT, "text_editor/open_scripts/list_script_names_as", PROPERTY_HINT_ENUM, "Name,Parent Directory And Name,Full Path"));
|
||||||
EDITOR_DEF("text_editor/open_scripts/list_script_names_as", 0);
|
EDITOR_DEF("text_editor/open_scripts/list_script_names_as", 0);
|
||||||
EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::STRING, "text_editor/external/exec_path", PROPERTY_HINT_GLOBAL_FILE));
|
EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::STRING, "text_editor/external/exec_path", PROPERTY_HINT_GLOBAL_FILE));
|
||||||
EDITOR_DEF("text_editor/external/exec_flags", "");
|
EDITOR_DEF("text_editor/external/exec_flags", "{file}");
|
||||||
|
EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::STRING, "text_editor/external/exec_flags", PROPERTY_HINT_PLACEHOLDER_TEXT, "Call flags with placeholders: {project}, {file}, {col}, {line}."));
|
||||||
|
|
||||||
ED_SHORTCUT("script_editor/open_recent", TTR("Open Recent"), KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_T);
|
ED_SHORTCUT("script_editor/open_recent", TTR("Open Recent"), KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_T);
|
||||||
ED_SHORTCUT("script_editor/clear_recent", TTR("Clear Recent Files"));
|
ED_SHORTCUT("script_editor/clear_recent", TTR("Clear Recent Files"));
|
||||||
|
|
Loading…
Reference in New Issue