summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-07-23 17:56:53 +0000
committerChris Lattner <sabre@nondot.org>2002-07-23 17:56:53 +0000
commit2c54a0db79bf5c8e90bbafd25ec6fa6bfc79bf89 (patch)
tree1ee02df748e64f7de88629ad381346e049bc57c7 /llvm
parent79e5e0009edb9fbe1f950f3cf6ba13d0c5b52b89 (diff)
downloadbcm5719-llvm-2c54a0db79bf5c8e90bbafd25ec6fa6bfc79bf89.tar.gz
bcm5719-llvm-2c54a0db79bf5c8e90bbafd25ec6fa6bfc79bf89.zip
Initial checkin
llvm-svn: 3005
Diffstat (limited to 'llvm')
-rw-r--r--llvm/include/Support/TypeInfo.h65
-rw-r--r--llvm/lib/Support/PluginLoader.cpp30
-rw-r--r--llvm/support/lib/Support/PluginLoader.cpp30
3 files changed, 125 insertions, 0 deletions
diff --git a/llvm/include/Support/TypeInfo.h b/llvm/include/Support/TypeInfo.h
new file mode 100644
index 00000000000..29f4e22a991
--- /dev/null
+++ b/llvm/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/llvm/lib/Support/PluginLoader.cpp b/llvm/lib/Support/PluginLoader.cpp
new file mode 100644
index 00000000000..c2e4e89813a
--- /dev/null
+++ b/llvm/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/llvm/support/lib/Support/PluginLoader.cpp b/llvm/support/lib/Support/PluginLoader.cpp
new file mode 100644
index 00000000000..c2e4e89813a
--- /dev/null
+++ b/llvm/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"));
OpenPOWER on IntegriCloud