mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 07:34:06 +00:00
Switch ValueSymbolTable to StringRef based API.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76894 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e6c42dd6d3
commit
bc8d813f71
@ -24,6 +24,7 @@ namespace llvm {
|
||||
class BasicBlock;
|
||||
class Function;
|
||||
class Module;
|
||||
class StringRef;
|
||||
|
||||
/// This class provides a symbol table of name/value pairs. It is essentially
|
||||
/// a std::map<std::string,Value*> but has a controlled interface provided by
|
||||
@ -62,12 +63,11 @@ public:
|
||||
/// @{
|
||||
public:
|
||||
|
||||
/// This method finds the value with the given \p name in the
|
||||
/// This method finds the value with the given \p Name in the
|
||||
/// the symbol table.
|
||||
/// @returns the value associated with the \p name
|
||||
/// @returns the value associated with the \p Name
|
||||
/// @brief Lookup a named Value.
|
||||
Value *lookup(const std::string &name) const;
|
||||
Value *lookup(const char *NameBegin, const char *NameEnd) const;
|
||||
Value *lookup(const StringRef &Name) const { return vmap.lookup(Name); }
|
||||
|
||||
/// @returns true iff the symbol table is empty
|
||||
/// @brief Determine if the symbol table is empty
|
||||
@ -110,7 +110,7 @@ private:
|
||||
/// createValueName - This method attempts to create a value name and insert
|
||||
/// it into the symbol table with the specified name. If it conflicts, it
|
||||
/// auto-renames the name and returns that instead.
|
||||
ValueName *createValueName(const char *NameStart, unsigned NameLen, Value *V);
|
||||
ValueName *createValueName(const StringRef &Name, Value *V);
|
||||
|
||||
/// This method removes a value from the symbol table. It leaves the
|
||||
/// ValueName attached to the value, but it is no longer inserted in the
|
||||
|
@ -548,8 +548,7 @@ static bool LinkGlobals(Module *Dest, const Module *Src,
|
||||
// Check to see if may have to link the global with the global, alias or
|
||||
// function.
|
||||
if (SGV->hasName() && !SGV->hasLocalLinkage())
|
||||
DGV = cast_or_null<GlobalValue>(DestSymTab.lookup(SGV->getNameStart(),
|
||||
SGV->getNameEnd()));
|
||||
DGV = cast_or_null<GlobalValue>(DestSymTab.lookup(SGV->getNameRef()));
|
||||
|
||||
// If we found a global with the same name in the dest module, but it has
|
||||
// internal linkage, we are really not doing any linkage here.
|
||||
@ -942,8 +941,7 @@ static bool LinkFunctionProtos(Module *Dest, const Module *Src,
|
||||
// Check to see if may have to link the function with the global, alias or
|
||||
// function.
|
||||
if (SF->hasName() && !SF->hasLocalLinkage())
|
||||
DGV = cast_or_null<GlobalValue>(DestSymTab.lookup(SF->getNameStart(),
|
||||
SF->getNameEnd()));
|
||||
DGV = cast_or_null<GlobalValue>(DestSymTab.lookup(SF->getNameRef()));
|
||||
|
||||
// If we found a global with the same name in the dest module, but it has
|
||||
// internal linkage, we are really not doing any linkage here.
|
||||
|
@ -118,7 +118,7 @@ GlobalValue *Module::getNamedValue(const std::string &Name) const {
|
||||
}
|
||||
|
||||
GlobalValue *Module::getNamedValue(const char *Name) const {
|
||||
llvm::Value *V = getValueSymbolTable().lookup(Name, Name+strlen(Name));
|
||||
llvm::Value *V = getValueSymbolTable().lookup(Name);
|
||||
return cast_or_null<GlobalValue>(V);
|
||||
}
|
||||
|
||||
|
@ -30,24 +30,6 @@ ValueSymbolTable::~ValueSymbolTable() {
|
||||
#endif
|
||||
}
|
||||
|
||||
// lookup a value - Returns null on failure...
|
||||
//
|
||||
Value *ValueSymbolTable::lookup(const std::string &Name) const {
|
||||
const_iterator VI = vmap.find(Name);
|
||||
if (VI != vmap.end()) // We found the symbol
|
||||
return VI->getValue();
|
||||
return 0;
|
||||
}
|
||||
|
||||
Value *ValueSymbolTable::lookup(const char *NameBegin,
|
||||
const char *NameEnd) const {
|
||||
// FIXME: ValueSymbolTable should move to a StringRef based API.
|
||||
const_iterator VI = vmap.find(StringRef(NameBegin, NameEnd - NameBegin));
|
||||
if (VI != vmap.end()) // We found the symbol
|
||||
return VI->getValue();
|
||||
return 0;
|
||||
}
|
||||
|
||||
// Insert a value into the symbol table with the specified name...
|
||||
//
|
||||
void ValueSymbolTable::reinsertValue(Value* V) {
|
||||
@ -93,10 +75,9 @@ void ValueSymbolTable::removeValueName(ValueName *V) {
|
||||
/// createValueName - This method attempts to create a value name and insert
|
||||
/// it into the symbol table with the specified name. If it conflicts, it
|
||||
/// auto-renames the name and returns that instead.
|
||||
ValueName *ValueSymbolTable::createValueName(const char *NameStart,
|
||||
unsigned NameLen, Value *V) {
|
||||
ValueName *ValueSymbolTable::createValueName(const StringRef &Name, Value *V) {
|
||||
// In the common case, the name is not already in the symbol table.
|
||||
ValueName &Entry = vmap.GetOrCreateValue(StringRef(NameStart, NameLen));
|
||||
ValueName &Entry = vmap.GetOrCreateValue(Name);
|
||||
if (Entry.getValue() == 0) {
|
||||
Entry.setValue(V);
|
||||
//DEBUG(DOUT << " Inserted value: " << Entry.getKeyData() << ": "
|
||||
@ -105,11 +86,11 @@ ValueName *ValueSymbolTable::createValueName(const char *NameStart,
|
||||
}
|
||||
|
||||
// Otherwise, there is a naming conflict. Rename this value.
|
||||
SmallString<128> UniqueName(NameStart, NameStart+NameLen);
|
||||
SmallString<128> UniqueName(Name.begin(), Name.end());
|
||||
|
||||
while (1) {
|
||||
// Trim any suffix off.
|
||||
UniqueName.resize(NameLen);
|
||||
UniqueName.resize(Name.size());
|
||||
UniqueName.append_uint_32(++LastUnique);
|
||||
|
||||
// Try insert the vmap entry with this suffix.
|
||||
|
Loading…
x
Reference in New Issue
Block a user