forked from OSchip/llvm-project
parent
79e5e0009e
commit
2c54a0db79
|
@ -0,0 +1,65 @@
|
|||
//===- Support/TypeInfo.h - Support class for type_info objects --*- C++ -*--=//
|
||||
//
|
||||
// This class makes std::type_info objects behave like first class objects that
|
||||
// can be put in maps and hashtables. This code is based off of code in the
|
||||
// Loki C++ library from the Modern C++ Design book.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef LLVM_SUPPORT_TYPEINFO_H
|
||||
#define LLVM_SUPPORT_TYPEINFO_H
|
||||
|
||||
#include <typeinfo>
|
||||
|
||||
struct TypeInfo {
|
||||
TypeInfo() { // needed for containers
|
||||
struct Nil {}; // Anonymous class distinct from all others...
|
||||
Info = &typeid(Nil);
|
||||
}
|
||||
|
||||
TypeInfo(const std::type_info &ti) : Info(&ti) { // non-explicit
|
||||
}
|
||||
|
||||
// Access for the wrapped std::type_info
|
||||
const std::type_info &get() const {
|
||||
return *Info;
|
||||
}
|
||||
|
||||
// Compatibility functions
|
||||
bool before(const TypeInfo &rhs) const {
|
||||
return Info->before(*rhs.Info);
|
||||
}
|
||||
const char *getClassName() const {
|
||||
return Info->name();
|
||||
}
|
||||
|
||||
private:
|
||||
const std::type_info *Info;
|
||||
};
|
||||
|
||||
// Comparison operators
|
||||
inline bool operator==(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return lhs.get() == rhs.get();
|
||||
}
|
||||
|
||||
inline bool operator<(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return lhs.before(rhs);
|
||||
}
|
||||
|
||||
inline bool operator!=(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return !(lhs == rhs);
|
||||
}
|
||||
|
||||
inline bool operator>(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return rhs < lhs;
|
||||
}
|
||||
|
||||
inline bool operator<=(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return !(lhs > rhs);
|
||||
}
|
||||
|
||||
inline bool operator>=(const TypeInfo &lhs, const TypeInfo &rhs) {
|
||||
return !(lhs < rhs);
|
||||
}
|
||||
|
||||
#endif
|
|
@ -0,0 +1,30 @@
|
|||
//===-- PluginLoader.cpp - Implement -load command line option ------------===//
|
||||
//
|
||||
// This file implements the -load <plugin> command line option processor. When
|
||||
// linked into a program, this new command line option is available that allows
|
||||
// users to load shared objects into the running program.
|
||||
//
|
||||
// Note that there are no symbols exported by the .o file generated for this
|
||||
// .cpp file. Because of this, a program must link against support.o instead of
|
||||
// support.a: otherwise this translation unit will not be included.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "Support/CommandLine.h"
|
||||
#include <dlfcn.h>
|
||||
#include <link.h>
|
||||
|
||||
namespace {
|
||||
struct PluginLoader {
|
||||
void operator=(const std::string &Filename) {
|
||||
if (dlopen(Filename.c_str(), RTLD_NOW) == 0)
|
||||
std::cerr << "Error opening '" << Filename << "': " << dlerror()
|
||||
<< "\n -load request ignored.\n";
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
// This causes operator= above to be invoked for every -load option.
|
||||
static cl::opt<PluginLoader, false, cl::parser<string> >
|
||||
LoadOpt("load", cl::ZeroOrMore, cl::value_desc("plugin.so"),
|
||||
cl::desc("Load the specified plugin"));
|
|
@ -0,0 +1,30 @@
|
|||
//===-- PluginLoader.cpp - Implement -load command line option ------------===//
|
||||
//
|
||||
// This file implements the -load <plugin> command line option processor. When
|
||||
// linked into a program, this new command line option is available that allows
|
||||
// users to load shared objects into the running program.
|
||||
//
|
||||
// Note that there are no symbols exported by the .o file generated for this
|
||||
// .cpp file. Because of this, a program must link against support.o instead of
|
||||
// support.a: otherwise this translation unit will not be included.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "Support/CommandLine.h"
|
||||
#include <dlfcn.h>
|
||||
#include <link.h>
|
||||
|
||||
namespace {
|
||||
struct PluginLoader {
|
||||
void operator=(const std::string &Filename) {
|
||||
if (dlopen(Filename.c_str(), RTLD_NOW) == 0)
|
||||
std::cerr << "Error opening '" << Filename << "': " << dlerror()
|
||||
<< "\n -load request ignored.\n";
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
// This causes operator= above to be invoked for every -load option.
|
||||
static cl::opt<PluginLoader, false, cl::parser<string> >
|
||||
LoadOpt("load", cl::ZeroOrMore, cl::value_desc("plugin.so"),
|
||||
cl::desc("Load the specified plugin"));
|
Loading…
Reference in New Issue