]> granicus.if.org Git - clang/commitdiff
Fixed deadcode bug where check for NULL decl occured within a block
authorTed Kremenek <kremenek@apple.com>
Mon, 29 Oct 2007 21:23:58 +0000 (21:23 +0000)
committerTed Kremenek <kremenek@apple.com>
Mon, 29 Oct 2007 21:23:58 +0000 (21:23 +0000)
where the decl would always be non-NULL.  Moved the check to after the
block to properly tidy up the iterator's state.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43473 91177308-0d34-0410-b5e6-96231b3b80d8

AST/StmtIterator.cpp

index 9db5f6134f80e27a9dac9f4b891f38823d1f30c3..89d17bd340bb6fe9057488b2667bedeef9c8ca6c 100644 (file)
@@ -31,6 +31,7 @@ static inline VariableArrayType* FindVA(Type* t) {
 
 void StmtIteratorBase::NextVA() {
   assert (getVAPtr());
+  assert (decl);
 
   VariableArrayType* p = getVAPtr();
   p = FindVA(p->getElementType().getTypePtr());
@@ -59,11 +60,6 @@ void StmtIteratorBase::NextDecl(bool ImmediateAdvance) {
   }    
   
   for ( ; decl ; decl = decl->getNextDeclarator()) {
-    if (!decl) {
-      RawVAPtr = 0;
-      return;
-    }
-
     if (VarDecl* VD = dyn_cast<VarDecl>(decl)) {        
       if (VariableArrayType* VAPtr = FindVA(VD->getType().getTypePtr())) {
         setVAPtr(VAPtr);
@@ -77,6 +73,11 @@ void StmtIteratorBase::NextDecl(bool ImmediateAdvance) {
       if (ECD->getInitExpr())
         return;  
   }
+  
+  if (!decl) {
+    RawVAPtr = 0;
+    return;
+  }
 }
 
 StmtIteratorBase::StmtIteratorBase(ScopedDecl* d)