summaryrefslogtreecommitdiffstats
path: root/modules/mono
diff options
context:
space:
mode:
authoralpacat <hayahane02@gmail.com>2024-09-15 03:54:40 +0800
committeralpacat <hayahane02@gmail.com>2024-09-19 12:49:15 +0800
commit7df5b78acab3120168cf0514b8b6fa2e7f826859 (patch)
tree78612fbaba71fce2017c3b5b53cb7b44f3dd8321 /modules/mono
parent6681f2563b99e14929a8acb27f4908fece398ef1 (diff)
downloadredot-engine-7df5b78acab3120168cf0514b8b6fa2e7f826859.tar.gz
Reorder C# script properties to fix editor serialization
Diffstat (limited to 'modules/mono')
-rw-r--r--modules/mono/csharp_script.cpp41
1 files changed, 34 insertions, 7 deletions
diff --git a/modules/mono/csharp_script.cpp b/modules/mono/csharp_script.cpp
index 5d59c33636..1210ca3a30 100644
--- a/modules/mono/csharp_script.cpp
+++ b/modules/mono/csharp_script.cpp
@@ -1497,11 +1497,23 @@ bool CSharpInstance::get(const StringName &p_name, Variant &r_ret) const {
void CSharpInstance::get_property_list(List<PropertyInfo> *p_properties) const {
List<PropertyInfo> props;
- script->get_script_property_list(&props);
+ ERR_FAIL_COND(!script.is_valid());
+#ifdef TOOLS_ENABLED
+ for (const PropertyInfo &prop : script->exported_members_cache) {
+ props.push_back(prop);
+ }
+#else
+ for (const KeyValue<StringName, PropertyInfo> &E : script->member_info) {
+ props.push_front(E.value);
+ }
+#endif
- // Call _get_property_list
+ for (PropertyInfo &prop : props) {
+ validate_property(prop);
+ p_properties->push_back(prop);
+ }
- ERR_FAIL_COND(!script.is_valid());
+ // Call _get_property_list
StringName method = SNAME("_get_property_list");
@@ -1524,10 +1536,25 @@ void CSharpInstance::get_property_list(List<PropertyInfo> *p_properties) const {
}
}
- props.reverse();
- for (PropertyInfo &prop : props) {
- validate_property(prop);
- p_properties->push_front(prop);
+ CSharpScript *top = script.ptr()->base_script.ptr();
+ while (top != nullptr) {
+ props.clear();
+#ifdef TOOLS_ENABLED
+ for (const PropertyInfo &prop : top->exported_members_cache) {
+ props.push_back(prop);
+ }
+#else
+ for (const KeyValue<StringName, PropertyInfo> &E : top->member_info) {
+ props.push_front(E.value);
+ }
+#endif
+
+ for (PropertyInfo &prop : props) {
+ validate_property(prop);
+ p_properties->push_back(prop);
+ }
+
+ top = top->base_script.ptr();
}
}