bruno added a comment.

> - Why are you adding ODR hash support for `RecordDecl` and not `TagDecl`? We 
> already have support for `EnumDecl`, so `TagDecl` seems like a good candidate 
> to cover both. Honestly, I don't know if it is possible or a good idea but it 
> looks plausible enough to consider.

The reason is that in C++ ODR diagnostics for TagDecl are handled as part of 
CXXRecordDecl, I didn't want add a path in TagDecl for C/ObjC only.

> - Are anonymous structs working? Worth adding test cases.

They are at the top level but not nested ones, I fixed that and should upload a 
new patch with that next.

> - Are unions working? Didn't notice any code specifically for them but 
> `RecordDecl` covers both structs and unions, so they should be working and we 
> need to test that.

Done in upcoming patch.

> - Few testing additions. These cases might be already covered or might be low 
> value, so take these suggestions with a grain of salt:
>   - test self-referential structs like `struct Node { struct Node *next; };`
>   - test comparing structs and forward declarations, e.g., `struct S;` and 
> `struct S { ... };`, and another couple `struct S { ... };` and `struct S; 
> struct S { ... };` The motivation is to make sure we aren't stumped when we 
> cannot find struct definition or when the definition is in unexpected place.

Ditto.

> Heads up in case it affects you refactoring work:
>  While looking through this code, I found a bug I previously made.  I fixed 
> it with a small change, but that lies in the middle of your refactoring 
> during FieldDecl handling.  The change is here:
> 
> https://reviews.llvm.org/rGa60e8927297005898b10a46300d929ba5cf7833c

Thanks for the heads up @rtrieu, I end up including that as part of 
rG90f58eaeff5f 
<https://reviews.llvm.org/rG90f58eaeff5f1d5017e7b689fac79180cdfa0160>


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D71734



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
  • [PATCH] D71734: [... Bruno Cardoso Lopes via Phabricator via cfe-commits

Reply via email to