aaron.ballman added inline comments.

================
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;
----------------
ymandel wrote:
> ymandel wrote:
> > aaron.ballman wrote:
> > > 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.
> > On a related note, are you sure the cause of this issue is 
> > `makeFileCharRange`? AFAIK, that does not involve any examination of 
> > tokens. It purely (attempts) to map from potentially a mix of expanded 
> > locations and file locations to purely file locations (and in the same file 
> > for that matter).
> I believe the issue lies with `DeclStmt`, not `InitListExpr`. Specifically, 
> the source range provided by `DeclStmt`.  See https://godbolt.org/z/vVtQZ8. 
> The non-decl statements have an end location on the token before the semi, 
> whereas the decl statements given their end location as the semi.
Ah, yeah, that sounds plausible too (the end location should be before the semi 
in both places). Either way, I think we should be fixing this in the frontend 
rather than trying to hack around it in clang-tidy checks, if at all possible. 
This may require undoing hacks done elsewhere, though.


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