From 892310eaff9eb8439029755ddf84c2f22f0b7dd7 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 24 Apr 2003 17:15:33 +0000 Subject: [PATCH] Make sure that the cloned module retains the type symbol table entries! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5894 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Utils/CloneModule.cpp | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/lib/Transforms/Utils/CloneModule.cpp b/lib/Transforms/Utils/CloneModule.cpp index 992431619c9..93bed758397 100644 --- a/lib/Transforms/Utils/CloneModule.cpp +++ b/lib/Transforms/Utils/CloneModule.cpp @@ -8,6 +8,7 @@ #include "llvm/Transforms/Utils/Cloning.h" #include "llvm/Module.h" #include "llvm/DerivedTypes.h" +#include "llvm/SymbolTable.h" #include "llvm/Constant.h" #include "ValueMapper.h" @@ -22,6 +23,14 @@ Module *CloneModule(const Module *M) { New->setEndianness(M->getEndianness()); New->setPointerSize(M->getPointerSize()); + // Copy all of the type symbol table entries over... + const SymbolTable &SymTab = M->getSymbolTable(); + SymbolTable::const_iterator TypeI = SymTab.find(Type::TypeTy); + if (TypeI != SymTab.end()) + for (SymbolTable::VarMap::const_iterator I = TypeI->second.begin(), + E = TypeI->second.end(); I != E; ++I) + New->addTypeName(I->first, cast(I->second)); + // Create the value map that maps things from the old module over to the new // module. std::map ValueMap; -- 2.34.1