nridge added a comment.

Thanks a lot for working on this! I agree this is well aligned with the goals 
of D77702 <https://reviews.llvm.org/D77702> (and in fact goes even further and 
meets the goals of D66990 <https://reviews.llvm.org/D66990> via the 
`declaration` modifier). The other modifiers are neat as well; I like the 
expressiveness of the kind + modifier model in general.

> This addresses some of the goals of D77702 <https://reviews.llvm.org/D77702>, 
> but leaves some things undone.
> Mostly because I think these will want some discussion.
>
> - no split between dependent type/name. (We may want to model this as a 
> modifier, type+dependent vs ???+dependent)

+1

> - no split between primitive/typedef. (Is introducing a nonstandard kind is 
> worth this distinction?)

Here's my general take on this:

- There is too much variety between programming languages to expect that a 
standard list of highlighting kinds is going to satisfactorily cover all 
languages.
- If LSP aims to be the basis for tools that are competitive with purpose-built 
language-specific tools, it's reasonable to allow for clients willing to go the 
extra mile in terms of customization (e.g. use a language-specific theme which 
provides colors for language-specific token kinds).
- Therefore, I would say yes, we should take the liberty of adding nonstandard 
highlighting kinds and modifiers where it makes sense from a language POV.

That said... for typedef specifically, I wonder if it actually makes more sense 
as a modifier than a kind. That is, have the kind be the target type (falling 
back to Unknown/Dependent if we don't know), and have a modifier flag for "the 
type is referred to via an alias" (as opposed to "the type is referred to 
directly"). WDYT?

> - no nonstandard local attribute This probably makes sense, I'm wondering if 
> we want others and how they fit together.

Are you referring to local-scope variables (i.e. `FunctionScope` in D95701 
<https://reviews.llvm.org/D95701>)? If so, I think the approach in that patch 
is promising.



================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:132
+    return isConst(AT->getElementType());
+  return isConst(T->getPointeeType());
+}
----------------
It seems a bit unintuitive that the path which non-pointer types (e.g. 
unqualified class or builtin types) take is to return false in this recursive 
call because `getPointeeType()` returns null... but I guess that works.


================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:136
+// Whether D is const in a loose sense (should it be highlighted as such?)
+bool isConst(const Decl *D) {
+  if (llvm::isa<EnumConstantDecl>(D) || llvm::isa<NonTypeTemplateParmDecl>(D))
----------------
Do you think in the future it might make sense to have the `readonly` modifier 
reflect, at least for variables, whether //the particular reference// to the 
variable is a readonly reference (e.g. binding the variable to a `const X&` vs. 
an `X&`)?


================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:184
+  if (const auto *FD = llvm::dyn_cast<FieldDecl>(D))
+    return FD->isCXXClassMember() && !FD->isCXXInstanceMember();
+  if (const auto *OMD = llvm::dyn_cast<ObjCMethodDecl>(D))
----------------
Will anything take this path (rather than being covered by 
`VD->isStaticDataMember()` above)?


================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:476
+      if (!Kind || (Result && Kind != Result))
+        continue;
+      Result = Kind;
----------------
This is a change of behaviour from before, in the case where the `ReferenceLoc` 
has multiple targets.

Before, we would produce at most one highlighting token for the `ReferenceLoc`. 
In the case where different target decls had different highlighting kinds, we 
wouldn't produce any.

Now, it looks like we produce a separate token for every target whose kind 
matches the kind of the first target (and skip targets with a conflicting kind).

Is that the intention?

It seems a bit strange: if we allow multiple tokens, why couldn't they have 
different kinds?


================
Comment at: 
clang-tools-extra/clangd/refactor/tweaks/AnnotateHighlightings.cpp:11
 #include "llvm/ADT/StringRef.h"
+#include "llvm/Support/ScopedPrinter.h"
 
----------------
Maybe add `// for llvm::to_string` at it's not obvious


================
Comment at: clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp:264
+        $Class[[D]] $Field_decl[[E]];
+        static double $StaticField_decl_static[[S]];
+        static void $StaticMethod_decl_static[[bar]]() {}
----------------
Presumably, the highlighting kinds `StaticField` and `StaticMethod` are going 
to be collapsed into `Field` and `Method` in a future change (after the removal 
of TheiaSemanticHighlighting, I guess)?


================
Comment at: clang-tools-extra/clangd/unittests/SemanticHighlightingTests.cpp:718
+      };
+      )cpp",
+  };
----------------
Should we add a test case for `_deprecated` as well?


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D77811/new/

https://reviews.llvm.org/D77811

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to