diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-03-27 04:38:56 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-03-27 04:38:56 +0000 |
commit | f4d17c4f22184e5ac5595e38f86eb86900535502 (patch) | |
tree | ba475eb2589fb488076b48bf96cb3bc9cf313972 /clang/lib/Sema/SemaDecl.cpp | |
parent | fdca4a7967e3dd575f725edb33a8078314df8093 (diff) | |
download | bcm5719-llvm-f4d17c4f22184e5ac5595e38f86eb86900535502.tar.gz bcm5719-llvm-f4d17c4f22184e5ac5595e38f86eb86900535502.zip |
Improve recovery when a constructor fails to type-check. Test case from Anders
llvm-svn: 67818
Diffstat (limited to 'clang/lib/Sema/SemaDecl.cpp')
-rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index e9f586583c9..fa386ef68d4 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -2294,7 +2294,7 @@ void Sema::AddInitializerToDecl(DeclTy *dcl, ExprArg init, bool DirectInit) { // A class is abstract if at least one function is pure virtual. cast<CXXRecordDecl>(CurContext)->setAbstract(true); - } else { + } else if (!Method->isInvalidDecl()) { Diag(Method->getLocation(), diag::err_non_virtual_pure) << Method->getDeclName() << Init->getSourceRange(); Method->setInvalidDecl(); |