Add removeModuleProvider()
authorDevang Patel <dpatel@apple.com>
Mon, 15 Oct 2007 19:56:32 +0000 (19:56 +0000)
committerDevang Patel <dpatel@apple.com>
Mon, 15 Oct 2007 19:56:32 +0000 (19:56 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43002 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/ExecutionEngine/ExecutionEngine.h
lib/ExecutionEngine/ExecutionEngine.cpp

index 7100a5ff043d29cc0363f4c39275eafc6ba7a2d6..2a2fb7cb8c4bd92d4693205c9d4dfb0211e41f49 100644 (file)
@@ -97,7 +97,11 @@ public:
   void addModuleProvider(ModuleProvider *P) {
     Modules.push_back(P);
   }
-  
+
+  /// removeModuleProvider - Remove a ModuleProvider from the list of modules.
+  /// Release module from ModuleProvider.
+  Module* removeModuleProvider(ModuleProvider *P, std::string *ErrInfo = 0);
+
   /// FindFunctionNamed - Search all of the active modules to find the one that
   /// defines FnName.  This is very slow operation and shouldn't be used for
   /// general code.
index 96604f10bcccdefc675a39de000f4eff157f72e1..512c4520e07ee61108f65ec8d66853197363dfbf 100644 (file)
@@ -51,6 +51,21 @@ ExecutionEngine::~ExecutionEngine() {
     delete Modules[i];
 }
 
+/// removeModuleProvider - Remove a ModuleProvider from the list of modules.
+/// Release module from ModuleProvider.
+Module* ExecutionEngine::removeModuleProvider(ModuleProvider *P, 
+                                              std::string *ErrInfo) {
+  for(SmallVector<ModuleProvider *, 1>::iterator I = Modules.begin(), 
+        E = Modules.end(); I != E; ++I) {
+    ModuleProvider *MP = *I;
+    if (MP == P) {
+      Modules.erase(I);
+      return MP->releaseModule(ErrInfo);
+    }
+  }
+  return NULL;
+}
+
 /// FindFunctionNamed - Search all of the active modules to find the one that
 /// defines FnName.  This is very slow operation and shouldn't be used for
 /// general code.