aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-11-09 19:39:48 +0000
committerChris Lattner <sabre@nondot.org>2003-11-09 19:39:48 +0000
commitd5b1245e8c8a0482ffa91601575743c6ec61ca19 (patch)
treed3c7c4c1523464323e89fe87836bda16d86e255b
parent54baafd28649a93c7c16ada4529b9212dc03aa05 (diff)
Fix PR95. I'm checking this patch in for Reid Spencer, who figured it out
and wrote it up. Thanks!! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9832 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/SymbolTable.h6
-rw-r--r--lib/VMCore/SymbolTable.cpp5
2 files changed, 7 insertions, 4 deletions
diff --git a/include/llvm/SymbolTable.h b/include/llvm/SymbolTable.h
index f457255f3b..42f15aa626 100644
--- a/include/llvm/SymbolTable.h
+++ b/include/llvm/SymbolTable.h
@@ -36,7 +36,7 @@ public:
typedef VarMap::iterator type_iterator;
typedef VarMap::const_iterator type_const_iterator;
- inline SymbolTable() : InternallyInconsistent(false) {}
+ inline SymbolTable() : InternallyInconsistent(false), LastUnique(0) {}
~SymbolTable();
// lookup - Returns null on failure...
@@ -109,6 +109,10 @@ private:
//
bool InternallyInconsistent;
+ // LastUnique - This value is used to retain the last unique value used
+ // by getUniqueName to generate unique names.
+ unsigned long LastUnique;
+
inline super::value_type operator[](const Type *Ty) {
assert(0 && "Should not use this operator to access symbol table!");
return super::value_type();
diff --git a/lib/VMCore/SymbolTable.cpp b/lib/VMCore/SymbolTable.cpp
index a6b9a0007b..9452cdfec4 100644
--- a/lib/VMCore/SymbolTable.cpp
+++ b/lib/VMCore/SymbolTable.cpp
@@ -61,11 +61,10 @@ std::string SymbolTable::getUniqueName(const Type *Ty,
if (I == end()) return BaseName;
std::string TryName = BaseName;
- unsigned Counter = 0;
type_iterator End = I->second.end();
- while (I->second.find(TryName) != End) // Loop until we find unoccupied
- TryName = BaseName + utostr(++Counter); // Name in the symbol table
+ while (I->second.find(TryName) != End) // Loop until we find a free
+ TryName = BaseName + utostr(++LastUnique); // name in the symbol table
return TryName;
}