From 9637e427053e359b66fb4b7141b0b237fdb53773 Mon Sep 17 00:00:00 2001 From: Bojidar Marinov Date: Tue, 5 Mar 2019 23:19:02 +0200 Subject: [PATCH] Fix enums coming from other classes without preload Fix #19704, fix #26001 --- core/script_language.cpp | 22 ++++++++++++++++++++++ core/script_language.h | 1 + modules/gdscript/gdscript_parser.cpp | 12 ++++++++++++ 3 files changed, 35 insertions(+) diff --git a/core/script_language.cpp b/core/script_language.cpp index f0310ffc310..1c244661b0d 100644 --- a/core/script_language.cpp +++ b/core/script_language.cpp @@ -409,6 +409,11 @@ bool PlaceHolderScriptInstance::get(const StringName &p_name, Variant &r_ret) co return true; } + if (constants.has(p_name)) { + r_ret = constants[p_name]; + return true; + } + if (!script->is_placeholder_fallback_enabled()) { Variant 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; 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) *r_is_valid = false; @@ -513,6 +525,9 @@ void PlaceHolderScriptInstance::update(const List &p_properties, c owner->_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) { @@ -552,6 +567,13 @@ Variant PlaceHolderScriptInstance::property_get_fallback(const StringName &p_nam *r_valid = true; return E->value(); } + + E = constants.find(p_name); + if (E) { + if (r_valid) + *r_valid = true; + return E->value(); + } } if (r_valid) diff --git a/core/script_language.h b/core/script_language.h index 2d350976927..65fb0f0268a 100644 --- a/core/script_language.h +++ b/core/script_language.h @@ -336,6 +336,7 @@ class PlaceHolderScriptInstance : public ScriptInstance { Object *owner; List properties; Map values; + Map constants; ScriptLanguage *language; Ref