Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
- Build Status
Buildable 32602 Build 32601: arc lint + arc unit
Event Timeline
I think it makes more sense to expose semantical information in HoverInfo(like Name, Scope, Definition, etc), rather than formatted strings, and let this be serialized by the users of ClangdServer (as in D61497). This is what I'll perform with that patch anyway, since it aims to provide consumers of ClangdServer with sementical information. So it is up to you whether to change the layering or keep it as it is in this patch.
clang-tools-extra/clangd/ClangdLSPServer.cpp | ||
---|---|---|
856 | Why not move R.contents.kind and R.range assignment out of the switch statement. and perform return after the switch. That way you can get rid of the llvm_unreachable(we would still get warnings for that switch-statement if someone adds a new MarkupKind but doesn't update that statement. And hopefully we should fallback to PlainText if editor doesn't support any markupkinds known to us. | |
clang-tools-extra/clangd/Protocol.cpp | ||
707 | Maybe also vlog/elog the unknown kind? So that we can easily catch new additions to spec. | |
clang-tools-extra/clangd/Protocol.h | ||
359 | This is mentioned as PlainText in the specs |
Having structured information instead of FormattedString looks good, this change mostly aims to add markdown support for resulting hover when the LSP clients have support for it.
I'm happy to restructure the HoverInfo to your liking if the current one seems problematic for any reason.
clang-tools-extra/clangd/ClangdLSPServer.cpp | ||
---|---|---|
856 | Done, we do want llvm_unreachable at the end, just in case a new MarkupKind gets added.
This is handled by the code parsing initialization options and it actually falls back to plaintext. |
- Move range and kind assignment out of the loop.
- Log error on failed deserialization of markup kind.
- s/Plaintext/PlainText
I'm happy to restructure the HoverInfo to your liking if the current one seems problematic for any reason.
It will just cause more code move on my side, no problems apart from that
clang-tools-extra/clangd/Protocol.cpp | ||
---|---|---|
707 | I was referring to the else case down below :D |
- Forgotten change
clang-tools-extra/clangd/Protocol.cpp | ||
---|---|---|
707 | Thanks for catching that! |
Planning to rebase this on top of D61497 and land afterwards in order to minimize merge conflicts.
LGTM, thanks!
clang-tools-extra/clangd/XRefs.cpp | ||
---|---|---|
1170 | Should this also be inlinecode, for consistency? I know it is not exactly code as the other two cases, but it might still be better to look similar in all cases |
clang-tools-extra/clangd/XRefs.cpp | ||
---|---|---|
1170 | Yeah, wasn't sure. Turned into inline code, could tweak later if needed. |
Why not move R.contents.kind and R.range assignment out of the switch statement. and perform return after the switch. That way you can get rid of the llvm_unreachable(we would still get warnings for that switch-statement if someone adds a new MarkupKind but doesn't update that statement.
And hopefully we should fallback to PlainText if editor doesn't support any markupkinds known to us.