summaryrefslogtreecommitdiffstats
path: root/modules/mono
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-09-19 17:13:34 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-09-19 17:13:34 +0200
commitae872a4ed58e49205f6845de912cb774d7a329de (patch)
tree7cf7bbb9bfaf5ac5cd0cf072f5c37a11b163f451 /modules/mono
parent575c3212c5e4d83d654466e9003eab6e7cc6f8c6 (diff)
parent7df5b78acab3120168cf0514b8b6fa2e7f826859 (diff)
downloadredot-engine-ae872a4ed58e49205f6845de912cb774d7a329de.tar.gz
Merge pull request #97014 from hayahane/fix_script_property_order
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 f47e6d209a..3d12994469 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();
}
}