]> granicus.if.org Git - clang/commitdiff
Modify WhileStmt::child_begin()/child_end() to include the initializer for the condit...
authorTed Kremenek <kremenek@apple.com>
Thu, 24 Dec 2009 00:54:19 +0000 (00:54 +0000)
committerTed Kremenek <kremenek@apple.com>
Thu, 24 Dec 2009 00:54:19 +0000 (00:54 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92104 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/AST/Stmt.h
lib/AST/Stmt.cpp

index 41b890c14f3ac597b347291eb25f9fef15d1a3fc..fae2e624e951420f6f7a8ab74125a262db9fea45 100644 (file)
@@ -813,6 +813,9 @@ public:
   // Iterators
   virtual child_iterator child_begin();
   virtual child_iterator child_end();
+  
+protected:
+  virtual void DoDestroy(ASTContext &Ctx);
 };
 
 /// DoStmt - This represents a 'do/while' stmt.
index bb5fba1ee0c33dfe9b902202843bf878a4be351c..dfdb2ce453d5707bade39597b91d7db1973ba6cd 100644 (file)
@@ -486,8 +486,22 @@ Stmt::child_iterator SwitchStmt::child_end() {
 }
 
 // WhileStmt
-Stmt::child_iterator WhileStmt::child_begin() { return &SubExprs[0]; }
-Stmt::child_iterator WhileStmt::child_end() { return &SubExprs[0]+END_EXPR; }
+Stmt::child_iterator WhileStmt::child_begin() {
+  return child_iterator(Var, &SubExprs[0]);
+}
+Stmt::child_iterator WhileStmt::child_end() {
+  return child_iterator(0, &SubExprs[0]+END_EXPR);
+}
+void WhileStmt::DoDestroy(ASTContext &C) {
+  // We do not use child_iterator here because that will include
+  // the expressions referenced by the condition variable.
+  for (Stmt **I = &SubExprs[0], **E = &SubExprs[END_EXPR]; I != E; ++I)
+    if (Stmt *Child = *I) Child->Destroy(C);
+  
+  this->~Stmt();
+  C.Deallocate((void *)this);
+}
+
 
 // DoStmt
 Stmt::child_iterator DoStmt::child_begin() { return &SubExprs[0]; }