Skip to content

Commit

Permalink
Merge pull request #79683 from Zylann/fix_gdext_get_property_list
Browse files Browse the repository at this point in the history
GDExtension: Fix `_get_property_list` not working correctly in parent classes
  • Loading branch information
YuriSizov committed Jul 26, 2023
2 parents 1de9171 + e8731f4 commit a68137b
Showing 1 changed file with 13 additions and 11 deletions.
24 changes: 13 additions & 11 deletions core/object/object.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -486,19 +486,21 @@ void Object::get_property_list(List<PropertyInfo> *p_list, bool p_reversed) cons
const ObjectGDExtension *current_extension = _extension;
while (current_extension) {
p_list->push_back(PropertyInfo(Variant::NIL, current_extension->class_name, PROPERTY_HINT_NONE, String(), PROPERTY_USAGE_CATEGORY));

ClassDB::get_property_list(current_extension->class_name, p_list, true, this);
current_extension = current_extension->parent;
}
}

if (_extension && _extension->get_property_list) {
uint32_t pcount;
const GDExtensionPropertyInfo *pinfo = _extension->get_property_list(_extension_instance, &pcount);
for (uint32_t i = 0; i < pcount; i++) {
p_list->push_back(PropertyInfo(pinfo[i]));
}
if (_extension->free_property_list) {
_extension->free_property_list(_extension_instance, pinfo);
if (current_extension->get_property_list) {
uint32_t pcount;
const GDExtensionPropertyInfo *pinfo = current_extension->get_property_list(_extension_instance, &pcount);
for (uint32_t i = 0; i < pcount; i++) {
p_list->push_back(PropertyInfo(pinfo[i]));
}
if (current_extension->free_property_list) {
current_extension->free_property_list(_extension_instance, pinfo);
}
}

current_extension = current_extension->parent;
}
}

Expand Down

0 comments on commit a68137b

Please sign in to comment.