aaron.ballman added inline comments.

================
Comment at: 
clang-tools-extra/clang-tidy/readability/BracesAroundStatementsCheck.cpp:30
       Lexer::getRawToken(Beginning, Tok, SM, Context->getLangOpts());
-  assert(!Invalid && "Expected a valid token.");
+  if (!Invalid) {
+    Kind = Tok.getKind();
----------------
Elide the braces.


================
Comment at: 
clang-tools-extra/clang-tidy/readability/BracesAroundStatementsCheck.cpp:40
+  tok::TokenKind Kind;
+  if (tryGetTokenKind(Loc, SM, Context, Kind)) {
+    return Kind;
----------------
Elide braces


================
Comment at: 
clang-tools-extra/clang-tidy/readability/BracesAroundStatementsCheck.cpp:76-77
+
+  // We need to check that it is not 'InitListExpr' which ends with 
+  // the tokens '};' because it will break the following analysis
+  tok::TokenKind NextTokKind;
----------------
Is there evidence that this behavior is desired? I have a hunch that this is a 
bug in Clang -- not all `InitListExpr`s will terminate with a semicolon, such 
as ones that appear as function arguments, like `foo({1, 2, 3});`, so I'm 
surprised to see it included here.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D74214



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

Reply via email to