Merge pull request #90446 from aaronp64/theme_override_tooltips
Fix `theme_override` tooltip caching
This commit is contained in:
commit
dffa8b1712
2 changed files with 17 additions and 12 deletions
|
@ -3220,12 +3220,13 @@ void EditorInspector::update_tree() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Search for the doc path in the cache.
|
// Search for the doc path in the cache.
|
||||||
HashMap<StringName, HashMap<StringName, String>>::Iterator E = doc_path_cache.find(classname);
|
HashMap<StringName, HashMap<StringName, DocCacheInfo>>::Iterator E = doc_cache.find(classname);
|
||||||
if (E) {
|
if (E) {
|
||||||
HashMap<StringName, String>::Iterator F = E->value.find(propname);
|
HashMap<StringName, DocCacheInfo>::Iterator F = E->value.find(propname);
|
||||||
if (F) {
|
if (F) {
|
||||||
found = true;
|
found = true;
|
||||||
doc_path = F->value;
|
doc_path = F->value.doc_path;
|
||||||
|
theme_item_name = F->value.theme_item_name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3246,23 +3247,22 @@ void EditorInspector::update_tree() {
|
||||||
theme_item_name = F->value.theme_properties[i].name;
|
theme_item_name = F->value.theme_properties[i].name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_native_class) {
|
|
||||||
doc_path_cache[classname][propname] = doc_path;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
for (int i = 0; i < F->value.properties.size(); i++) {
|
for (int i = 0; i < F->value.properties.size(); i++) {
|
||||||
String doc_path_current = "class_property:" + F->value.name + ":" + F->value.properties[i].name;
|
String doc_path_current = "class_property:" + F->value.name + ":" + F->value.properties[i].name;
|
||||||
if (F->value.properties[i].name == propname.operator String()) {
|
if (F->value.properties[i].name == propname.operator String()) {
|
||||||
doc_path = doc_path_current;
|
doc_path = doc_path_current;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_native_class) {
|
|
||||||
doc_path_cache[classname][propname] = doc_path;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (is_native_class) {
|
||||||
|
DocCacheInfo cache_info;
|
||||||
|
cache_info.doc_path = doc_path;
|
||||||
|
cache_info.theme_item_name = theme_item_name;
|
||||||
|
doc_cache[classname][propname] = cache_info;
|
||||||
|
}
|
||||||
|
|
||||||
if (!doc_path.is_empty() || F->value.inherits.is_empty()) {
|
if (!doc_path.is_empty() || F->value.inherits.is_empty()) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -505,7 +505,12 @@ class EditorInspector : public ScrollContainer {
|
||||||
int property_focusable;
|
int property_focusable;
|
||||||
int update_scroll_request;
|
int update_scroll_request;
|
||||||
|
|
||||||
HashMap<StringName, HashMap<StringName, String>> doc_path_cache;
|
struct DocCacheInfo {
|
||||||
|
String doc_path;
|
||||||
|
String theme_item_name;
|
||||||
|
};
|
||||||
|
|
||||||
|
HashMap<StringName, HashMap<StringName, DocCacheInfo>> doc_cache;
|
||||||
HashSet<StringName> restart_request_props;
|
HashSet<StringName> restart_request_props;
|
||||||
HashMap<String, String> custom_property_descriptions;
|
HashMap<String, String> custom_property_descriptions;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue