mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-03 02:31:26 +00:00
Add Module::getTypeName
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2237 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3e5fe173bb
commit
f33fa6fb57
@ -69,6 +69,11 @@ public:
|
||||
//
|
||||
bool addTypeName(const std::string &Name, const Type *Ty);
|
||||
|
||||
// getTypeName - If there is at least one entry in the symbol table for the
|
||||
// specified type, return it.
|
||||
//
|
||||
std::string getTypeName(const Type *Ty);
|
||||
|
||||
// Get the underlying elements of the Module...
|
||||
inline const GlobalListType &getGlobalList() const { return GlobalList; }
|
||||
inline GlobalListType &getGlobalList() { return GlobalList; }
|
||||
|
@ -86,6 +86,26 @@ bool Module::addTypeName(const std::string &Name, const Type *Ty) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// getTypeName - If there is at least one entry in the symbol table for the
|
||||
// specified type, return it.
|
||||
//
|
||||
std::string Module::getTypeName(const Type *Ty) {
|
||||
const SymbolTable *ST = getSymbolTable();
|
||||
if (ST == 0) return ""; // No symbol table, must not have an entry...
|
||||
if (ST->find(Type::TypeTy) == ST->end())
|
||||
return ""; // No names for types...
|
||||
|
||||
SymbolTable::type_const_iterator TI = ST->type_begin(Type::TypeTy);
|
||||
SymbolTable::type_const_iterator TE = ST->type_end(Type::TypeTy);
|
||||
|
||||
while (TI != TE && TI->second != (const Value*)Ty)
|
||||
++TI;
|
||||
|
||||
if (TI != TE) // Must have found an entry!
|
||||
return TI->first;
|
||||
return ""; // Must not have found anything...
|
||||
}
|
||||
|
||||
|
||||
// dropAllReferences() - This function causes all the subinstructions to "let
|
||||
// go" of all references that they are maintaining. This allows one to
|
||||
|
Loading…
x
Reference in New Issue
Block a user