[cfe-commits] r41620 - /cfe/trunk/AST/CFG.cpp

Ted Kremenek kremenek at apple.com
Thu Aug 30 11:39:41 PDT 2007


Author: kremenek
Date: Thu Aug 30 13:39:40 2007
New Revision: 41620

URL: http://llvm.org/viewvc/llvm-project?rev=41620&view=rev
Log:
Fixed bug in CFG construction where we failed to handle loop bodies with
no statements (or just full of ';' statements).

Modified:
    cfe/trunk/AST/CFG.cpp

Modified: cfe/trunk/AST/CFG.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/AST/CFG.cpp?rev=41620&r1=41619&r2=41620&view=diff

==============================================================================
--- cfe/trunk/AST/CFG.cpp (original)
+++ cfe/trunk/AST/CFG.cpp Thu Aug 30 13:39:40 2007
@@ -213,7 +213,7 @@
 ///  of the created blocks, or the original value of "Block" when this method
 ///  was called if no additional blocks are created.
 CFGBlock* CFGBuilder::addStmt(Stmt* S) {
-  assert (Block);
+  if (!Block) Block = createBlock();
   return WalkAST(S,true);
 }
 
@@ -555,8 +555,8 @@
     // All breaks should go to the code following the loop.
     BreakTargetBlock = LoopSuccessor;
     
-    // Create a new block to contain the (bottom) of the loop body.      
-    Block = createBlock();
+    // Create a new block to contain the (bottom) of the loop body.
+    Block = NULL;
     
     // If we have increment code, insert it at the end of the body block.
     if (Stmt* I = F->getInc()) Block = addStmt(I);
@@ -564,8 +564,11 @@
     // Now populate the body block, and in the process create new blocks
     // as we walk the body of the loop.
     CFGBlock* BodyBlock = Visit(F->getBody());      
-    assert (BodyBlock);      
-    if (Block) FinishBlock(BodyBlock);
+
+    if (!BodyBlock)
+      BodyBlock = ExitConditionBlock; // can happen for "for (...;...; ) ;"
+    else if (Block)
+      FinishBlock(BodyBlock);
     
     // This new body block is a successor to our "exit" condition block.
     ExitConditionBlock->addSuccessor(BodyBlock);
@@ -644,8 +647,11 @@
     
     // Create the body.  The returned block is the entry to the loop body.
     CFGBlock* BodyBlock = Visit(W->getBody());
-    assert (BodyBlock);
-    if (Block) FinishBlock(BodyBlock);
+    
+    if (!BodyBlock)
+      BodyBlock = ExitConditionBlock; // can happen for "while(...) ;"
+    else if (Block)
+      FinishBlock(BodyBlock);
     
     // Add the loop body entry as a successor to the condition.
     ExitConditionBlock->addSuccessor(BodyBlock);
@@ -719,9 +725,12 @@
     
     // Create the body.  The returned block is the entry to the loop body.
     BodyBlock = Visit(D->getBody());
-    assert (BodyBlock);
-    if (Block) FinishBlock(BodyBlock);
     
+    if (!BodyBlock)
+      BodyBlock = ExitConditionBlock; // can happen for "do ; while(...)"
+    else if (Block)
+      FinishBlock(BodyBlock);
+        
     // Add the loop body entry as a successor to the condition.
     ExitConditionBlock->addSuccessor(BodyBlock);
   }





More information about the cfe-commits mailing list