mirror of
https://github.com/godotengine/godot.git
synced 2025-11-01 06:01:14 +00:00
Merge pull request #72925 from vonagam/fix-enum-typed-array-error
GDScript: Fix error about enum typed arrays
This commit is contained in:
commit
6e0dd6beca
2 changed files with 18 additions and 10 deletions
|
|
@ -4252,18 +4252,22 @@ Variant GDScriptAnalyzer::make_subscript_reduced_value(GDScriptParser::Subscript
|
||||||
Array GDScriptAnalyzer::make_array_from_element_datatype(const GDScriptParser::DataType &p_element_datatype, const GDScriptParser::Node *p_source_node) {
|
Array GDScriptAnalyzer::make_array_from_element_datatype(const GDScriptParser::DataType &p_element_datatype, const GDScriptParser::Node *p_source_node) {
|
||||||
Array array;
|
Array array;
|
||||||
|
|
||||||
Ref<Script> script_type = p_element_datatype.script_type;
|
if (p_element_datatype.builtin_type == Variant::OBJECT) {
|
||||||
if (p_element_datatype.kind == GDScriptParser::DataType::CLASS && script_type.is_null()) {
|
Ref<Script> script_type = p_element_datatype.script_type;
|
||||||
Error err = OK;
|
if (p_element_datatype.kind == GDScriptParser::DataType::CLASS && script_type.is_null()) {
|
||||||
Ref<GDScript> scr = GDScriptCache::get_shallow_script(p_element_datatype.script_path, err);
|
Error err = OK;
|
||||||
if (err) {
|
Ref<GDScript> scr = GDScriptCache::get_shallow_script(p_element_datatype.script_path, err);
|
||||||
push_error(vformat(R"(Error while getting cache for script "%s".)", p_element_datatype.script_path), p_source_node);
|
if (err) {
|
||||||
return array;
|
push_error(vformat(R"(Error while getting cache for script "%s".)", p_element_datatype.script_path), p_source_node);
|
||||||
|
return array;
|
||||||
|
}
|
||||||
|
script_type.reference_ptr(scr->find_class(p_element_datatype.class_type->fqcn));
|
||||||
}
|
}
|
||||||
script_type.reference_ptr(scr->find_class(p_element_datatype.class_type->fqcn));
|
|
||||||
}
|
|
||||||
|
|
||||||
array.set_typed(p_element_datatype.builtin_type, p_element_datatype.native_type, script_type);
|
array.set_typed(p_element_datatype.builtin_type, p_element_datatype.native_type, script_type);
|
||||||
|
} else {
|
||||||
|
array.set_typed(p_element_datatype.builtin_type, StringName(), Variant());
|
||||||
|
}
|
||||||
|
|
||||||
return array;
|
return array;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -201,6 +201,10 @@ func test():
|
||||||
assert(str(typed_enums) == '[391]')
|
assert(str(typed_enums) == '[391]')
|
||||||
assert(typed_enums.get_typed_builtin() == TYPE_INT)
|
assert(typed_enums.get_typed_builtin() == TYPE_INT)
|
||||||
|
|
||||||
|
const const_enums: Array[E] = []
|
||||||
|
assert(const_enums.get_typed_builtin() == TYPE_INT)
|
||||||
|
assert(const_enums.get_typed_class_name() == &'')
|
||||||
|
|
||||||
|
|
||||||
var a := A.new()
|
var a := A.new()
|
||||||
var typed_natives: Array[RefCounted] = [a]
|
var typed_natives: Array[RefCounted] = [a]
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue