summaryrefslogtreecommitdiff
path: root/core/io
diff options
context:
space:
mode:
authorMai Lavelle <mai.lavelle@gmail.com>2023-02-01 01:21:09 -0500
committerMai Lavelle <mai.lavelle@gmail.com>2023-02-01 01:22:43 -0500
commit87e6885f5ef36bddbbdaebf69a611e9d040c0cc5 (patch)
tree46afa1ecec10efb7279bf4083a61c5bc256ba239 /core/io
parent935a6ef46b7c6af4239b6adce41b8198f051b57a (diff)
Fix loading of binary resources with typed arrays
Diffstat (limited to 'core/io')
-rw-r--r--core/io/resource_format_binary.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/core/io/resource_format_binary.cpp b/core/io/resource_format_binary.cpp
index c0463de427..38f41d645c 100644
--- a/core/io/resource_format_binary.cpp
+++ b/core/io/resource_format_binary.cpp
@@ -832,6 +832,18 @@ Error ResourceLoaderBinary::load() {
}
}
+ if (value.get_type() == Variant::ARRAY) {
+ Array set_array = value;
+ bool is_get_valid = false;
+ Variant get_value = res->get(name, &is_get_valid);
+ if (is_get_valid && get_value.get_type() == Variant::ARRAY) {
+ Array get_array = get_value;
+ if (!set_array.is_same_typed(get_array)) {
+ value = Array(set_array, get_array.get_typed_builtin(), get_array.get_typed_class_name(), get_array.get_typed_script());
+ }
+ }
+ }
+
if (set_valid) {
res->set(name, value);
}