sammccall added a comment.

Libclang changes need tests I think.



================
Comment at: clang-tools-extra/clangd/Protocol.cpp:265
   case index::SymbolKind::Parameter:
+  case index::SymbolKind::TemplateParm:
     return SymbolKind::Variable;
----------------
this seems kind of dubious, maybe worth a comment?
(If we had the decl here we'd distinguish between type and non-type, right?)


================
Comment at: clang-tools-extra/clangd/unittests/HoverTests.cpp:586
+         HI.LocalScope = "foo::";
+       }},
+      {// TemplateTemplate Type Parameter
----------------
I do think we're going to want to have `HI.Type = "typename"` here, maybe with 
some special-case in the rendering.

(Especially with concepts where the TTP can be constrained as Integral or 
something)

Fine to leave for now but FIXME somewhere?


================
Comment at: clang/include/clang-c/Index.h:6257
+  CXIdxEntity_CXXInterface          = 26,
+  CXIdxEntity_CXXTemplateParm       = 27
 
----------------
As far as hover goes, calling this "template parameter" and making int/class 
the "type" is cute and fits well.

But I worry we're not exposing enough info here and at the libclang level (and 
I guess Index) we should be distinguishing the 3 cases. WDYT?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D73696



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

Reply via email to