[clang] [Sema] Instantiate destructors for initialized anonymous union fields (PR #128866)
Maurice Heumann via cfe-commits
cfe-commits at lists.llvm.org
Fri Feb 28 00:30:17 PST 2025
================
@@ -5451,10 +5451,23 @@ bool Sema::SetCtorInitializers(CXXConstructorDecl *Constructor, bool AnyErrors,
NumInitializers * sizeof(CXXCtorInitializer*));
Constructor->setCtorInitializers(baseOrMemberInitializers);
+ SourceLocation Location = Constructor->getLocation();
+
+ for (CXXCtorInitializer *Initializer : Info.AllToInit) {
+ FieldDecl *Field = Initializer->getAnyMember();
+ if (!Field)
+ continue;
+
+ RecordDecl *FieldRecordDecl = Field->getParent();
+ if (!FieldRecordDecl->isUnion() ||
----------------
momo5502 wrote:
One test failed, but it seems that it now behaves identical to gcc ( https://godbolt.org/z/fbxT8xnY9 ), so I fixed the test.
https://github.com/llvm/llvm-project/pull/128866
More information about the cfe-commits
mailing list