summaryrefslogtreecommitdiffstats
path: root/modules/gdscript/gdscript_analyzer.h
diff options
context:
space:
mode:
authorDanil Alexeev <danil@alexeev.xyz>2023-08-23 12:37:18 +0300
committerDanil Alexeev <danil@alexeev.xyz>2023-08-25 16:29:11 +0300
commit89429b0273a3358f4a0a283abf7efa7fcb4e5e4c (patch)
treefa92cea3947e222bedf4fa3ff69fb3d45921a269 /modules/gdscript/gdscript_analyzer.h
parent6758a7f8c07d1f4c8ec4f052ded6d26402967ebe (diff)
downloadredot-engine-89429b0273a3358f4a0a283abf7efa7fcb4e5e4c.tar.gz
GDScript: Fix lambda resolution with cyclic references
Diffstat (limited to 'modules/gdscript/gdscript_analyzer.h')
-rw-r--r--modules/gdscript/gdscript_analyzer.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/modules/gdscript/gdscript_analyzer.h b/modules/gdscript/gdscript_analyzer.h
index 5bc2c89a87..ec155706df 100644
--- a/modules/gdscript/gdscript_analyzer.h
+++ b/modules/gdscript/gdscript_analyzer.h
@@ -43,7 +43,8 @@ class GDScriptAnalyzer {
HashMap<String, Ref<GDScriptParserRef>> depended_parsers;
const GDScriptParser::EnumNode *current_enum = nullptr;
- List<GDScriptParser::LambdaNode *> lambda_stack;
+ GDScriptParser::LambdaNode *current_lambda = nullptr;
+ List<GDScriptParser::LambdaNode *> pending_body_resolution_lambdas;
bool static_context = false;
// Tests for detecting invalid overloading of script members
@@ -129,6 +130,7 @@ class GDScriptAnalyzer {
void mark_node_unsafe(const GDScriptParser::Node *p_node);
void downgrade_node_type_source(GDScriptParser::Node *p_node);
void mark_lambda_use_self();
+ void resolve_pending_lambda_bodies();
bool class_exists(const StringName &p_class) const;
Ref<GDScriptParserRef> get_parser_for(const String &p_path);
void reduce_identifier_from_base_set_class(GDScriptParser::IdentifierNode *p_identifier, GDScriptParser::DataType p_identifier_datatype);