Fix enums coming from other classes without preload

Fix #19704, fix #26001
This commit is contained in:
Bojidar Marinov 2019-03-05 23:19:02 +02:00
parent c40877bc6a
commit 9637e42705
No known key found for this signature in database
GPG key ID: 4D546A8F1E091856
3 changed files with 35 additions and 0 deletions

View file

@ -409,6 +409,11 @@ bool PlaceHolderScriptInstance::get(const StringName &p_name, Variant &r_ret) co
return true; return true;
} }
if (constants.has(p_name)) {
r_ret = constants[p_name];
return true;
}
if (!script->is_placeholder_fallback_enabled()) { if (!script->is_placeholder_fallback_enabled()) {
Variant defval; Variant defval;
if (script->get_property_default_value(p_name, defval)) { if (script->get_property_default_value(p_name, defval)) {
@ -444,6 +449,13 @@ Variant::Type PlaceHolderScriptInstance::get_property_type(const StringName &p_n
*r_is_valid = true; *r_is_valid = true;
return values[p_name].get_type(); return values[p_name].get_type();
} }
if (constants.has(p_name)) {
if (r_is_valid)
*r_is_valid = true;
return constants[p_name].get_type();
}
if (r_is_valid) if (r_is_valid)
*r_is_valid = false; *r_is_valid = false;
@ -513,6 +525,9 @@ void PlaceHolderScriptInstance::update(const List<PropertyInfo> &p_properties, c
owner->_change_notify(); owner->_change_notify();
} }
//change notify //change notify
constants.clear();
script->get_constants(&constants);
} }
void PlaceHolderScriptInstance::property_set_fallback(const StringName &p_name, const Variant &p_value, bool *r_valid) { void PlaceHolderScriptInstance::property_set_fallback(const StringName &p_name, const Variant &p_value, bool *r_valid) {
@ -552,6 +567,13 @@ Variant PlaceHolderScriptInstance::property_get_fallback(const StringName &p_nam
*r_valid = true; *r_valid = true;
return E->value(); return E->value();
} }
E = constants.find(p_name);
if (E) {
if (r_valid)
*r_valid = true;
return E->value();
}
} }
if (r_valid) if (r_valid)

View file

@ -336,6 +336,7 @@ class PlaceHolderScriptInstance : public ScriptInstance {
Object *owner; Object *owner;
List<PropertyInfo> properties; List<PropertyInfo> properties;
Map<StringName, Variant> values; Map<StringName, Variant> values;
Map<StringName, Variant> constants;
ScriptLanguage *language; ScriptLanguage *language;
Ref<Script> script; Ref<Script> script;

View file

@ -815,6 +815,16 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
} }
if (!dependencies_only) { if (!dependencies_only) {
if (!bfn && ScriptServer::is_global_class(identifier)) {
Ref<Script> scr = ResourceLoader::load(ScriptServer::get_global_class_path(identifier));
if (scr.is_valid() && scr->is_valid()) {
ConstantNode *constant = alloc_node<ConstantNode>();
constant->value = scr;
expr = constant;
bfn = true;
}
}
// Check parents for the constant // Check parents for the constant
if (!bfn && cln->extends_file != StringName()) { if (!bfn && cln->extends_file != StringName()) {
Ref<GDScript> parent = ResourceLoader::load(cln->extends_file); Ref<GDScript> parent = ResourceLoader::load(cln->extends_file);
@ -7247,6 +7257,7 @@ GDScriptParser::DataType GDScriptParser::_reduce_identifier_type(const DataType
DataType result; DataType result;
result.has_type = true; result.has_type = true;
result.script_type = scr; result.script_type = scr;
result.is_constant = true;
result.is_meta_type = true; result.is_meta_type = true;
Ref<GDScript> gds = scr; Ref<GDScript> gds = scr;
if (gds.is_valid()) { if (gds.is_valid()) {
@ -7297,6 +7308,7 @@ GDScriptParser::DataType GDScriptParser::_reduce_identifier_type(const DataType
if (singleton.is_valid()) { if (singleton.is_valid()) {
DataType result; DataType result;
result.has_type = true; result.has_type = true;
result.is_constant = true;
result.script_type = singleton; result.script_type = singleton;
Ref<GDScript> gds = singleton; Ref<GDScript> gds = singleton;