From 70c755b2e390d3edfb594a84a7531beb26b2bc07 Mon Sep 17 00:00:00 2001 From: Nathan Ridge Date: Thu, 23 Aug 2018 14:59:55 -0400 Subject: [PATCH] Include symbol role information in semantic highlighting (fixes #787) This allows clients to e.g. color references differently from declarations. --- src/message_handler.cc | 20 +++++++++++++++++--- src/message_handler.h | 2 ++ 2 files changed, 19 insertions(+), 3 deletions(-) diff --git a/src/message_handler.cc b/src/message_handler.cc index b3843e90a..e5bd7c915 100644 --- a/src/message_handler.cc +++ b/src/message_handler.cc @@ -113,6 +113,17 @@ void EmitInactiveLines(WorkingFile* working_file, QueueManager::WriteStdout(kMethodType_CqueryPublishInactiveRegions, out); } +struct SymbolAndRole { + SymbolIdx symbol; + Role role; + + bool operator==(const SymbolAndRole& o) const { + return symbol == o.symbol && role == o.role; + } +}; +MAKE_HASHABLE(SymbolAndRole, t.symbol, t.role); + + void EmitSemanticHighlighting(QueryDatabase* db, SemanticHighlightSymbolCache* semantic_cache, WorkingFile* working_file, @@ -127,13 +138,14 @@ void EmitSemanticHighlighting(QueryDatabase* db, semantic_cache->GetCacheForFile(file->def->path); // Group symbols together. - std::unordered_map + std::unordered_map grouped_symbols; for (QueryId::SymbolRef sym : file->def->all_symbols) { std::string_view detailed_name; lsSymbolKind parent_kind = lsSymbolKind::Unknown; lsSymbolKind kind = lsSymbolKind::Unknown; StorageClass storage = StorageClass::Invalid; + Role role = sym.role; // This switch statement also filters out symbols that are not highlighted. switch (sym.kind) { case SymbolKind::Func: { @@ -217,8 +229,9 @@ void EmitSemanticHighlighting(QueryDatabase* db, } optional loc = GetLsRange(working_file, sym.range); + SymbolAndRole key{sym, role}; if (loc) { - auto it = grouped_symbols.find(sym); + auto it = grouped_symbols.find(key); if (it != grouped_symbols.end()) { it->second.ranges.push_back(*loc); } else { @@ -228,8 +241,9 @@ void EmitSemanticHighlighting(QueryDatabase* db, symbol.parentKind = parent_kind; symbol.kind = kind; symbol.storage = storage; + symbol.role = role; symbol.ranges.push_back(*loc); - grouped_symbols[sym] = symbol; + grouped_symbols[key] = symbol; } } } diff --git a/src/message_handler.h b/src/message_handler.h index 628090fd0..e62604465 100644 --- a/src/message_handler.h +++ b/src/message_handler.h @@ -32,6 +32,7 @@ struct Out_CqueryPublishSemanticHighlighting lsSymbolKind parentKind; lsSymbolKind kind; StorageClass storage; + Role role; std::vector ranges; }; struct Params { @@ -46,6 +47,7 @@ MAKE_REFLECT_STRUCT(Out_CqueryPublishSemanticHighlighting::Symbol, parentKind, kind, storage, + role, ranges); MAKE_REFLECT_STRUCT(Out_CqueryPublishSemanticHighlighting::Params, uri,