Merge pull request #32954 from argentite/new-extend-script

Add separate menu entries for extending and replacing scripts
This commit is contained in:
Rémi Verschelde 2019-10-23 07:33:50 +02:00 committed by GitHub
commit f022e4748c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 88 additions and 60 deletions

View file

@ -2205,7 +2205,14 @@ void EditorPropertyResource::_menu_option(int p_which) {
case OBJ_MENU_NEW_SCRIPT: { case OBJ_MENU_NEW_SCRIPT: {
if (Object::cast_to<Node>(get_edited_object())) { if (Object::cast_to<Node>(get_edited_object())) {
EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(get_edited_object())); EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(get_edited_object()), false);
}
} break;
case OBJ_MENU_EXTEND_SCRIPT: {
if (Object::cast_to<Node>(get_edited_object())) {
EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(get_edited_object()), true);
} }
} break; } break;
@ -2338,7 +2345,8 @@ void EditorPropertyResource::_update_menu_items() {
menu->clear(); menu->clear();
if (get_edited_property() == "script" && base_type == "Script" && Object::cast_to<Node>(get_edited_object())) { if (get_edited_property() == "script" && base_type == "Script" && Object::cast_to<Node>(get_edited_object())) {
menu->add_icon_item(get_icon("Script", "EditorIcons"), TTR("New Script"), OBJ_MENU_NEW_SCRIPT); menu->add_icon_item(get_icon("ScriptCreate", "EditorIcons"), TTR("New Script"), OBJ_MENU_NEW_SCRIPT);
menu->add_icon_item(get_icon("ScriptExtend", "EditorIcons"), TTR("Extend Script"), OBJ_MENU_EXTEND_SCRIPT);
menu->add_separator(); menu->add_separator();
} else if (base_type != "") { } else if (base_type != "") {
int idx = 0; int idx = 0;
@ -2633,7 +2641,6 @@ void EditorPropertyResource::update_property() {
if (res == RES()) { if (res == RES()) {
assign->set_icon(Ref<Texture>()); assign->set_icon(Ref<Texture>());
assign->set_text(TTR("[empty]")); assign->set_text(TTR("[empty]"));
assign->set_tooltip("");
} else { } else {
assign->set_icon(EditorNode::get_singleton()->get_object_icon(res.operator->(), "Object")); assign->set_icon(EditorNode::get_singleton()->get_object_icon(res.operator->(), "Object"));
@ -2909,7 +2916,7 @@ void EditorInspectorDefaultPlugin::parse_begin(Object *p_object) {
bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Type p_type, const String &p_path, PropertyHint p_hint, const String &p_hint_text, int p_usage) { bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Type p_type, const String &p_path, PropertyHint p_hint, const String &p_hint_text, int p_usage) {
double default_float_step = EDITOR_GET("interface/inspector/default_float_step"); float default_float_step = EDITOR_GET("interface/inspector/default_float_step");
switch (p_type) { switch (p_type) {

View file

@ -550,7 +550,8 @@ class EditorPropertyResource : public EditorProperty {
OBJ_MENU_COPY = 5, OBJ_MENU_COPY = 5,
OBJ_MENU_PASTE = 6, OBJ_MENU_PASTE = 6,
OBJ_MENU_NEW_SCRIPT = 7, OBJ_MENU_NEW_SCRIPT = 7,
OBJ_MENU_SHOW_IN_FILE_SYSTEM = 8, OBJ_MENU_EXTEND_SCRIPT = 8,
OBJ_MENU_SHOW_IN_FILE_SYSTEM = 9,
TYPE_BASE_ID = 100, TYPE_BASE_ID = 100,
CONVERT_BASE_ID = 1000 CONVERT_BASE_ID = 1000

View file

@ -246,7 +246,13 @@ void CustomPropertyEditor::_menu_option(int p_which) {
case OBJ_MENU_NEW_SCRIPT: { case OBJ_MENU_NEW_SCRIPT: {
if (Object::cast_to<Node>(owner)) if (Object::cast_to<Node>(owner))
EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(owner)); EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(owner), false);
} break;
case OBJ_MENU_EXTEND_SCRIPT: {
if (Object::cast_to<Node>(owner))
EditorNode::get_singleton()->get_scene_tree_dock()->open_script_dialog(Object::cast_to<Node>(owner), true);
} break; } break;
case OBJ_MENU_SHOW_IN_FILE_SYSTEM: { case OBJ_MENU_SHOW_IN_FILE_SYSTEM: {

View file

@ -77,7 +77,8 @@ class CustomPropertyEditor : public Popup {
OBJ_MENU_COPY = 4, OBJ_MENU_COPY = 4,
OBJ_MENU_PASTE = 5, OBJ_MENU_PASTE = 5,
OBJ_MENU_NEW_SCRIPT = 6, OBJ_MENU_NEW_SCRIPT = 6,
OBJ_MENU_SHOW_IN_FILE_SYSTEM = 7, OBJ_MENU_EXTEND_SCRIPT = 7,
OBJ_MENU_SHOW_IN_FILE_SYSTEM = 8,
TYPE_BASE_ID = 100, TYPE_BASE_ID = 100,
CONVERT_BASE_ID = 1000 CONVERT_BASE_ID = 1000
}; };

View file

@ -421,53 +421,11 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
create_dialog->popup_create(false, true, selected->get_class()); create_dialog->popup_create(false, true, selected->get_class());
} break; } break;
case TOOL_EXTEND_SCRIPT: {
attach_script_to_selected(true);
} break;
case TOOL_ATTACH_SCRIPT: { case TOOL_ATTACH_SCRIPT: {
attach_script_to_selected(false);
if (!profile_allow_script_editing) {
break;
}
List<Node *> selection = editor_selection->get_selected_node_list();
if (selection.empty())
break;
Node *selected = scene_tree->get_selected();
if (!selected)
selected = selection.front()->get();
Ref<Script> existing = selected->get_script();
String path = selected->get_filename();
if (path == "") {
String root_path = editor_data->get_edited_scene_root()->get_filename();
if (root_path == "") {
path = String("res://").plus_file(selected->get_name());
} else {
path = root_path.get_base_dir().plus_file(selected->get_name());
}
}
String inherits = selected->get_class();
if (existing.is_valid()) {
for (int i = 0; i < ScriptServer::get_language_count(); i++) {
ScriptLanguage *l = ScriptServer::get_language(i);
if (l->get_type() == existing->get_class()) {
String name = l->get_global_class_name(existing->get_path());
if (ScriptServer::is_global_class(name) && EDITOR_GET("interface/editors/derive_script_globals_by_name").operator bool()) {
inherits = name;
} else if (l->can_inherit_from_file()) {
inherits = "\"" + existing->get_path() + "\"";
}
break;
}
}
}
script_create_dialog->connect("script_created", this, "_script_created");
script_create_dialog->connect("popup_hide", this, "_script_creation_closed");
script_create_dialog->set_inheritance_base_type("Node");
script_create_dialog->config(inherits, path);
script_create_dialog->popup_centered();
} break; } break;
case TOOL_CLEAR_SCRIPT: { case TOOL_CLEAR_SCRIPT: {
@ -2482,10 +2440,9 @@ void SceneTreeDock::_tree_rmb(const Vector2 &p_menu_pos) {
if (profile_allow_script_editing) { if (profile_allow_script_editing) {
if (selection.size() == 1) { if (selection.size() == 1) {
if (!existing_script.is_valid()) {
menu->add_icon_shortcut(get_icon("ScriptCreate", "EditorIcons"), ED_GET_SHORTCUT("scene_tree/attach_script"), TOOL_ATTACH_SCRIPT); menu->add_icon_shortcut(get_icon("ScriptCreate", "EditorIcons"), ED_GET_SHORTCUT("scene_tree/attach_script"), TOOL_ATTACH_SCRIPT);
} else { if (existing_script.is_valid()) {
menu->add_icon_shortcut(get_icon("ScriptExtend", "EditorIcons"), ED_GET_SHORTCUT("scene_tree/extend_script"), TOOL_ATTACH_SCRIPT); menu->add_icon_shortcut(get_icon("ScriptExtend", "EditorIcons"), ED_GET_SHORTCUT("scene_tree/extend_script"), TOOL_EXTEND_SCRIPT);
} }
} }
if (selection.size() > 1 || (existing_script.is_valid() && exisiting_script_removable)) { if (selection.size() > 1 || (existing_script.is_valid() && exisiting_script_removable)) {
@ -2595,11 +2552,65 @@ void SceneTreeDock::_focus_node() {
} }
} }
void SceneTreeDock::open_script_dialog(Node *p_for_node) { void SceneTreeDock::attach_script_to_selected(bool p_extend) {
if (!profile_allow_script_editing) {
return;
}
List<Node *> selection = editor_selection->get_selected_node_list();
if (selection.empty())
return;
Node *selected = scene_tree->get_selected();
if (!selected)
selected = selection.front()->get();
Ref<Script> existing = selected->get_script();
String path = selected->get_filename();
if (path == "") {
String root_path = editor_data->get_edited_scene_root()->get_filename();
if (root_path == "") {
path = String("res://").plus_file(selected->get_name());
} else {
path = root_path.get_base_dir().plus_file(selected->get_name());
}
}
String inherits = selected->get_class();
if (p_extend && existing.is_valid()) {
for (int i = 0; i < ScriptServer::get_language_count(); i++) {
ScriptLanguage *l = ScriptServer::get_language(i);
if (l->get_type() == existing->get_class()) {
String name = l->get_global_class_name(existing->get_path());
if (ScriptServer::is_global_class(name) && EDITOR_GET("interface/editors/derive_script_globals_by_name").operator bool()) {
inherits = name;
} else if (l->can_inherit_from_file()) {
inherits = "\"" + existing->get_path() + "\"";
}
break;
}
}
}
script_create_dialog->connect("script_created", this, "_script_created");
script_create_dialog->connect("popup_hide", this, "_script_creation_closed");
script_create_dialog->set_inheritance_base_type("Node");
script_create_dialog->config(inherits, path);
script_create_dialog->popup_centered();
}
void SceneTreeDock::open_script_dialog(Node *p_for_node, bool p_extend) {
scene_tree->set_selected(p_for_node, false); scene_tree->set_selected(p_for_node, false);
if (p_extend) {
_tool_selected(TOOL_EXTEND_SCRIPT);
} else {
_tool_selected(TOOL_ATTACH_SCRIPT); _tool_selected(TOOL_ATTACH_SCRIPT);
} }
}
void SceneTreeDock::add_remote_tree_editor(Control *p_remote) { void SceneTreeDock::add_remote_tree_editor(Control *p_remote) {
ERR_FAIL_COND(remote_tree != NULL); ERR_FAIL_COND(remote_tree != NULL);

View file

@ -64,6 +64,7 @@ class SceneTreeDock : public VBoxContainer {
TOOL_RENAME, TOOL_RENAME,
TOOL_BATCH_RENAME, TOOL_BATCH_RENAME,
TOOL_REPLACE, TOOL_REPLACE,
TOOL_EXTEND_SCRIPT,
TOOL_ATTACH_SCRIPT, TOOL_ATTACH_SCRIPT,
TOOL_CLEAR_SCRIPT, TOOL_CLEAR_SCRIPT,
TOOL_MOVE_UP, TOOL_MOVE_UP,
@ -259,7 +260,8 @@ public:
void replace_node(Node *p_node, Node *p_by_node, bool p_keep_properties = true, bool p_remove_old = true); void replace_node(Node *p_node, Node *p_by_node, bool p_keep_properties = true, bool p_remove_old = true);
void open_script_dialog(Node *p_for_node); void attach_script_to_selected(bool p_extend);
void open_script_dialog(Node *p_for_node, bool p_extend);
ScriptCreateDialog *get_script_create_dialog() { return script_create_dialog; } ScriptCreateDialog *get_script_create_dialog() { return script_create_dialog; }