summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2013-02-01 04:49:10 +0000
committerDouglas Gregor <dgregor@apple.com>2013-02-01 04:49:10 +0000
commitbc0e5c0114d68be7d86ca76ae466af56ac96ee4d (patch)
treefd2dbbbbac37755b2b33de1fb8c12eb243887fff /clang
parent59e7bd5b5e862dc15f3e09cf52eab8c286fccb22 (diff)
downloadbcm5719-llvm-bc0e5c0114d68be7d86ca76ae466af56ac96ee4d.tar.gz
bcm5719-llvm-bc0e5c0114d68be7d86ca76ae466af56ac96ee4d.zip
Don't do delayed exception-specification checking on an invalid
class. Fixes <rdar://problem/13017229>. llvm-svn: 174145
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp8
-rw-r--r--clang/test/CXX/except/except.spec/p14.cpp11
2 files changed, 19 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index 9ef91467dac..ead7b6548b9 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -7871,6 +7871,14 @@ void Sema::DefineImplicitDestructor(SourceLocation CurrentLocation,
/// \brief Perform any semantic analysis which needs to be delayed until all
/// pending class member declarations have been parsed.
void Sema::ActOnFinishCXXMemberDecls() {
+ // If the context is an invalid C++ class, just suppress these checks.
+ if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(CurContext)) {
+ if (Record->isInvalidDecl()) {
+ DelayedDestructorExceptionSpecChecks.clear();
+ return;
+ }
+ }
+
// Perform any deferred checking of exception specifications for virtual
// destructors.
for (unsigned i = 0, e = DelayedDestructorExceptionSpecChecks.size();
diff --git a/clang/test/CXX/except/except.spec/p14.cpp b/clang/test/CXX/except/except.spec/p14.cpp
index ff21ab8e56b..99ed2fdee19 100644
--- a/clang/test/CXX/except/except.spec/p14.cpp
+++ b/clang/test/CXX/except/except.spec/p14.cpp
@@ -101,3 +101,14 @@ namespace PR14141 {
~Derived3() noexcept(true) = default; // expected-error {{does not match the calculated}}
};
}
+
+namespace rdar13017229 {
+ struct Base {
+ virtual ~Base() {}
+ };
+
+ struct Derived : Base {
+ virtual ~Derived();
+ Typo foo(); // expected-error{{unknown type name 'Typo'}}
+ };
+}
OpenPOWER on IntegriCloud