mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
LoadLibraryPermanently no longer throws an exception, so this code doesn't have
to catch it. Other minor cleanups. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29050 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cc2fa54dfa
commit
17aa9d3f53
@ -16,42 +16,28 @@
|
||||
#include "llvm/System/DynamicLibrary.h"
|
||||
#include <iostream>
|
||||
#include <vector>
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
static std::vector<std::string>* plugins;
|
||||
static std::vector<std::string> *Plugins;
|
||||
|
||||
void PluginLoader::operator=(const std::string &Filename) {
|
||||
std::string ErrorMessage;
|
||||
if (!Plugins)
|
||||
Plugins = new std::vector<std::string>();
|
||||
|
||||
if (!plugins)
|
||||
plugins = new std::vector<std::string>();
|
||||
|
||||
try {
|
||||
sys::DynamicLibrary::LoadLibraryPermanently(Filename.c_str());
|
||||
plugins->push_back(Filename);
|
||||
} catch (const std::string& errmsg) {
|
||||
if (errmsg.empty()) {
|
||||
ErrorMessage = "Unknown";
|
||||
} else {
|
||||
ErrorMessage = errmsg;
|
||||
}
|
||||
}
|
||||
if (!ErrorMessage.empty())
|
||||
std::cerr << "Error opening '" << Filename << "': " << ErrorMessage
|
||||
std::string Error;
|
||||
if (sys::DynamicLibrary::LoadLibraryPermanently(Filename.c_str(), &Error)) {
|
||||
std::cerr << "Error opening '" << Filename << "': " << Error
|
||||
<< "\n -load request ignored.\n";
|
||||
} else {
|
||||
Plugins->push_back(Filename);
|
||||
}
|
||||
}
|
||||
|
||||
unsigned PluginLoader::getNumPlugins()
|
||||
{
|
||||
if(plugins)
|
||||
return plugins->size();
|
||||
else
|
||||
return 0;
|
||||
unsigned PluginLoader::getNumPlugins() {
|
||||
return Plugins ? Plugins->size() : 0;
|
||||
}
|
||||
|
||||
std::string& PluginLoader::getPlugin(unsigned num)
|
||||
{
|
||||
assert(plugins && num < plugins->size() && "Asking for an out of bounds plugin");
|
||||
return (*plugins)[num];
|
||||
std::string &PluginLoader::getPlugin(unsigned num) {
|
||||
assert(Plugins && num < Plugins->size() && "Asking for an out of bounds plugin");
|
||||
return (*Plugins)[num];
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user