summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorMikhail Glushenkov <foldr@codedgers.com>2010-08-13 06:02:45 +0000
committerMikhail Glushenkov <foldr@codedgers.com>2010-08-13 06:02:45 +0000
commitaa1a373a66fdc9602baa01b5405f6da69b3588f2 (patch)
tree5b865fb76c07dcd87433099ead210f52756b039a /utils
parent2e58b0055d8f8fc589d8a33293f84dbecad7151c (diff)
downloadllvm-aa1a373a66fdc9602baa01b5405f6da69b3588f2.tar.gz
llvm-aa1a373a66fdc9602baa01b5405f6da69b3588f2.tar.bz2
llvm-aa1a373a66fdc9602baa01b5405f6da69b3588f2.tar.xz
Add a workaround for building with Clang.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111007 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r--utils/TableGen/LLVMCConfigurationEmitter.cpp18
-rw-r--r--utils/TableGen/TableGen.cpp6
2 files changed, 19 insertions, 5 deletions
diff --git a/utils/TableGen/LLVMCConfigurationEmitter.cpp b/utils/TableGen/LLVMCConfigurationEmitter.cpp
index 7a68d696f9..97dca8c6aa 100644
--- a/utils/TableGen/LLVMCConfigurationEmitter.cpp
+++ b/utils/TableGen/LLVMCConfigurationEmitter.cpp
@@ -17,6 +17,8 @@
#include "llvm/ADT/IntrusiveRefCntPtr.h"
#include "llvm/ADT/StringMap.h"
#include "llvm/ADT/StringSet.h"
+#include "llvm/Support/CommandLine.h"
+#include "llvm/System/Path.h"
#include <algorithm>
#include <cassert>
@@ -27,6 +29,8 @@
using namespace llvm;
+extern cl::opt<std::string> InputFilename;
+
namespace {
//===----------------------------------------------------------------------===//
@@ -2974,9 +2978,18 @@ void EmitHookDeclarations(const ToolDescriptions& ToolDescs,
O << "}\n\n";
}
+std::string GetPluginName() {
+ if (!InputFilename.empty()) {
+ return sys::Path(InputFilename).getBasename();
+ }
+
+ return "";
+}
+
/// EmitRegisterPlugin - Emit code to register this plugin.
void EmitRegisterPlugin(int Priority, raw_ostream& O) {
- O << "struct Plugin : public llvmc::BasePlugin {\n\n";
+ O << "struct Plugin" << GetPluginName()
+ << " : public llvmc::BasePlugin {\n\n";
O.indent(Indent1) << "int Priority() const { return "
<< Priority << "; }\n\n";
O.indent(Indent1) << "int PreprocessOptions() const\n";
@@ -2987,7 +3000,8 @@ void EmitRegisterPlugin(int Priority, raw_ostream& O) {
<< "int PopulateCompilationGraph(CompilationGraph& graph) const\n";
O.indent(Indent1) << "{ return PopulateCompilationGraphLocal(graph); }\n"
<< "};\n\n"
- << "static llvmc::RegisterPlugin<Plugin> RP;\n\n";
+ << "static llvmc::RegisterPlugin<Plugin"
+ << GetPluginName()<< "> RP;\n\n";
}
/// EmitIncludes - Emit necessary #include directives and some
diff --git a/utils/TableGen/TableGen.cpp b/utils/TableGen/TableGen.cpp
index ebd163d265..cc784103e3 100644
--- a/utils/TableGen/TableGen.cpp
+++ b/utils/TableGen/TableGen.cpp
@@ -146,9 +146,6 @@ namespace {
OutputFilename("o", cl::desc("Output filename"), cl::value_desc("filename"),
cl::init("-"));
- cl::opt<std::string>
- InputFilename(cl::Positional, cl::desc("<input file>"), cl::init("-"));
-
cl::list<std::string>
IncludeDirs("I", cl::desc("Directory of include files"),
cl::value_desc("directory"), cl::Prefix);
@@ -161,6 +158,9 @@ namespace {
// FIXME: Eliminate globals from tblgen.
+cl::opt<std::string>
+InputFilename(cl::Positional, cl::desc("<input file>"), cl::init("-"));
+
RecordKeeper llvm::Records;
static SourceMgr SrcMgr;