diff options
author | ordigdug <originaldigdug@yahoo.com> | 2018-07-12 15:18:08 -0400 |
---|---|---|
committer | ordigdug <originaldigdug@yahoo.com> | 2018-07-18 20:01:03 -0400 |
commit | afb4dfab22ffd1b87faa9dd596efa832f2475abb (patch) | |
tree | 249d3d8aa7186d8047c62a4385e353c6db7be343 /editor/editor_properties.cpp | |
parent | de910f8c26407ea37b97a94a6fb1a8731d3694c6 (diff) |
Fix -new inspector- Inconsistencies with exported enums - Fixes remaining issues in #19534
Diffstat (limited to 'editor/editor_properties.cpp')
-rw-r--r-- | editor/editor_properties.cpp | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/editor/editor_properties.cpp b/editor/editor_properties.cpp index 1f45902008..cd0bba4c9c 100644 --- a/editor/editor_properties.cpp +++ b/editor/editor_properties.cpp @@ -390,13 +390,37 @@ EditorPropertyCheck::EditorPropertyCheck() { void EditorPropertyEnum::_option_selected(int p_which) { - emit_signal("property_changed", get_edited_property(), p_which); + String text = options->get_item_text(p_which); + Vector<String> text_split = text.split(":"); + if (text_split.size() == 1) { + emit_signal("property_changed", get_edited_property(), p_which); + return; + } + String name = text_split[1]; + emit_signal("property_changed", get_edited_property(), name.to_int()); } void EditorPropertyEnum::update_property() { int which = get_edited_object()->get(get_edited_property()); - options->select(which); + if (which == 0) { + options->select(which); + return; + } + + for (int i = 0; i < options->get_item_count(); i++) { + String text = options->get_item_text(i); + Vector<String> text_split = text.split(":"); + if (text_split.size() == 1) { + options->select(which); + return; + } + String name = text_split[1]; + if (itos(which) == name) { + options->select(i); + return; + } + } } void EditorPropertyEnum::setup(const Vector<String> &p_options) { |