erichkeane added inline comments.

================
Comment at: clang/lib/AST/ItaniumMangle.cpp:5561
+  // field represents an anonymous record type.
+  const CXXRecordDecl *RD = FD->getType()->getAsCXXRecordDecl();
+
----------------
rjmccall wrote:
> Alas, bit-fields are also allowed to be anonymous.
Ah, good point, i'll update the comment and add a test.


================
Comment at: clang/lib/AST/ItaniumMangle.cpp:5576
+      "program to refer to the anonymous union, and there is therefore no need 
"
+      "to mangle its name. '");
+}
----------------
rjmccall wrote:
> Unfortunately, I think class value mangling has a counter-example to this: 
> you can have an anonymous struct or union which doesn't declare any named 
> members but will of course nonetheless show up in the list of members in the 
> enclosing class.  Code can even give it a non-zero initializer using 
> list-initialization; that value can never be read, but it's there, and 
> presumably it's part of uniquely determining a different template argument 
> value and therefore needs to be mangled.
> 
> I don't know what we should do about this in the ABI, but we shouldn't crash 
> in the compiler.
I'm not really understanding what you mean?  Can you provide an example?  All 
of the cases I could come up with like this ended up getting caught by the 
'zero -init' case.

That said, I considered this 'unreachable' to be a distinct improvement over 
our current behavior which is to crash at effectively line 5558. 

Would you prefer some sort of 'fatal-error' emit here?  


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

https://reviews.llvm.org/D122820

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

Reply via email to