Fix PR95. I'm checking this patch in for Reid Spencer, who figured it out

and wrote it up.  Thanks!!

llvm-svn: 9832
This commit is contained in:
Chris Lattner 2003-11-09 19:39:48 +00:00
parent da8571b464
commit a570f7b681
2 changed files with 7 additions and 4 deletions

View File

@ -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();

View File

@ -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;
}