Merge pull request #44093 from nekomatata/gdscript-base-class-init

Fix base script not initialized properly in some cases
This commit is contained in:
Rémi Verschelde 2020-12-07 11:29:45 +01:00 committed by GitHub
commit 3c9c2cbb23
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -98,7 +98,8 @@ GDScriptDataType GDScriptCompiler::_gdtype_from_datatype(const GDScriptParser::D
} break; } break;
case GDScriptParser::DataType::SCRIPT: { case GDScriptParser::DataType::SCRIPT: {
result.kind = GDScriptDataType::SCRIPT; result.kind = GDScriptDataType::SCRIPT;
result.script_type = Ref<Script>(p_datatype.script_type).ptr(); result.script_type_ref = Ref<Script>(p_datatype.script_type);
result.script_type = result.script_type_ref.ptr();
result.native_type = result.script_type->get_instance_base_type(); result.native_type = result.script_type->get_instance_base_type();
} break; } break;
case GDScriptParser::DataType::CLASS: { case GDScriptParser::DataType::CLASS: {
@ -124,11 +125,13 @@ GDScriptDataType GDScriptCompiler::_gdtype_from_datatype(const GDScriptParser::D
names.pop_back(); names.pop_back();
} }
result.kind = GDScriptDataType::GDSCRIPT; result.kind = GDScriptDataType::GDSCRIPT;
result.script_type = script.ptr(); result.script_type_ref = script;
result.script_type = result.script_type_ref.ptr();
result.native_type = script->get_instance_base_type(); result.native_type = script->get_instance_base_type();
} else { } else {
result.kind = GDScriptDataType::GDSCRIPT; result.kind = GDScriptDataType::GDSCRIPT;
result.script_type = GDScriptCache::get_shallow_script(p_datatype.script_path, main_script->path).ptr(); result.script_type_ref = GDScriptCache::get_shallow_script(p_datatype.script_path, main_script->path);
result.script_type = result.script_type_ref.ptr();
result.native_type = p_datatype.native_type; result.native_type = p_datatype.native_type;
} }
} }
@ -151,8 +154,8 @@ GDScriptDataType GDScriptCompiler::_gdtype_from_datatype(const GDScriptParser::D
// Only hold strong reference to the script if it's not the owner of the // Only hold strong reference to the script if it's not the owner of the
// element qualified with this type, to avoid cyclic references (leaks). // element qualified with this type, to avoid cyclic references (leaks).
if (result.script_type && result.script_type != p_owner) { if (result.script_type && result.script_type == p_owner) {
result.script_type_ref = Ref<Script>(result.script_type); result.script_type_ref = Ref<Script>();
} }
return result; return result;