diff options
author | Julien Lerouge <jlerouge@apple.com> | 2008-10-22 16:30:41 +0000 |
---|---|---|
committer | Julien Lerouge <jlerouge@apple.com> | 2008-10-22 16:30:41 +0000 |
commit | d231d1803d2282c4518e7439fca3a0a841d8789b (patch) | |
tree | 3a1da97e84ceead2fe09898880cd627e1089a7d7 /lib/Support | |
parent | 9c73ace7acb2d76007b66efc41eae2ed98a8ef5d (diff) | |
download | external_llvm-d231d1803d2282c4518e7439fca3a0a841d8789b.zip external_llvm-d231d1803d2282c4518e7439fca3a0a841d8789b.tar.gz external_llvm-d231d1803d2282c4518e7439fca3a0a841d8789b.tar.bz2 |
Fix for PR2881: fix a small leak exposed by valgrind, using a ManagedStatic.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57984 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support')
-rw-r--r-- | lib/Support/PluginLoader.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/Support/PluginLoader.cpp b/lib/Support/PluginLoader.cpp index 0635a9d..5acf1d1 100644 --- a/lib/Support/PluginLoader.cpp +++ b/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]; } |