diff options
author | George Marques <george@gmarqu.es> | 2020-08-26 16:01:08 -0300 |
---|---|---|
committer | George Marques <george@gmarqu.es> | 2020-08-26 16:01:08 -0300 |
commit | b2b45987d007a22f2a7c07ce06fe55338217c86c (patch) | |
tree | f6e4751f69048331b42c53b89dcc44c6db9ce5b9 /modules/gdscript/gdscript_analyzer.cpp | |
parent | 4a3fca47e5401781f2d022f01a975fca4e2026f1 (diff) | |
download | redot-engine-b2b45987d007a22f2a7c07ce06fe55338217c86c.tar.gz |
GDScript: Show error when there's an inheritance cycle
Diffstat (limited to 'modules/gdscript/gdscript_analyzer.cpp')
-rw-r--r-- | modules/gdscript/gdscript_analyzer.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/modules/gdscript/gdscript_analyzer.cpp b/modules/gdscript/gdscript_analyzer.cpp index 319d7f67d3..cabe096579 100644 --- a/modules/gdscript/gdscript_analyzer.cpp +++ b/modules/gdscript/gdscript_analyzer.cpp @@ -302,6 +302,16 @@ Error GDScriptAnalyzer::resolve_inheritance(GDScriptParser::ClassNode *p_class, return ERR_PARSE_ERROR; } + // Check for cyclic inheritance. + const GDScriptParser::ClassNode *base_class = result.class_type; + while (base_class) { + if (base_class->fqcn == p_class->fqcn) { + push_error("Cyclic inheritance.", p_class); + return ERR_PARSE_ERROR; + } + base_class = base_class->base_type.class_type; + } + p_class->base_type = result; class_type.native_type = result.native_type; p_class->set_datatype(class_type); @@ -309,7 +319,10 @@ Error GDScriptAnalyzer::resolve_inheritance(GDScriptParser::ClassNode *p_class, if (p_recursive) { for (int i = 0; i < p_class->members.size(); i++) { if (p_class->members[i].type == GDScriptParser::ClassNode::Member::CLASS) { - resolve_inheritance(p_class->members[i].m_class, true); + Error err = resolve_inheritance(p_class->members[i].m_class, true); + if (err) { + return err; + } } } } |