diff options
author | David Blaikie <dblaikie@gmail.com> | 2012-01-24 04:51:48 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2012-01-24 04:51:48 +0000 |
commit | 0f2ae789807d8a936723d4fb5f9234fbec240ada (patch) | |
tree | 782202cd7fc2537a3187831d9461c40184661944 /clang/lib/Analysis/CFG.cpp | |
parent | c46534a0cd68f6f2593bcdee9bcc952c7ff7f9bf (diff) | |
download | bcm5719-llvm-0f2ae789807d8a936723d4fb5f9234fbec240ada.tar.gz bcm5719-llvm-0f2ae789807d8a936723d4fb5f9234fbec240ada.zip |
Revert various template unreachability code I committed accidentally.
r148774, r148775, r148776, r148777
llvm-svn: 148780
Diffstat (limited to 'clang/lib/Analysis/CFG.cpp')
-rw-r--r-- | clang/lib/Analysis/CFG.cpp | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/clang/lib/Analysis/CFG.cpp b/clang/lib/Analysis/CFG.cpp index c7040fc6d45..7b84710b594 100644 --- a/clang/lib/Analysis/CFG.cpp +++ b/clang/lib/Analysis/CFG.cpp @@ -721,7 +721,7 @@ void CFGBuilder::addAutomaticObjDtors(LocalScope::const_iterator B, } const CXXDestructorDecl *Dtor = Ty->getAsCXXRecordDecl()->getDestructor(); - if (Dtor && cast<FunctionType>(Dtor->getType())->getNoReturnAttr()) + if (cast<FunctionType>(Dtor->getType())->getNoReturnAttr()) Block = createNoReturnBlock(); else autoCreateBlock(); @@ -750,12 +750,13 @@ void CFGBuilder::addImplicitDtorsForDestructor(const CXXDestructorDecl *DD) { // Before virtual bases destroy direct base objects. for (CXXRecordDecl::base_class_const_iterator BI = RD->bases_begin(), BE = RD->bases_end(); BI != BE; ++BI) { - if (!BI->isVirtual()) - if (const CXXRecordDecl *CD = BI->getType()->getAsCXXRecordDecl()) - if (!CD->hasTrivialDestructor()) { - autoCreateBlock(); - appendBaseDtor(Block, BI); - } + if (!BI->isVirtual()) { + const CXXRecordDecl *CD = BI->getType()->getAsCXXRecordDecl(); + if (!CD->hasTrivialDestructor()) { + autoCreateBlock(); + appendBaseDtor(Block, BI); + } + } } // First destroy member objects. @@ -864,7 +865,7 @@ LocalScope* CFGBuilder::addLocalScopeForVarDecl(VarDecl *VD, // Check if type is a C++ class with non-trivial destructor. if (const CXXRecordDecl *CD = QT->getAsCXXRecordDecl()) - if (CD->hasDefinition() && !CD->hasTrivialDestructor()) { + if (!CD->hasTrivialDestructor()) { // Add the variable to scope Scope = createOrReuseLocalScope(Scope); Scope->addVar(VD); |