Fix reference to iterator invalidated by an erase operation. Uncovered

by _GLIBCXX_DEBUG.

llvm-svn: 37796
This commit is contained in:
David Greene 2007-06-29 02:53:16 +00:00
parent df6a87ea1c
commit c176772093

View File

@ -564,11 +564,12 @@ Loop *LoopSimplify::SeparateNestedLoop(Loop *L) {
// Scan all of the loop children of L, moving them to OuterLoop if they are // Scan all of the loop children of L, moving them to OuterLoop if they are
// not part of the inner loop. // not part of the inner loop.
for (Loop::iterator I = L->begin(); I != L->end(); ) const std::vector<Loop*> &SubLoops = L->getSubLoops();
if (BlocksInL.count((*I)->getHeader())) for (size_t I = 0; I != SubLoops.size(); )
if (BlocksInL.count(SubLoops[I]->getHeader()))
++I; // Loop remains in L ++I; // Loop remains in L
else else
NewOuter->addChildLoop(L->removeChildLoop(I)); NewOuter->addChildLoop(L->removeChildLoop(SubLoops.begin() + I));
// Now that we know which blocks are in L and which need to be moved to // Now that we know which blocks are in L and which need to be moved to
// OuterLoop, move any blocks that need it. // OuterLoop, move any blocks that need it.