hokein added inline comments.

================
Comment at: clang-tools-extra/clangd/ClangdServer.cpp:671
+              // FIMXE: this is tricky
+              llvm::StringRef(LSPDiag.Message)
+                  .starts_with_insensitive(Diag.Message))
----------------
hokein wrote:
> kadircet wrote:
> > this is tricky indeed and conceptually really hard to achieve inside 
> > ClangdServer layer.
> > 
> > what about keeping the cache in ClangdLSPServer, but changing the format? 
> > Similar to `TweakRef`, we now have a `DiagRef`, which is 
> > ClangdServer-native. So we can keep a cache from `(FilePath, 
> > clangd::Diagnostic)` to `clangd::DiagRef`, and pass those `DiagRef`s to 
> > `ClangdServer` and make sure we're doing the search for sure on the right 
> > domain here?
> > 
> > this also gives us the flexibility to change the definition of a `DiagRef` 
> > in the future.
> I'm not a fan of keeping a cache in `ClangdLSPServer`, I'd like to remove it 
> entirely. 
> 
> What do you think about this alternative? 
> 
> - pull out and exposed the `mainMessage` API from the `toLSPDiags`
> - we add the `ClangdDiagnosticOptions` to the `CodeActionInputs`.
> - when searching a diagnostic in `ClangdServer.cpp`, we check the equality by 
> checking `mainMessage(ClangdServerDiagnostic.message, Inputs.DiagOpts) == 
> DiagRef.Message`
> 
> The downside here is that we have to pay `O(N * cost of mainMessage)` to find 
> a matched diagnostic.
>  
I updated the patch with the `mainMessage` approach, please take a look.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D155173

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

Reply via email to