From fbfdd5e1104a883c311fddf3a7ed6763f35f3781 Mon Sep 17 00:00:00 2001 From: George Marques Date: Tue, 9 Mar 2021 12:30:06 -0300 Subject: [PATCH] Add functions to retrieve type of a typed Array --- core/variant/array.cpp | 16 ++++++++++++++++ core/variant/array.h | 4 ++++ 2 files changed, 20 insertions(+) diff --git a/core/variant/array.cpp b/core/variant/array.cpp index 2ad5e1b3b94..707140ba1bf 100644 --- a/core/variant/array.cpp +++ b/core/variant/array.cpp @@ -547,6 +547,22 @@ void Array::set_typed(uint32_t p_type, const StringName &p_class_name, const Var _p->typed.where = "TypedArray"; } +bool Array::is_typed() const { + return _p->typed.type != Variant::NIL; +} + +uint32_t Array::get_typed_builtin() const { + return _p->typed.type; +} + +StringName Array::get_typed_class_name() const { + return _p->typed.class_name; +} + +Variant Array::get_typed_script() const { + return _p->typed.script; +} + Array::Array(const Array &p_from) { _p = nullptr; _ref(p_from); diff --git a/core/variant/array.h b/core/variant/array.h index 9865f23d32f..8b67f7f085d 100644 --- a/core/variant/array.h +++ b/core/variant/array.h @@ -113,6 +113,10 @@ public: bool typed_assign(const Array &p_other); void set_typed(uint32_t p_type, const StringName &p_class_name, const Variant &p_script); + bool is_typed() const; + uint32_t get_typed_builtin() const; + StringName get_typed_class_name() const; + Variant get_typed_script() const; Array(const Array &p_from); Array(); ~Array();