Skip to content

Commit

Permalink
Add Control to preferred types
Browse files Browse the repository at this point in the history
  • Loading branch information
stijn-h committed Jun 30, 2020
1 parent 4599381 commit ec86d32
Showing 1 changed file with 12 additions and 7 deletions.
19 changes: 12 additions & 7 deletions editor/scene_tree_dock.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -350,17 +350,22 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
if (!profile_allow_editing) {
break;
}
String preferred = "";
Node *current_edited_scene_root = EditorNode::get_singleton()->get_edited_scene();

// Prefer nodes that inherit from the current scene root.
Node *current_edited_scene_root = EditorNode::get_singleton()->get_edited_scene();
if (current_edited_scene_root) {
if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Node2D")) {
preferred = "Node2D";
} else if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Node3D")) {
preferred = "Node3D";
static const String preferred_types[] = { "Node2D", "Node3D", "Control" };

StringName root_class = current_edited_scene_root->get_class_name();

for (int i = 0; i < preferred_types->size(); i++) {
if (ClassDB::is_parent_class(root_class, preferred_types[i])) {
create_dialog->set_preferred_search_result_type(preferred_types[i]);
break;
}
}
}
create_dialog->set_preferred_search_result_type(preferred);

create_dialog->popup_create(true);
} break;
case TOOL_INSTANCE: {
Expand Down

0 comments on commit ec86d32

Please sign in to comment.