sammccall accepted this revision.
sammccall added a comment.
This revision is now accepted and ready to land.

(My first reaction was that this belongs in semanticHighlights() rather than 
toSemanticTokens, but I think you got it right - the single-line restriction is 
pretty unnatural from clang's point of view, and cuts across tokens generated 
in different places).



================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:948
+    } else {
+      // If a tokens length is past the end of the line, it should be treated 
as
+      // if the token ends at the end of the line and will not wrap onto the
----------------
This wording is hard for me to follow. I think it's saying:

"If the token spans a line break, truncate it to avoid this"


================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.cpp:948
+    } else {
+      // If a tokens length is past the end of the line, it should be treated 
as
+      // if the token ends at the end of the line and will not wrap onto the
----------------
sammccall wrote:
> This wording is hard for me to follow. I think it's saying:
> 
> "If the token spans a line break, truncate it to avoid this"
It seems it would be better to split into one token per line, rather than 
simply truncating.

Is truncation for simplicity or is there a reason to prefer it?

FWIW I think this wouldn't be too hard to implement if you reordered the 
tokenType/tokenModifiers above so this part is the last step, and just copied 
the whole SemanticToken object from the back of the Result. But on the other 
hand it's not terribly important, either.

At least I think we should have a comment for the truncate/split tradeoff.


================
Comment at: clang-tools-extra/clangd/SemanticHighlighting.h:90
   uint32_t Modifiers = 0;
   Range R;
 
----------------
I think this deserves a comment like:

```
// This is clang's token bounds, which may span multiple lines.
// This may be split/truncated to a single line when required by LSP.
```


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D127856

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

Reply via email to