diff options
author | Chris Lattner <sabre@nondot.org> | 2002-07-23 17:56:53 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-07-23 17:56:53 +0000 |
commit | c1b5d092a0f89db5356ae79d8cc4213118f230dd (patch) | |
tree | 4b0c9531f31baf1a2c974fa95a94d504d093cc2e | |
parent | 6dc0193e68dfd35588c5f3c7a941c1ca505d5629 (diff) | |
download | external_llvm-c1b5d092a0f89db5356ae79d8cc4213118f230dd.zip external_llvm-c1b5d092a0f89db5356ae79d8cc4213118f230dd.tar.gz external_llvm-c1b5d092a0f89db5356ae79d8cc4213118f230dd.tar.bz2 |
Initial checkin
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3005 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/Support/TypeInfo.h | 65 | ||||
-rw-r--r-- | include/llvm/Support/TypeInfo.h | 65 | ||||
-rw-r--r-- | lib/Support/PluginLoader.cpp | 30 | ||||
-rw-r--r-- | support/lib/Support/PluginLoader.cpp | 30 |
4 files changed, 190 insertions, 0 deletions
diff --git a/include/Support/TypeInfo.h b/include/Support/TypeInfo.h new file mode 100644 index 0000000..29f4e22 --- /dev/null +++ b/include/Support/TypeInfo.h @@ -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 diff --git a/include/llvm/Support/TypeInfo.h b/include/llvm/Support/TypeInfo.h new file mode 100644 index 0000000..29f4e22 --- /dev/null +++ b/include/llvm/Support/TypeInfo.h @@ -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 diff --git a/lib/Support/PluginLoader.cpp b/lib/Support/PluginLoader.cpp new file mode 100644 index 0000000..c2e4e89 --- /dev/null +++ b/lib/Support/PluginLoader.cpp @@ -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")); diff --git a/support/lib/Support/PluginLoader.cpp b/support/lib/Support/PluginLoader.cpp new file mode 100644 index 0000000..c2e4e89 --- /dev/null +++ b/support/lib/Support/PluginLoader.cpp @@ -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")); |