summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-08-12 00:57:17 +0000
committerJohn McCall <rjmccall@apple.com>2010-08-12 00:57:17 +0000
commit12d53da8cb4bbe43bb92c38a770f2cd5b3679cd0 (patch)
tree40da1cc5ba51813ad372362440a3111a12bb29d4 /clang
parent7d7b4d1b0f6675c50206ce1b046f9d1045042cc5 (diff)
downloadbcm5719-llvm-12d53da8cb4bbe43bb92c38a770f2cd5b3679cd0.tar.gz
bcm5719-llvm-12d53da8cb4bbe43bb92c38a770f2cd5b3679cd0.zip
Fix a crash on invalid when declaring an implicit member of a class with an
invalid destructor. llvm-svn: 110891
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaDecl.cpp8
-rw-r--r--clang/test/SemaCXX/destructor.cpp14
2 files changed, 21 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index de7ad3d791d..b27f727b3c5 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -3652,8 +3652,14 @@ void Sema::CheckFunctionDeclaration(Scope *S, FunctionDecl *NewFD,
bool &Redeclaration,
bool &OverloadableAttrRequired) {
// If NewFD is already known erroneous, don't do any of this checking.
- if (NewFD->isInvalidDecl())
+ if (NewFD->isInvalidDecl()) {
+ // If this is a class member, mark the class invalid immediately.
+ // This avoids some consistency errors later.
+ if (isa<CXXMethodDecl>(NewFD))
+ cast<CXXMethodDecl>(NewFD)->getParent()->setInvalidDecl();
+
return;
+ }
if (NewFD->getResultType()->isVariablyModifiedType()) {
// Functions returning a variably modified type violate C99 6.7.5.2p2
diff --git a/clang/test/SemaCXX/destructor.cpp b/clang/test/SemaCXX/destructor.cpp
index 1502f734712..cdcae2e4119 100644
--- a/clang/test/SemaCXX/destructor.cpp
+++ b/clang/test/SemaCXX/destructor.cpp
@@ -105,3 +105,17 @@ namespace test6 {
class B : A<int> { B(); };
B::B() {} // expected-note {{in instantiation of member function 'test6::A<int>::~A' requested here}}
}
+
+// Make sure classes are marked invalid when they have invalid
+// members. This avoids a crash-on-invalid.
+namespace test7 {
+ struct A {
+ ~A() const; // expected-error {{'const' qualifier is not allowed on a destructor}}
+ };
+ struct B : A {};
+
+ void test() {
+ B *b;
+ b->~B();
+ }
+}
OpenPOWER on IntegriCloud