eliminate ValueSymbolTable::rename, it has no advantage over using remove+insert.

Make insert/remove assert if used incorrectly instead of returning a bool.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33988 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2007-02-07 06:13:49 +00:00
parent 1e348549d9
commit 56920a0ecc
3 changed files with 9 additions and 55 deletions

View File

@ -91,7 +91,7 @@ public:
/// @return 1 if the name is in the symbol table, 0 otherwise /// @return 1 if the name is in the symbol table, 0 otherwise
/// @brief Determine if a name is in the symbol table /// @brief Determine if a name is in the symbol table
ValueMap::size_type count(const std::string &name) const { bool count(const std::string &name) const {
return vmap.count(name); return vmap.count(name);
} }
@ -134,18 +134,10 @@ private:
/// This method removes a value from the symbol table. The name of the /// This method removes a value from the symbol table. The name of the
/// Value is extracted from \p Val and used to lookup the Value in the /// Value is extracted from \p Val and used to lookup the Value in the
/// symbol table. If the Value is not in the symbol table, this method /// symbol table. \p Val is not deleted, just removed from the symbol table.
/// returns false. \p Val is not deleted, just removed from the symbol table.
/// @returns true if \p Val was successfully removed, false otherwise
/// @brief Remove a value from the symbol table. /// @brief Remove a value from the symbol table.
bool remove(Value* Val); void remove(Value* Val);
/// Given a value with a non-empty name, remove its existing
/// entry from the symbol table and insert a new one for Name. This is
/// equivalent to doing "remove(V), V->Name = Name, insert(V)".
/// @brief Rename a value in the symbol table
bool rename(Value *V, const std::string &Name);
/// @} /// @}
/// @name Internal Data /// @name Internal Data
/// @{ /// @{
@ -154,7 +146,6 @@ private:
mutable uint32_t LastUnique; ///< Counter for tracking unique names mutable uint32_t LastUnique; ///< Counter for tracking unique names
/// @} /// @}
}; };
} // End llvm namespace } // End llvm namespace

View File

@ -120,7 +120,9 @@ void Value::setName(const std::string &name) {
Name = name; Name = name;
else if (hasName()) { else if (hasName()) {
if (!name.empty()) { // Replacing name. if (!name.empty()) { // Replacing name.
ST->rename(this, name); ST->remove(this);
Name = name;
ST->insert(this);
} else { // Transitioning from hasName -> noname. } else { // Transitioning from hasName -> noname.
ST->remove(this); ST->remove(this);
Name.clear(); Name.clear();

View File

@ -103,54 +103,15 @@ void ValueSymbolTable::insert(Value* V) {
} }
// Remove a value // Remove a value
bool ValueSymbolTable::remove(Value *V) { void ValueSymbolTable::remove(Value *V) {
assert(V->hasName() && "Value doesn't have name!"); assert(V->hasName() && "Value doesn't have name!");
iterator Entry = vmap.find(V->getName()); iterator Entry = vmap.find(V->getName());
if (Entry == vmap.end()) assert(Entry != vmap.end() && "Entry was not in the symtab!");
return false;
DEBUG(DOUT << " Removing Value: " << Entry->second->getName() << "\n"); DEBUG(DOUT << " Removing Value: " << Entry->second->getName() << "\n");
// Remove the value from the plane... // Remove the value from the plane...
vmap.erase(Entry); vmap.erase(Entry);
return true;
}
// rename - Given a value with a non-empty name, remove its existing entry
// from the symbol table and insert a new one for Name. This is equivalent to
// doing "remove(V), V->Name = Name, insert(V)",
//
bool ValueSymbolTable::rename(Value *V, const std::string &name) {
assert(V && "Can't rename a null Value");
assert(V->hasName() && "Can't rename a nameless Value");
assert(!V->getName().empty() && "Can't rename an Value with null name");
assert(V->getName() != name && "Can't rename a Value with same name");
assert(!name.empty() && "Can't rename a named Value with a null name");
// Find the name
iterator VI = vmap.find(V->getName());
// If we didn't find it, we're done
if (VI == vmap.end())
return false;
// Remove the old entry.
vmap.erase(VI);
// See if we can insert the new name.
VI = vmap.lower_bound(name);
// Is there a naming conflict?
if (VI != vmap.end() && VI->first == name) {
V->Name = getUniqueName( name);
vmap.insert(make_pair(V->Name, V));
} else {
V->Name = name;
vmap.insert(VI, make_pair(V->Name, V));
}
return true;
} }
// DumpVal - a std::for_each function for dumping a value // DumpVal - a std::for_each function for dumping a value