Centralize the management of CXXRecordDecl::DefinitionData's
Polymorphic bit in CXXRecordDecl itself. Yes, this is also part of <rdar://problem/8459981>. llvm-svn: 114925
This commit is contained in:
parent
01daafc58a
commit
d22553cf21
|
@ -708,10 +708,6 @@ public:
|
|||
/// which means that the class contains or inherits a virtual function.
|
||||
bool isPolymorphic() const { return data().Polymorphic; }
|
||||
|
||||
/// setPolymorphic - Set whether this class is polymorphic (C++
|
||||
/// [class.virtual]).
|
||||
void setPolymorphic(bool Poly) { data().Polymorphic = Poly; }
|
||||
|
||||
/// isAbstract - Whether this class is abstract (C++ [class.abstract]),
|
||||
/// which means that the class contains or inherits a pure virtual function.
|
||||
bool isAbstract() const { return data().Abstract; }
|
||||
|
|
|
@ -110,6 +110,12 @@ CXXRecordDecl::setBases(CXXBaseSpecifier const * const *Bases,
|
|||
if (!BaseClassDecl->isEmpty())
|
||||
data().Empty = false;
|
||||
|
||||
// C++ [class.virtual]p1:
|
||||
// A class that declares or inherits a virtual function is called a
|
||||
// polymorphic class.
|
||||
if (BaseClassDecl->isPolymorphic())
|
||||
data().Polymorphic = true;
|
||||
|
||||
// Now go through all virtual bases of this base and add them.
|
||||
for (CXXRecordDecl::base_class_iterator VBase =
|
||||
BaseClassDecl->vbases_begin(),
|
||||
|
@ -298,6 +304,11 @@ CXXRecordDecl::addedMember(Decl *D) {
|
|||
// Virtual functions make the class non-empty.
|
||||
// FIXME: Standard ref?
|
||||
data().Empty = false;
|
||||
|
||||
// C++ [class.virtual]p1:
|
||||
// A class that declares or inherits a virtual function is called a
|
||||
// polymorphic class.
|
||||
data().Polymorphic = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -640,7 +651,6 @@ void CXXRecordDecl::removeConversion(const NamedDecl *ConvDecl) {
|
|||
|
||||
void CXXRecordDecl::setMethodAsVirtual(FunctionDecl *Method) {
|
||||
Method->setVirtualAsWritten(true);
|
||||
setPolymorphic(true);
|
||||
setHasTrivialConstructor(false);
|
||||
setHasTrivialCopyConstructor(false);
|
||||
setHasTrivialCopyAssignment(false);
|
||||
|
|
|
@ -516,12 +516,6 @@ Sema::CheckBaseSpecifier(CXXRecordDecl *Class,
|
|||
void Sema::SetClassDeclAttributesFromBase(CXXRecordDecl *Class,
|
||||
const CXXRecordDecl *BaseClass,
|
||||
bool BaseIsVirtual) {
|
||||
// C++ [class.virtual]p1:
|
||||
// A class that [...] inherits a virtual function is called a polymorphic
|
||||
// class.
|
||||
if (BaseClass->isPolymorphic())
|
||||
Class->setPolymorphic(true);
|
||||
|
||||
if (BaseIsVirtual) {
|
||||
// C++ [class.ctor]p5:
|
||||
// A constructor is trivial if its class has no virtual base classes.
|
||||
|
|
Loading…
Reference in New Issue