Initial checkin

llvm-svn: 3005
This commit is contained in:
Chris Lattner 2002-07-23 17:56:53 +00:00
parent 79e5e0009e
commit 2c54a0db79
3 changed files with 125 additions and 0 deletions

View File

@ -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

View File

@ -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"));

View File

@ -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"));