Skip to content

Commit

Permalink
Merge pull request #85384 from HolonProduction/unique-name-completion
Browse files Browse the repository at this point in the history
Suggest scene unique nodes in `get_node` autocompletion
  • Loading branch information
YuriSizov committed Jan 17, 2024
2 parents 2e1f4f4 + 8cc8551 commit 28cf7fe
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 5 deletions.
25 changes: 20 additions & 5 deletions modules/gdscript/gdscript_editor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3197,6 +3197,11 @@ ::Error GDScriptLanguage::complete_code(const String &p_code, const String &p_pa
List<String> opts;
p_owner->get_argument_options("get_node", 0, &opts);

bool for_unique_name = false;
if (completion_context.node != nullptr && completion_context.node->type == GDScriptParser::Node::GET_NODE && !static_cast<GDScriptParser::GetNodeNode *>(completion_context.node)->use_dollar) {
for_unique_name = true;
}

for (const String &E : opts) {
r_forced = true;
String opt = E.strip_edges();
Expand All @@ -3205,6 +3210,14 @@ ::Error GDScriptLanguage::complete_code(const String &p_code, const String &p_pa
// or handle NodePaths which are valid identifiers and don't need quotes.
opt = opt.unquote();
}

if (for_unique_name) {
if (!opt.begins_with("%")) {
continue;
}
opt = opt.substr(1);
}

// The path needs quotes if it's not a valid identifier (with an exception
// for "/" as path separator, which also doesn't require quotes).
if (!opt.replace("/", "_").is_valid_identifier()) {
Expand All @@ -3216,11 +3229,13 @@ ::Error GDScriptLanguage::complete_code(const String &p_code, const String &p_pa
options.insert(option.display, option);
}

// Get autoloads.
for (const KeyValue<StringName, ProjectSettings::AutoloadInfo> &E : ProjectSettings::get_singleton()->get_autoload_list()) {
String path = "/root/" + E.key;
ScriptLanguage::CodeCompletionOption option(path.quote(quote_style), ScriptLanguage::CODE_COMPLETION_KIND_NODE_PATH);
options.insert(option.display, option);
if (!for_unique_name) {
// Get autoloads.
for (const KeyValue<StringName, ProjectSettings::AutoloadInfo> &E : ProjectSettings::get_singleton()->get_autoload_list()) {
String path = "/root/" + E.key;
ScriptLanguage::CodeCompletionOption option(path.quote(quote_style), ScriptLanguage::CODE_COMPLETION_KIND_NODE_PATH);
options.insert(option.display, option);
}
}
}
} break;
Expand Down
4 changes: 4 additions & 0 deletions scene/main/node.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3088,6 +3088,10 @@ static void _add_nodes_to_options(const Node *p_base, const Node *p_node, List<S
if (p_node != p_base && !p_node->get_owner()) {
return;
}
if (p_node->is_unique_name_in_owner() && p_node->get_owner() == p_base) {
String n = "%" + p_node->get_name();
r_options->push_back(n.quote());
}
String n = p_base->get_path_to(p_node);
r_options->push_back(n.quote());
for (int i = 0; i < p_node->get_child_count(); i++) {
Expand Down

0 comments on commit 28cf7fe

Please sign in to comment.