Skip to content

Conversation

@jlahoda
Copy link
Contributor

@jlahoda jlahoda commented Dec 25, 2020

This is a crude attempt to include semantic highlights introduced in LSP spec 3.16.0:
https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_semanticTokens

It is mostly copied src/message_handler.cc#emitSemanticHighlight, with some tweaks. Feedback is welcome!

@MaskRay
Copy link
Owner

MaskRay commented Dec 26, 2020

Thanks! I guess the specification is probably a bit unfortunate, since the payload may be much larger than the ccls extension...

@FelipeLema
Copy link

I've been using this branch today and it looks like it works all right (at least, for starters… I didn't see any obvious errors or problems)

@MaskRay is there any documentation of how to handle the missing TODOs? (I didn't seem to run to any of these errors, btw)

Copy link
Owner

@MaskRay MaskRay left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you know which client can be used for testing? It seems that semantic tokens do not support rainbow semantic highlighting?

namespace ccls {
using namespace llvm;

std::vector<const char *> SEMANTIC_TOKENS = {
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

const char *SEMANTIC_TOKENS[] =

@@ -0,0 +1,257 @@
// Copyright 2017-2020 ccls Authors
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Omit year number // Copyright ccls Authors


}

void MessageHandler::textDocument_semanticTokensFull(
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This replicates too many lines in message_handler.cc. You can make the message_handler.cc implementation public and call that function.

@MaskRay MaskRay force-pushed the master branch 3 times, most recently from db890d4 to cc13ced Compare November 6, 2024 05:57
@MaskRay MaskRay force-pushed the master branch 3 times, most recently from e403622 to cfc7c02 Compare August 15, 2025 06:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants