================ @@ -9543,6 +9543,48 @@ bool SpecialMemberDeletionInfo::shouldDeleteForSubobjectCall( if (DiagKind == -1) return false; + if (this->S.Context.getLangOpts().CPlusPlus26 && inUnion() && + CSM == CXXSpecialMemberKind::Destructor) { + // [class.dtor]/7 In C++26, a destructor for a union X is only deleted under + // the additional conditions that: + + // overload resolution to select a constructor to default-initialize an + // object of type X either fails or selects a constructor that is either + // deleted or not trivial, or + // or X has a variant member V of class type M (or possibly + // multi-dimensional array thereof) where V has a default member initializer + // and M has a destructor that is non-trivial, + + RecordDecl *Parent = Field->getParent(); + while (Parent && + (Parent->isAnonymousStructOrUnion() || + (Parent->isUnion() && Parent->getIdentifier() == nullptr))) { + if (auto RD = dyn_cast_or_null<RecordDecl>(Parent->getParent())) { + Parent = RD; + } else { + break; + } + } + + auto ParentDecl = dyn_cast<CXXRecordDecl>(Parent); + if (!ParentDecl->isBeingDefined()) { + Sema::SpecialMemberOverloadResult SMOR = S.LookupSpecialMember( + ParentDecl, CXXSpecialMemberKind::DefaultConstructor, false, false, + false, false, false); + if (SMOR.getKind() == Sema::SpecialMemberOverloadResult::Success) { + CXXConstructorDecl *Ctor = + dyn_cast<CXXConstructorDecl>(SMOR.getMethod()); + if (Ctor->isTrivial()) { ---------------- bcardosolopes wrote:
Same here https://github.com/llvm/llvm-project/pull/146815 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits