diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-05-19 11:21:11 +0200 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-05-19 11:21:11 +0200 |
commit | 4ce95d684cbebd800a88c556f98325d689ac0082 (patch) | |
tree | dbf320e8cb985123311b42242346f33136cb8d17 /modules/gdscript/gdscript_editor.cpp | |
parent | 6761923f4f90c9f564e94e6845471d504d5f63f1 (diff) | |
parent | d13106484158b56e3f1843f4a706e6f213d47f42 (diff) | |
download | redot-engine-4ce95d684cbebd800a88c556f98325d689ac0082.tar.gz |
Merge pull request #91653 from HolonProduction/autocompletion-analyze-recursively-but-leave-the-parser-alone
Autocompletion: Analyze CLASS types as they are encountered
Diffstat (limited to 'modules/gdscript/gdscript_editor.cpp')
-rw-r--r-- | modules/gdscript/gdscript_editor.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/modules/gdscript/gdscript_editor.cpp b/modules/gdscript/gdscript_editor.cpp index cacdb1df7f..4ae39d80cd 100644 --- a/modules/gdscript/gdscript_editor.cpp +++ b/modules/gdscript/gdscript_editor.cpp @@ -2088,6 +2088,12 @@ static bool _guess_expression_type(GDScriptParser::CompletionContext &p_context, found = false; } + // If the found type was not fully analyzed we analyze it now. + if (found && r_type.type.kind == GDScriptParser::DataType::CLASS && !r_type.type.class_type->resolved_body) { + Error err; + Ref<GDScriptParserRef> r = GDScriptCache::get_parser(r_type.type.script_path, GDScriptParserRef::FULLY_SOLVED, err); + } + // Check type hint last. For collections we want chance to get the actual value first // This way we can detect types from the content of dictionaries and arrays if (!found && p_expression->get_datatype().is_hard_type()) { |