summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-06-12 10:00:34 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-06-12 10:00:34 +0200
commit4516050e645c00e0a6338a3183a53aef58338544 (patch)
tree0f030b5cf0d80d6f7dbc2c708c863ea4af3efebd /modules
parent5bab95a5566b1b1c49200f71e21888b2b7b90f3e (diff)
parent5962646fd3220b5fb5a4faec8599f05b4904cdfa (diff)
downloadredot-engine-4516050e645c00e0a6338a3183a53aef58338544.tar.gz
Merge pull request #92885 from Chaosus/fix_goto_definition_for_new
Fix goto definition for `new` method
Diffstat (limited to 'modules')
-rw-r--r--modules/gdscript/gdscript_editor.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/modules/gdscript/gdscript_editor.cpp b/modules/gdscript/gdscript_editor.cpp
index 11d4a4002c..fcabb7c4a8 100644
--- a/modules/gdscript/gdscript_editor.cpp
+++ b/modules/gdscript/gdscript_editor.cpp
@@ -3571,9 +3571,13 @@ static Error _lookup_symbol_from_base(const GDScriptParser::DataType &p_base, co
switch (base_type.kind) {
case GDScriptParser::DataType::CLASS: {
if (base_type.class_type) {
- if (base_type.class_type->has_member(p_symbol)) {
+ String name = p_symbol;
+ if (name == "new") {
+ name = "_init";
+ }
+ if (base_type.class_type->has_member(name)) {
r_result.type = ScriptLanguage::LOOKUP_RESULT_SCRIPT_LOCATION;
- r_result.location = base_type.class_type->get_member(p_symbol).get_line();
+ r_result.location = base_type.class_type->get_member(name).get_line();
r_result.class_path = base_type.script_path;
Error err = OK;
r_result.script = GDScriptCache::get_shallow_script(r_result.class_path, err);