From aa1a373a66fdc9602baa01b5405f6da69b3588f2 Mon Sep 17 00:00:00 2001 From: Mikhail Glushenkov Date: Fri, 13 Aug 2010 06:02:45 +0000 Subject: [PATCH] Add a workaround for building with Clang. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111007 91177308-0d34-0410-b5e6-96231b3b80d8 --- utils/TableGen/LLVMCConfigurationEmitter.cpp | 18 ++++++++++++++++-- utils/TableGen/TableGen.cpp | 6 +++--- 2 files changed, 19 insertions(+), 5 deletions(-) diff --git a/utils/TableGen/LLVMCConfigurationEmitter.cpp b/utils/TableGen/LLVMCConfigurationEmitter.cpp index 7a68d696f92..97dca8c6aa3 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 #include @@ -27,6 +29,8 @@ using namespace llvm; +extern cl::opt 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 RP;\n\n"; + << "static llvmc::RegisterPlugin RP;\n\n"; } /// EmitIncludes - Emit necessary #include directives and some diff --git a/utils/TableGen/TableGen.cpp b/utils/TableGen/TableGen.cpp index ebd163d265c..cc784103e36 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 - InputFilename(cl::Positional, cl::desc(""), cl::init("-")); - cl::list 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 +InputFilename(cl::Positional, cl::desc(""), cl::init("-")); + RecordKeeper llvm::Records; static SourceMgr SrcMgr;