diff options
author | SaracenOne <SaracenOne@gmail.com> | 2021-08-10 02:39:42 +0100 |
---|---|---|
committer | SaracenOne <SaracenOne@gmail.com> | 2021-08-10 02:41:44 +0100 |
commit | 861bb3a48890e7c46310f47ce19eaa8578bbc566 (patch) | |
tree | c9b18acf4a8a221ccc3a971eac0b92f7ba76a844 /modules/gdscript/gdscript.cpp | |
parent | f3ddc14d3829ed09d6eab81811bcfb1314626ddf (diff) | |
download | redot-engine-861bb3a48890e7c46310f47ce19eaa8578bbc566.tar.gz |
Automatically call the _init function on base class if one does not exist.
Diffstat (limited to 'modules/gdscript/gdscript.cpp')
-rw-r--r-- | modules/gdscript/gdscript.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/modules/gdscript/gdscript.cpp b/modules/gdscript/gdscript.cpp index 8957b00a1b..8c6e56aeb9 100644 --- a/modules/gdscript/gdscript.cpp +++ b/modules/gdscript/gdscript.cpp @@ -87,6 +87,19 @@ Object *GDScriptNativeClass::instantiate() { return ClassDB::instantiate(name); } +GDScriptFunction *GDScript::_super_constructor(GDScript *p_script) { + if (p_script->initializer) { + return p_script->initializer; + } else { + GDScript *base = p_script->_base; + if (base != nullptr) { + return _super_constructor(base); + } else { + return nullptr; + } + } +} + void GDScript::_super_implicit_constructor(GDScript *p_script, GDScriptInstance *p_instance, Callable::CallError &r_error) { GDScript *base = p_script->_base; if (base != nullptr) { @@ -135,6 +148,8 @@ GDScriptInstance *GDScript::_create_instance(const Variant **p_args, int p_argco if (p_argcount < 0) { return instance; } + + initializer = _super_constructor(this); if (initializer != nullptr) { initializer->call(instance, p_args, p_argcount, r_error); if (r_error.error != Callable::CallError::CALL_OK) { |