summaryrefslogtreecommitdiffstats
path: root/scene/property_list_helper.cpp
diff options
context:
space:
mode:
authorkobewi <kobewi4e@gmail.com>2024-02-11 12:09:55 +0100
committerkobewi <kobewi4e@gmail.com>2024-02-11 12:09:55 +0100
commit4f29ef82db50bb38f0f2ac1020350b8cc36d5079 (patch)
tree618f9c22d8dfb5b92d582b788fda50bf447f4080 /scene/property_list_helper.cpp
parent4e990cd7e51d17cf24f854cc33b2715eaa27200f (diff)
downloadredot-engine-4f29ef82db50bb38f0f2ac1020350b8cc36d5079.tar.gz
Add PropertyListHelper to PopupMenu
Diffstat (limited to 'scene/property_list_helper.cpp')
-rw-r--r--scene/property_list_helper.cpp55
1 files changed, 29 insertions, 26 deletions
diff --git a/scene/property_list_helper.cpp b/scene/property_list_helper.cpp
index 596a6a050a..2d3179d9fd 100644
--- a/scene/property_list_helper.cpp
+++ b/scene/property_list_helper.cpp
@@ -47,35 +47,28 @@ const PropertyListHelper::Property *PropertyListHelper::_get_property(const Stri
return property_list.getptr(components[1]);
}
-void PropertyListHelper::_bind_property(const Property &p_property, const Object *p_object) {
- Property property = p_property;
- property.info = p_property.info;
- property.default_value = p_property.default_value;
- property.setter = Callable(p_object, p_property.setter_name);
- property.getter = Callable(p_object, p_property.getter_name);
-
- property_list[property.info.name] = property;
+void PropertyListHelper::_call_setter(const MethodBind *p_setter, int p_index, const Variant &p_value) const {
+ Variant args[] = { p_index, p_value };
+ const Variant *argptrs[] = { &args[0], &args[1] };
+ Callable::CallError ce;
+ p_setter->call(object, argptrs, 2, ce);
}
-void PropertyListHelper::set_prefix(const String &p_prefix) {
- prefix = p_prefix;
+Variant PropertyListHelper::_call_getter(const MethodBind *p_getter, int p_index) const {
+ Callable::CallError ce;
+ Variant args[] = { p_index };
+ const Variant *argptrs[] = { &args[0] };
+ return p_getter->call(object, argptrs, 1, ce);
}
-void PropertyListHelper::register_property(const PropertyInfo &p_info, const Variant &p_default, const StringName &p_setter, const StringName &p_getter) {
- Property property;
- property.info = p_info;
- property.default_value = p_default;
- property.setter_name = p_setter;
- property.getter_name = p_getter;
-
- property_list[p_info.name] = property;
+void PropertyListHelper::set_prefix(const String &p_prefix) {
+ prefix = p_prefix;
}
-void PropertyListHelper::setup_for_instance(const PropertyListHelper &p_base, const Object *p_object) {
+void PropertyListHelper::setup_for_instance(const PropertyListHelper &p_base, Object *p_object) {
prefix = p_base.prefix;
- for (const KeyValue<String, Property> &E : p_base.property_list) {
- _bind_property(E.value, p_object);
- }
+ property_list = p_base.property_list;
+ object = p_object;
}
void PropertyListHelper::get_property_list(List<PropertyInfo> *p_list, int p_count) const {
@@ -84,7 +77,7 @@ void PropertyListHelper::get_property_list(List<PropertyInfo> *p_list, int p_cou
const Property &property = E.value;
PropertyInfo info = property.info;
- if (property.getter.call(i) == property.default_value) {
+ if (_call_getter(property.getter, i) == property.default_value) {
info.usage &= (~PROPERTY_USAGE_STORAGE);
}
@@ -99,7 +92,7 @@ bool PropertyListHelper::property_get_value(const String &p_property, Variant &r
const Property *property = _get_property(p_property, &index);
if (property) {
- r_ret = property->getter.call(index);
+ r_ret = _call_getter(property->getter, index);
return true;
}
return false;
@@ -110,7 +103,7 @@ bool PropertyListHelper::property_set_value(const String &p_property, const Vari
const Property *property = _get_property(p_property, &index);
if (property) {
- property->setter.call(index, p_value);
+ _call_setter(property->setter, index, p_value);
return true;
}
return false;
@@ -121,7 +114,7 @@ bool PropertyListHelper::property_can_revert(const String &p_property) const {
const Property *property = _get_property(p_property, &index);
if (property) {
- return property->getter.call(index) != property->default_value;
+ return _call_getter(property->getter, index) != property->default_value;
}
return false;
}
@@ -136,3 +129,13 @@ bool PropertyListHelper::property_get_revert(const String &p_property, Variant &
}
return false;
}
+
+PropertyListHelper::~PropertyListHelper() {
+ // No object = it's the main helper. Do a cleanup.
+ if (!object) {
+ for (const KeyValue<String, Property> &E : property_list) {
+ memdelete(E.value.setter);
+ memdelete(E.value.getter);
+ }
+ }
+}