From: Tobias Grosser Date: Thu, 8 May 2014 07:55:34 +0000 (+0000) Subject: Revert "SCEV: Use I = vector<>.erase(I) to iterate and delete at the same time" X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=f46646d87beafcddd3778338a913d6cd3ff19179;p=oota-llvm.git Revert "SCEV: Use I = vector<>.erase(I) to iterate and delete at the same time" as committed in r208282. The original commit was incorrect. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@208286 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/ScalarEvolution.cpp b/lib/Analysis/ScalarEvolution.cpp index 8f5a2a98cc1..148e58d548f 100644 --- a/lib/Analysis/ScalarEvolution.cpp +++ b/lib/Analysis/ScalarEvolution.cpp @@ -7223,9 +7223,12 @@ static void findArrayDimensionsRec(ScalarEvolution &SE, Terms[I] = Q; } - for (auto I = Terms.begin(), E = Terms.end(); I != E; I++) - if (isa(*I)) - I = Terms.erase(I); + // Remove all SCEVConstants. + for (unsigned I = 0; I < Terms.size();) + if (isa(Terms[I])) + Terms.erase(Terms.begin() + I); + else + ++I; if (Terms.size() > 0) findArrayDimensionsRec(SE, Terms, Sizes, Zero, One);