From 76c0a3fea07a31c5760ba0f75116fb557a7149fd Mon Sep 17 00:00:00 2001 From: Hugo Locurcio Date: Wed, 19 Apr 2023 02:00:13 +0200 Subject: [PATCH] Display enum value descriptions in the editor inspector help tooltips This makes it possible to see what each value does without having to open a documentation tab. Some enum value names may be mismatched as the API doesn't always match the property hint used in the editor. --- editor/editor_inspector.cpp | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/editor/editor_inspector.cpp b/editor/editor_inspector.cpp index cd762002b2d7..bcbef30b3e35 100644 --- a/editor/editor_inspector.cpp +++ b/editor/editor_inspector.cpp @@ -3143,11 +3143,32 @@ void EditorInspector::update_tree() { if (!found) { // Build the property description String and add it to the cache. DocTools *dd = EditorHelp::get_doc_data(); - HashMap::Iterator F = dd->class_list.find(classname); + HashMap::ConstIterator F = dd->class_list.find(classname); while (F && doc_info.description.is_empty()) { for (int i = 0; i < F->value.properties.size(); i++) { if (F->value.properties[i].name == propname.operator String()) { doc_info.description = DTR(F->value.properties[i].description); + + const Vector class_enum = F->value.properties[i].enumeration.split("."); + const String class_name = class_enum[0]; + const String enum_name = class_enum.size() >= 2 ? class_enum[1] : ""; + if (!enum_name.is_empty()) { + HashMap::ConstIterator enum_class = dd->class_list.find(class_name); + if (enum_class) { + for (DocData::ConstantDoc val : enum_class->value.constants) { + // Don't display `_MAX` enum value descriptions, as these are never exposed in the inspector. + if (val.enumeration == enum_name && !val.name.ends_with("_MAX")) { + const String enum_value = EditorPropertyNameProcessor::get_singleton()->process_name(val.name, EditorPropertyNameProcessor::STYLE_CAPITALIZED); + // Prettify the enum value display, so that "_" becomes "Value". + doc_info.description += vformat( + "\n[b]%s:[/b] %s", + enum_value.trim_prefix(EditorPropertyNameProcessor::get_singleton()->process_name(enum_name, EditorPropertyNameProcessor::STYLE_CAPITALIZED) + " "), + DTR(val.description).trim_prefix("\n")); + } + } + } + } + doc_info.path = "class_property:" + F->value.name + ":" + F->value.properties[i].name; break; }