aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-12-31 07:09:33 +0000
committerChris Lattner <sabre@nondot.org>2003-12-31 07:09:33 +0000
commit6d28a268c32860e76efc85cd2ab59176601b23c6 (patch)
tree5c06cbdb6b2e5d2e463b7e72bf2454cc5d18b6a8 /lib
parent69284b03d1dc7ebdc2ce22f65afe5ef04cc01cf4 (diff)
downloadexternal_llvm-6d28a268c32860e76efc85cd2ab59176601b23c6.zip
external_llvm-6d28a268c32860e76efc85cd2ab59176601b23c6.tar.gz
external_llvm-6d28a268c32860e76efc85cd2ab59176601b23c6.tar.bz2
* Make Module::getTypeName const
* Add new Module::getTypeByName method * Group methods in Module.cpp better git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10668 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/VMCore/Module.cpp39
1 files changed, 23 insertions, 16 deletions
diff --git a/lib/VMCore/Module.cpp b/lib/VMCore/Module.cpp
index b4b0925..83e0a6e 100644
--- a/lib/VMCore/Module.cpp
+++ b/lib/VMCore/Module.cpp
@@ -137,21 +137,6 @@ Function *Module::getFunction(const std::string &Name, const FunctionType *Ty) {
return cast_or_null<Function>(SymTab.lookup(PointerType::get(Ty), Name));
}
-// addTypeName - Insert an entry in the symbol table mapping Str to Type. If
-// there is already an entry for this name, true is returned and the symbol
-// table is not modified.
-//
-bool Module::addTypeName(const std::string &Name, const Type *Ty) {
- SymbolTable &ST = getSymbolTable();
-
- if (ST.lookup(Type::TypeTy, Name)) return true; // Already in symtab...
-
- // Not in symbol table? Set the name with the Symtab as an argument so the
- // type knows what to update...
- ((Value*)Ty)->setName(Name, &ST);
-
- return false;
-}
/// getMainFunction - This function looks up main efficiently. This is such a
/// common case, that it is a method in Module. If main cannot be found, a
@@ -217,11 +202,33 @@ Function *Module::getNamedFunction(const std::string &Name) {
}
+// addTypeName - Insert an entry in the symbol table mapping Str to Type. If
+// there is already an entry for this name, true is returned and the symbol
+// table is not modified.
+//
+bool Module::addTypeName(const std::string &Name, const Type *Ty) {
+ SymbolTable &ST = getSymbolTable();
+
+ if (ST.lookup(Type::TypeTy, Name)) return true; // Already in symtab...
+
+ // Not in symbol table? Set the name with the Symtab as an argument so the
+ // type knows what to update...
+ ((Value*)Ty)->setName(Name, &ST);
+
+ return false;
+}
+
+/// getTypeByName - Return the type with the specified name in this module, or
+/// null if there is none by that name.
+const Type *Module::getTypeByName(const std::string &Name) const {
+ const SymbolTable &ST = getSymbolTable();
+ return cast_or_null<Type>(ST.lookup(Type::TypeTy, Name));
+}
// 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) {
+std::string Module::getTypeName(const Type *Ty) const {
const SymbolTable &ST = getSymbolTable();
if (ST.find(Type::TypeTy) == ST.end())
return ""; // No names for types...