diff options
author | RĂ©mi Verschelde <rverschelde@gmail.com> | 2019-07-19 17:58:17 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-07-19 17:58:17 +0200 |
commit | c317a3ce16a35b21d85b250a0e810526bb89db38 (patch) | |
tree | dfe7278154a4901e520c5ddbea575adf1f12a3ae | |
parent | e12f3a9bfd15429a2f574bb7cc9e096aa02e7c9c (diff) | |
parent | e86f6faf641ea909798ba7fef3414eae6d1400b2 (diff) |
Merge pull request #30354 from LikeLakers2/multinodeedit-same-type-properties
MultiNodeEdit now only shows properties with the exact same PropertyInfo data
-rw-r--r-- | core/object.h | 9 | ||||
-rw-r--r-- | editor/multi_node_edit.cpp | 4 |
2 files changed, 12 insertions, 1 deletions
diff --git a/core/object.h b/core/object.h index 1e0b22c086..e6c5b7c5b9 100644 --- a/core/object.h +++ b/core/object.h @@ -179,6 +179,15 @@ struct PropertyInfo { usage(PROPERTY_USAGE_DEFAULT) { } + bool operator==(const PropertyInfo &p_info) const { + return ((type == p_info.type) && + (name == p_info.name) && + (class_name == p_info.class_name) && + (hint == p_info.hint) && + (hint_string == p_info.hint_string) && + (usage == p_info.usage)); + } + bool operator<(const PropertyInfo &p_info) const { return name < p_info.name; } diff --git a/editor/multi_node_edit.cpp b/editor/multi_node_edit.cpp index 6af7e4bd00..85e47594a8 100644 --- a/editor/multi_node_edit.cpp +++ b/editor/multi_node_edit.cpp @@ -152,7 +152,9 @@ void MultiNodeEdit::_get_property_list(List<PropertyInfo> *p_list) const { datas.push_back(usage.getptr(F->get().name)); } - usage[F->get().name].uses++; + // Make sure only properties with the same exact PropertyInfo data will appear + if (usage[F->get().name].info == F->get()) + usage[F->get().name].uses++; } nc++; |