summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Support/PluginLoader.cpp
diff options
context:
space:
mode:
authorJulien Lerouge <jlerouge@apple.com>2008-10-22 16:30:41 +0000
committerJulien Lerouge <jlerouge@apple.com>2008-10-22 16:30:41 +0000
commite9de15b88a3d6e0e198a4aa74219c346055f26c4 (patch)
treebd0a491d4433e5761ebed1f79fe31aa76306299b /llvm/lib/Support/PluginLoader.cpp
parent7c3a36435576d461fd8a63d87e0a660bc26c53d2 (diff)
downloadbcm5719-llvm-e9de15b88a3d6e0e198a4aa74219c346055f26c4.tar.gz
bcm5719-llvm-e9de15b88a3d6e0e198a4aa74219c346055f26c4.zip
Fix for PR2881: fix a small leak exposed by valgrind, using a ManagedStatic.
llvm-svn: 57984
Diffstat (limited to 'llvm/lib/Support/PluginLoader.cpp')
-rw-r--r--llvm/lib/Support/PluginLoader.cpp11
1 files changed, 5 insertions, 6 deletions
diff --git a/llvm/lib/Support/PluginLoader.cpp b/llvm/lib/Support/PluginLoader.cpp
index 0635a9d52ca..5acf1d13ee9 100644
--- a/llvm/lib/Support/PluginLoader.cpp
+++ b/llvm/lib/Support/PluginLoader.cpp
@@ -12,6 +12,7 @@
//===----------------------------------------------------------------------===//
#define DONT_GET_PLUGIN_LOADER_OPTION
+#include "llvm/Support/ManagedStatic.h"
#include "llvm/Support/PluginLoader.h"
#include "llvm/Support/Streams.h"
#include "llvm/System/DynamicLibrary.h"
@@ -19,12 +20,9 @@
#include <vector>
using namespace llvm;
-static std::vector<std::string> *Plugins;
+static ManagedStatic<std::vector<std::string> > Plugins;
void PluginLoader::operator=(const std::string &Filename) {
- if (!Plugins)
- Plugins = new std::vector<std::string>();
-
std::string Error;
if (sys::DynamicLibrary::LoadLibraryPermanently(Filename.c_str(), &Error)) {
cerr << "Error opening '" << Filename << "': " << Error
@@ -35,10 +33,11 @@ void PluginLoader::operator=(const std::string &Filename) {
}
unsigned PluginLoader::getNumPlugins() {
- return Plugins ? Plugins->size() : 0;
+ return Plugins.isConstructed() ? Plugins->size() : 0;
}
std::string &PluginLoader::getPlugin(unsigned num) {
- assert(Plugins && num < Plugins->size() && "Asking for an out of bounds plugin");
+ assert(Plugins.isConstructed() && num < Plugins->size() &&
+ "Asking for an out of bounds plugin");
return (*Plugins)[num];
}
OpenPOWER on IntegriCloud