[cfe-dev] Poor DeclStmt source range with leading [[attributes]]?
Stephan Bergmann via cfe-dev
cfe-dev at lists.llvm.org
Mon Oct 7 08:23:28 PDT 2019
On 30/09/2019 16:01, Stephan Bergmann wrote:
> Seen with various versions of Clang, 8.0.0 and recent trunk,
>
>> $ cat test.cc
>> void f() {
>> [[maybe_unused]] int i;
>> }
>
>> clang++ -c -Xclang -ast-dump test.cc
> [...]
>> `-FunctionDecl 0x8ab1148 <test.cc:1:1, line:3:1> line:1:6 f 'void ()'
>> `-CompoundStmt 0x8ab1320 <col:10, line:3:1>
>> `-DeclStmt 0x8ab1308 <line:2:19, col:24>
>> `-VarDecl 0x8ab1248 <col:19, col:23> col:23 i 'int'
>> `-UnusedAttr 0x8ab12b0 <col:4> maybe_unused
>
> Note how the DeclStmt (and the enclosed VarDecl) only start with the
> "int" at column 19, not with the "[[" at column 1. (And that matches
> what you programmatically obtain from that DeclStmt via
> getSourceRange/getBeginLoc.)
>
> Is there some good reason for that, or is it a bug that should get fixed?
Assuming it's a bug, I started <https://reviews.llvm.org/D68581>
"Include leading attributes in DeclStmt's SourceRange" now.
More information about the cfe-dev
mailing list