You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-09 12:50:35 +00:00
GDExtension: fix _get_property_list not working correctly in parent classes
This commit is contained in:
@@ -486,19 +486,21 @@ void Object::get_property_list(List<PropertyInfo> *p_list, bool p_reversed) cons
|
|||||||
const ObjectGDExtension *current_extension = _extension;
|
const ObjectGDExtension *current_extension = _extension;
|
||||||
while (current_extension) {
|
while (current_extension) {
|
||||||
p_list->push_back(PropertyInfo(Variant::NIL, current_extension->class_name, PROPERTY_HINT_NONE, String(), PROPERTY_USAGE_CATEGORY));
|
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) {
|
ClassDB::get_property_list(current_extension->class_name, p_list, true, this);
|
||||||
uint32_t pcount;
|
|
||||||
const GDExtensionPropertyInfo *pinfo = _extension->get_property_list(_extension_instance, &pcount);
|
if (current_extension->get_property_list) {
|
||||||
for (uint32_t i = 0; i < pcount; i++) {
|
uint32_t pcount;
|
||||||
p_list->push_back(PropertyInfo(pinfo[i]));
|
const GDExtensionPropertyInfo *pinfo = current_extension->get_property_list(_extension_instance, &pcount);
|
||||||
}
|
for (uint32_t i = 0; i < pcount; i++) {
|
||||||
if (_extension->free_property_list) {
|
p_list->push_back(PropertyInfo(pinfo[i]));
|
||||||
_extension->free_property_list(_extension_instance, pinfo);
|
}
|
||||||
|
if (current_extension->free_property_list) {
|
||||||
|
current_extension->free_property_list(_extension_instance, pinfo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
current_extension = current_extension->parent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user