diff options
author | Jakub Staszak <kubastaszak@gmail.com> | 2012-10-16 19:32:31 +0000 |
---|---|---|
committer | Jakub Staszak <kubastaszak@gmail.com> | 2012-10-16 19:32:31 +0000 |
commit | ba34fdb0e47c39b9bb770869d343f849ceb6fff3 (patch) | |
tree | 9c1d198c146acb22a0391855dcbde6c2564a5faf | |
parent | fef9e3199a6256c957e990f79051b8926f623538 (diff) | |
download | bcm5719-llvm-ba34fdb0e47c39b9bb770869d343f849ceb6fff3.tar.gz bcm5719-llvm-ba34fdb0e47c39b9bb770869d343f849ceb6fff3.zip |
Simplify potentially quadratic behavior while erasing elements from std::vector.
llvm-svn: 166045
-rw-r--r-- | llvm/lib/Transforms/Scalar/DCE.cpp | 8 |
1 files changed, 1 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/Scalar/DCE.cpp b/llvm/lib/Transforms/Scalar/DCE.cpp index 086f0a1a714..8d53443b389 100644 --- a/llvm/lib/Transforms/Scalar/DCE.cpp +++ b/llvm/lib/Transforms/Scalar/DCE.cpp @@ -118,13 +118,7 @@ bool DCE::runOnFunction(Function &F) { I->eraseFromParent(); // Remove the instruction from the worklist if it still exists in it. - for (std::vector<Instruction*>::iterator WI = WorkList.begin(); - WI != WorkList.end(); ) { - if (*WI == I) - WI = WorkList.erase(WI); - else - ++WI; - } + WorkList.erase(std::remove(WorkList.begin(), WorkList.end(), I), WorkList.end()); MadeChange = true; ++DCEEliminated; |