Merge pull request #32954 from argentite/new-extend-script
Add separate menu entries for extending and replacing scripts
This commit is contained in:
commit
f022e4748c
6 changed files with 88 additions and 60 deletions
|
@ -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) {
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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: {
|
||||||
|
|
|
@ -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
|
||||||
};
|
};
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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; }
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue