Add new constructor to accept vector of exported names while creating
InternalizePass.
llvm-svn: 29222
diff --git a/llvm/lib/Transforms/IPO/Internalize.cpp b/llvm/lib/Transforms/IPO/Internalize.cpp
index 4bfc5a2..0874ce5 100644
--- a/llvm/lib/Transforms/IPO/Internalize.cpp
+++ b/llvm/lib/Transforms/IPO/Internalize.cpp
@@ -45,6 +45,7 @@
bool DontInternalize;
public:
InternalizePass(bool InternalizeEverything = true);
+ InternalizePass(const std::vector <const char *>& exportList);
void LoadFile(const char *Filename);
virtual bool runOnModule(Module &M);
};
@@ -62,6 +63,13 @@
DontInternalize = true;
}
+InternalizePass::InternalizePass(const std::vector<const char *>&exportList) {
+ for(std::vector<const char *>::const_iterator itr = exportList.begin();
+ itr != exportList.end(); itr++) {
+ ExternalNames.insert(*itr);
+ }
+}
+
void InternalizePass::LoadFile(const char *Filename) {
// Load the APIFile...
std::ifstream In(Filename);
@@ -151,3 +159,7 @@
ModulePass *llvm::createInternalizePass(bool InternalizeEverything) {
return new InternalizePass(InternalizeEverything);
}
+
+ModulePass *llvm::createInternalizePass(const std::vector <const char *> &exportList) {
+ return new InternalizePass(exportList);
+}