mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-02-04 00:06:50 +00:00
C++11 [class.ctor]p5 says that
A defaulted default constructor for a class X is defined as deleted if [...] - X is a union and all of its variant members are of const-qualified type. A pedantic reading therefore says that union X { }; has a deleted default constructor, which is both silly and almost certainly unintended. Pretend as if this this read - X is a union with one or more variant members, and all of its variant members are of const-qualified type. llvm-svn: 151394
This commit is contained in:
parent
2120e2bd73
commit
232ee49c7b
@ -4531,7 +4531,8 @@ bool SpecialMemberDeletionInfo::shouldDeleteForField(FieldDecl *FD) {
|
||||
}
|
||||
|
||||
// At least one member in each anonymous union must be non-const
|
||||
if (CSM == Sema::CXXDefaultConstructor && AllVariantFieldsAreConst)
|
||||
if (CSM == Sema::CXXDefaultConstructor && AllVariantFieldsAreConst &&
|
||||
FieldRecord->field_begin() != FieldRecord->field_end())
|
||||
return true;
|
||||
|
||||
// Don't try to initialize the anonymous union
|
||||
@ -4611,7 +4612,10 @@ bool SpecialMemberDeletionInfo::shouldDeleteForField(FieldDecl *FD) {
|
||||
/// A defaulted default constructor for a class X is defined as deleted if
|
||||
/// X is a union and all of its variant members are of const-qualified type.
|
||||
bool SpecialMemberDeletionInfo::shouldDeleteForAllConstMembers() {
|
||||
return CSM == Sema::CXXDefaultConstructor && inUnion() && AllFieldsAreConst;
|
||||
// This is a silly definition, because it gives an empty union a deleted
|
||||
// default constructor. Don't do that.
|
||||
return CSM == Sema::CXXDefaultConstructor && inUnion() && AllFieldsAreConst &&
|
||||
(MD->getParent()->field_begin() != MD->getParent()->field_end());
|
||||
}
|
||||
|
||||
/// Determine whether a defaulted special member function should be defined as
|
||||
|
@ -121,11 +121,11 @@ late_delete::late_delete() = default; // expected-error {{would delete it}}
|
||||
|
||||
// See also rdar://problem/8125400.
|
||||
namespace empty {
|
||||
static union {}; // expected-error {{implicitly-deleted default constructor}} expected-note {{here}}
|
||||
static union { union {}; }; // expected-error {{implicitly-deleted default constructor}} expected-note {{here}}
|
||||
static union {};
|
||||
static union { union {}; };
|
||||
static union { struct {}; };
|
||||
static union { union { union {}; }; }; // expected-error {{implicitly-deleted default constructor}} expected-note {{here}}
|
||||
static union { union { union {}; }; };
|
||||
static union { union { struct {}; }; };
|
||||
static union { struct { union {}; }; }; // expected-error {{implicitly-deleted default constructor}} expected-note {{here}}
|
||||
static union { struct { union {}; }; };
|
||||
static union { struct { struct {}; }; };
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user