diff options
author | Chris Lattner <sabre@nondot.org> | 2002-09-08 21:47:54 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-09-08 21:47:54 +0000 |
commit | 5fb724332aeb0f70fb6cd882718e09d1db0e12d5 (patch) | |
tree | 6d9418cefc918b960e198403d6ff81ed6739927b | |
parent | e30e1cf029000f167e1456fbe1ac780599cce703 (diff) |
Factor silly code duplication out
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3627 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/IPO/DeadTypeElimination.cpp | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/lib/Transforms/IPO/DeadTypeElimination.cpp b/lib/Transforms/IPO/DeadTypeElimination.cpp index 842bc58b29..58fe7f0a59 100644 --- a/lib/Transforms/IPO/DeadTypeElimination.cpp +++ b/lib/Transforms/IPO/DeadTypeElimination.cpp @@ -74,7 +74,11 @@ bool DTE::run(Module &M) { // Loop over all entries in the type plane... SymbolTable::VarMap &Plane = STI->second; for (SymbolTable::VarMap::iterator PI = Plane.begin(); PI != Plane.end();) - if (ShouldNukeSymtabEntry(*PI)) { // Should we remove this entry? + // If this entry should be unconditionally removed, or if we detect that + // the type is not used, remove it. + // + if (ShouldNukeSymtabEntry(*PI) || + !UsedTypes.count(cast<Type>(PI->second))) { #if MAP_IS_NOT_BRAINDEAD PI = Plane.erase(PI); // STD C++ Map should support this! #else @@ -83,15 +87,6 @@ bool DTE::run(Module &M) { #endif ++NumKilled; Changed = true; - } else if (!UsedTypes.count(cast<Type>(PI->second))) { -#if MAP_IS_NOT_BRAINDEAD - PI = Plane.erase(PI); // STD C++ Map should support this! -#else - Plane.erase(PI); // Alas, GCC 2.95.3 doesn't *SIGH* - PI = Plane.begin(); // N^2 algorithms are fun. :( -#endif - ++NumKilled; - Changed = true; } else { ++PI; } |