sammccall marked 3 inline comments as done.
sammccall added inline comments.


================
Comment at: clang-tools-extra/clangd/InlayHints.cpp:252
+// This is used to summarize e.g. the condition of a while loop.
+std::string summarizeExpr(const Expr *E) {
+  struct Namer : ConstStmtVisitor<Namer, std::string> {
----------------
hokein wrote:
> This looks like a complicated implementation to get an abbreviated-form of 
> cond expression for the inlay label text.
> 
> 
> A different idea would be if the user can just click the inlay label text, 
> then the editor jumps to the corresponding for statement (looks like it is 
> supported with the 
> [InlayHintLabelPart::Location](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#inlayHintLabelPart))
>  with that we probably don't need to emit an abbreviated-form text (`// for` 
> should be clear enough).
> A different idea would be if the user can just click the inlay label text, 
> then the editor jumps to the corresponding for statement (looks like it is 
> supported with the InlayHintLabelPart::Location) with that we probably don't 
> need to emit an abbreviated-form text (// for should be clear enough).

Agree we should have this too (also for other kinds of hints).

But I don't think it's a replacement:
 - BlockEnd is most useful to connect blockend + blockstart context when the 
block start is far away, and navigating to it destroys your blockend context. 
(Hover is better in this regard but still isn't available *in-line*).
 - inlayhintlabelpart isn't available in most editors that support inlayhint, 
and realistically may never be


================
Comment at: clang-tools-extra/clangd/InlayHints.cpp:578
+  //   } else if (cond2) {
+  //   } // mark as "cond1" or "cond2"?
+  // For now, the answer is neither, just mark as "if".
----------------
hokein wrote:
> my opinion for this case would be (the marking result is also consistent with 
> the brackets)
> 
> ```
> if (cond1) {
> } // mark as cond1
> else if (cond2) {
> } // mark as cond2.
> ```
If the first if is } is on a separate line we could do this.

The styles we work the most place `} else` on one line though, so this isn't an 
option.
In those styles we see if/elseif/else as a single construct (and format it as 
such) - and marking as cond2 seems strange to me...


================
Comment at: clang-tools-extra/clangd/InlayHints.cpp:599
+                    llvm::StringRef Name = "") {
+    if (const auto *CS = llvm::dyn_cast_or_null<CompoundStmt>(Body))
+      addBlockEndHint(CS->getSourceRange(), Label, Name, "");
----------------
hokein wrote:
> it looks like we will mark the block end for single-statement `CompoundStmt` 
> without `{}`, it doesn't seem to add much value to this case (the body is 
> short enough to spot the for statement).
> 
> ```
> for (int i = 0; i < 10; ++i)
>   foo();
> ```
As discussed offline, CompoundStmt exists exactly where braces exist.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D155421

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

Reply via email to