diff options
author | Douglas Gregor <dgregor@apple.com> | 2013-02-01 04:49:10 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2013-02-01 04:49:10 +0000 |
commit | bc0e5c0114d68be7d86ca76ae466af56ac96ee4d (patch) | |
tree | fd2dbbbbac37755b2b33de1fb8c12eb243887fff /clang | |
parent | 59e7bd5b5e862dc15f3e09cf52eab8c286fccb22 (diff) | |
download | bcm5719-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.cpp | 8 | ||||
-rw-r--r-- | clang/test/CXX/except/except.spec/p14.cpp | 11 |
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'}} + }; +} |