forked from OSchip/llvm-project
Diagnose when a destructor uses a unrelated class type as its name.
llvm-svn: 76577
This commit is contained in:
parent
82fe3e3398
commit
b154ecafa6
|
@ -385,6 +385,8 @@ def err_destructor_with_params : Error<"destructor cannot have any parameters">;
|
|||
def err_destructor_variadic : Error<"destructor cannot be variadic">;
|
||||
def err_destructor_typedef_name : Error<
|
||||
"destructor cannot be declared using a typedef %0 of the class name">;
|
||||
def err_destructor_name : Error<
|
||||
"expected the class name after '~' to name the enclosing class">;
|
||||
|
||||
// C++ initialization
|
||||
def err_lvalue_to_rvalue_ref : Error<"rvalue reference cannot bind to lvalue">;
|
||||
|
|
|
@ -2456,6 +2456,16 @@ void Sema::CheckFunctionDeclaration(FunctionDecl *NewFD, NamedDecl *&PrevDecl,
|
|||
CheckConstructor(Constructor);
|
||||
} else if (isa<CXXDestructorDecl>(NewFD)) {
|
||||
CXXRecordDecl *Record = cast<CXXRecordDecl>(NewFD->getParent());
|
||||
QualType ClassType = Context.getTypeDeclType(Record);
|
||||
if (!ClassType->isDependentType()) {
|
||||
ClassType = Context.getCanonicalType(ClassType);
|
||||
DeclarationName Name
|
||||
= Context.DeclarationNames.getCXXDestructorName(ClassType);
|
||||
if (NewFD->getDeclName() != Name) {
|
||||
Diag(NewFD->getLocation(), diag::err_destructor_name);
|
||||
return NewFD->setInvalidDecl();
|
||||
}
|
||||
}
|
||||
Record->setUserDeclaredDestructor(true);
|
||||
// C++ [class]p4: A POD-struct is an aggregate class that has [...] no
|
||||
// user-defined destructor.
|
||||
|
|
|
@ -55,3 +55,9 @@ G::~G() { }
|
|||
struct H {
|
||||
~H(void) { }
|
||||
};
|
||||
|
||||
struct X {};
|
||||
|
||||
struct Y {
|
||||
~X(); // expected-error {{expected the class name after '~' to name the enclosing class}}
|
||||
};
|
||||
|
|
Loading…
Reference in New Issue