Merge pull request #61867 from Bromeon/refactor/property-info

This commit is contained in:
Rémi Verschelde 2022-06-30 15:45:31 +02:00 committed by GitHub
commit daa055d479
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 17 additions and 27 deletions

View File

@ -55,14 +55,7 @@ protected:
virtual PropertyInfo _gen_argument_type_info(int p_arg) const override { virtual PropertyInfo _gen_argument_type_info(int p_arg) const override {
GDNativePropertyInfo pinfo; GDNativePropertyInfo pinfo;
get_argument_info_func(method_userdata, p_arg, &pinfo); get_argument_info_func(method_userdata, p_arg, &pinfo);
PropertyInfo ret; return PropertyInfo(pinfo);
ret.type = Variant::Type(pinfo.type);
ret.name = pinfo.name;
ret.class_name = pinfo.class_name;
ret.hint = PropertyHint(pinfo.hint);
ret.usage = pinfo.usage;
ret.class_name = pinfo.class_name;
return ret;
} }
public: public:
@ -204,16 +197,11 @@ void NativeExtension::_register_extension_class_property(const GDNativeExtension
NativeExtension *self = static_cast<NativeExtension *>(p_library); NativeExtension *self = static_cast<NativeExtension *>(p_library);
StringName class_name = p_class_name; StringName class_name = p_class_name;
ERR_FAIL_COND_MSG(!self->extension_classes.has(class_name), "Attempt to register extension class property '" + String(p_info->name) + "' for unexisting class '" + class_name + "'."); String property_name = p_info->name;
ERR_FAIL_COND_MSG(!self->extension_classes.has(class_name), "Attempt to register extension class property '" + property_name + "' for unexisting class '" + class_name + "'.");
//Extension *extension = &self->extension_classes[class_name]; //Extension *extension = &self->extension_classes[class_name];
PropertyInfo pinfo; PropertyInfo pinfo(*p_info);
pinfo.type = Variant::Type(p_info->type);
pinfo.name = p_info->name;
pinfo.class_name = p_info->class_name;
pinfo.hint = PropertyHint(p_info->hint);
pinfo.hint_string = p_info->hint_string;
pinfo.usage = p_info->usage;
ClassDB::add_property(class_name, pinfo, p_setter, p_getter); ClassDB::add_property(class_name, pinfo, p_setter, p_getter);
} }
@ -245,13 +233,7 @@ void NativeExtension::_register_extension_class_signal(const GDNativeExtensionCl
MethodInfo s; MethodInfo s;
s.name = p_signal_name; s.name = p_signal_name;
for (int i = 0; i < p_argument_count; i++) { for (int i = 0; i < p_argument_count; i++) {
PropertyInfo arg; PropertyInfo arg(p_argument_info[i]);
arg.type = Variant::Type(p_argument_info[i].type);
arg.name = p_argument_info[i].name;
arg.class_name = p_argument_info[i].class_name;
arg.hint = PropertyHint(p_argument_info[i].hint);
arg.hint_string = p_argument_info[i].hint_string;
arg.usage = p_argument_info[i].usage;
s.arguments.push_back(arg); s.arguments.push_back(arg);
} }
ClassDB::add_signal(class_name, s); ClassDB::add_signal(class_name, s);

View File

@ -493,7 +493,7 @@ void Object::get_property_list(List<PropertyInfo> *p_list, bool p_reversed) cons
uint32_t pcount; uint32_t pcount;
const GDNativePropertyInfo *pinfo = _extension->get_property_list(_extension_instance, &pcount); const GDNativePropertyInfo *pinfo = _extension->get_property_list(_extension_instance, &pcount);
for (uint32_t i = 0; i < pcount; i++) { for (uint32_t i = 0; i < pcount; i++) {
p_list->push_back(PropertyInfo(Variant::Type(pinfo[i].type), pinfo[i].class_name, PropertyHint(pinfo[i].hint), pinfo[i].hint_string, pinfo[i].usage, pinfo[i].class_name)); p_list->push_back(PropertyInfo(pinfo[i]));
} }
if (_extension->free_property_list) { if (_extension->free_property_list) {
_extension->free_property_list(_extension_instance, pinfo); _extension->free_property_list(_extension_instance, pinfo);

View File

@ -190,6 +190,14 @@ struct PropertyInfo {
type(Variant::OBJECT), type(Variant::OBJECT),
class_name(p_class_name) {} class_name(p_class_name) {}
explicit PropertyInfo(const GDNativePropertyInfo &pinfo) :
type((Variant::Type)pinfo.type),
name(pinfo.name),
class_name(pinfo.class_name), // can be null
hint((PropertyHint)pinfo.hint),
hint_string(pinfo.hint_string), // can be null
usage(pinfo.usage) {}
bool operator==(const PropertyInfo &p_info) const { bool operator==(const PropertyInfo &p_info) const {
return ((type == p_info.type) && return ((type == p_info.type) &&
(name == p_info.name) && (name == p_info.name) &&

View File

@ -671,7 +671,7 @@ public:
uint32_t pcount; uint32_t pcount;
const GDNativePropertyInfo *pinfo = native_info->get_property_list_func(instance, &pcount); const GDNativePropertyInfo *pinfo = native_info->get_property_list_func(instance, &pcount);
for (uint32_t i = 0; i < pcount; i++) { for (uint32_t i = 0; i < pcount; i++) {
p_list->push_back(PropertyInfo(Variant::Type(pinfo[i].type), pinfo[i].class_name, PropertyHint(pinfo[i].hint), pinfo[i].hint_string, pinfo[i].usage, pinfo[i].class_name)); p_list->push_back(PropertyInfo(pinfo[i]));
} }
if (native_info->free_property_list_func) { if (native_info->free_property_list_func) {
native_info->free_property_list_func(instance, pinfo); native_info->free_property_list_func(instance, pinfo);
@ -716,9 +716,9 @@ public:
m.name = minfo[i].name; m.name = minfo[i].name;
m.flags = minfo[i].flags; m.flags = minfo[i].flags;
m.id = minfo[i].id; m.id = minfo[i].id;
m.return_val = PropertyInfo(Variant::Type(minfo[i].return_value.type), minfo[i].return_value.class_name, PropertyHint(minfo[i].return_value.hint), minfo[i].return_value.hint_string, minfo[i].return_value.usage, minfo[i].return_value.class_name); m.return_val = PropertyInfo(minfo[i].return_value);
for (uint32_t j = 0; j < minfo[i].argument_count; j++) { for (uint32_t j = 0; j < minfo[i].argument_count; j++) {
m.arguments.push_back(PropertyInfo(Variant::Type(minfo[i].arguments[j].type), minfo[i].arguments[j].class_name, PropertyHint(minfo[i].arguments[j].hint), minfo[i].arguments[j].hint_string, minfo[i].arguments[j].usage, minfo[i].arguments[j].class_name)); m.arguments.push_back(PropertyInfo(minfo[i].arguments[j]));
} }
const Variant *def_values = (const Variant *)minfo[i].default_arguments; const Variant *def_values = (const Variant *)minfo[i].default_arguments;
for (uint32_t j = 0; j < minfo[i].default_argument_count; j++) { for (uint32_t j = 0; j < minfo[i].default_argument_count; j++) {