]> granicus.if.org Git - clang/commitdiff
Modify begin()/end() for AsmStmt iterators to handle the case when Exprs.empty()
authorTed Kremenek <kremenek@apple.com>
Fri, 22 May 2009 22:03:22 +0000 (22:03 +0000)
committerTed Kremenek <kremenek@apple.com>
Fri, 22 May 2009 22:03:22 +0000 (22:03 +0000)
is true. Because of recent changes to llvm::SmallVector, using these iterators
when Exprs was empty would cause an assertion failure.

This fixes: PR 4245.

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

include/clang/AST/Stmt.h

index 57b420870fff52437025eafb62a64b92953a1eb0..ffd2a742df3ad922d0da44dc3e0e97e657a6a49e 100644 (file)
@@ -1161,30 +1161,39 @@ public:
   typedef ConstExprIterator const_inputs_iterator;
   
   inputs_iterator begin_inputs() {
-    return &Exprs[0] + NumOutputs;
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs;
   }
   
   inputs_iterator end_inputs() {
-    return  &Exprs[0] + NumOutputs + NumInputs;
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs + NumInputs;
   }
   
   const_inputs_iterator begin_inputs() const {
-    return &Exprs[0] + NumOutputs;
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs;
   }
   
   const_inputs_iterator end_inputs() const {
-    return  &Exprs[0] + NumOutputs + NumInputs;}
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs + NumInputs;
+  }
   
   // Output expr iterators.
   
   typedef ExprIterator outputs_iterator;
   typedef ConstExprIterator const_outputs_iterator;
   
-  outputs_iterator begin_outputs() { return &Exprs[0]; }
-  outputs_iterator end_outputs() { return &Exprs[0] + NumOutputs; }
+  outputs_iterator begin_outputs() {
+    return Exprs.empty() ? NULL : &Exprs[0];
+  }
+  outputs_iterator end_outputs() {
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs;
+  }
   
-  const_outputs_iterator begin_outputs() const { return &Exprs[0]; }
-  const_outputs_iterator end_outputs() const { return &Exprs[0] + NumOutputs; }
+  const_outputs_iterator begin_outputs() const {
+    return Exprs.empty() ? NULL : &Exprs[0];
+  }
+  const_outputs_iterator end_outputs() const {
+    return Exprs.empty() ? NULL : &Exprs[0] + NumOutputs;
+  }
   
   // Input name iterator.