diff --git a/support/tools/TableGen/CodeEmitterGen.cpp b/support/tools/TableGen/CodeEmitterGen.cpp index b3928b8c36e6..076945616f94 100644 --- a/support/tools/TableGen/CodeEmitterGen.cpp +++ b/support/tools/TableGen/CodeEmitterGen.cpp @@ -11,6 +11,8 @@ void CodeEmitterGen::run(std::ostream &o) { std::vector Insts = Records.getAllDerivedDefinitions("Instruction"); + EmitSourceFileHeader("Machine Code Emitter", o); + std::string Namespace = "V9::"; std::string ClassName = "SparcV9CodeEmitter::"; diff --git a/support/tools/TableGen/CodeEmitterGen.h b/support/tools/TableGen/CodeEmitterGen.h index 7ae3ef8d92c1..4b87da5067ee 100644 --- a/support/tools/TableGen/CodeEmitterGen.h +++ b/support/tools/TableGen/CodeEmitterGen.h @@ -7,11 +7,9 @@ #ifndef CODEMITTERGEN_H #define CODEMITTERGEN_H -#include -#include -class RecordKeeper; +#include "TableGenBackend.h" -class CodeEmitterGen { +class CodeEmitterGen : public TableGenBackend { RecordKeeper &Records; public: CodeEmitterGen(RecordKeeper &R) : Records(R) {} diff --git a/support/tools/TableGen/RegisterInfoEmitter.cpp b/support/tools/TableGen/RegisterInfoEmitter.cpp index 043fb3b5bebd..a4ad8d5a734a 100644 --- a/support/tools/TableGen/RegisterInfoEmitter.cpp +++ b/support/tools/TableGen/RegisterInfoEmitter.cpp @@ -11,13 +11,6 @@ #include "Support/StringExtras.h" #include -static void EmitSourceHeader(const std::string &Desc, std::ostream &o) { - o << "//===- TableGen'erated file -------------------------------------*-" - " C++ -*-===//\n//\n// " << Desc << "\n//\n// Automatically generate" - "d file, do not edit!\n//\n//===------------------------------------" - "----------------------------------===//\n\n"; -} - // runEnums - Print out enum values for all of the registers. void RegisterInfoEmitter::runEnums(std::ostream &OS) { std::vector Registers = Records.getAllDerivedDefinitions("Register"); @@ -27,7 +20,7 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) { std::string Namespace = Registers[0]->getValueAsString("Namespace"); - EmitSourceHeader("Target Register Enum Values", OS); + EmitSourceFileHeader("Target Register Enum Values", OS); if (!Namespace.empty()) OS << "namespace " << Namespace << " {\n"; @@ -41,22 +34,8 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) { OS << "}\n"; } -static Record *getTarget(RecordKeeper &RC) { - std::vector Targets = RC.getAllDerivedDefinitions("Target"); - - if (Targets.size() != 1) - throw std::string("ERROR: Multiple subclasses of Target defined!"); - return Targets[0]; -} - -static std::string getQualifiedName(Record *R) { - std::string Namespace = R->getValueAsString("Namespace"); - if (Namespace.empty()) return R->getName(); - return Namespace + "::" + R->getName(); -} - void RegisterInfoEmitter::runHeader(std::ostream &OS) { - EmitSourceHeader("Register Information Header Fragment", OS); + EmitSourceFileHeader("Register Information Header Fragment", OS); std::string ClassName = getTarget(Records)->getName() + "GenRegisterInfo"; @@ -72,7 +51,7 @@ void RegisterInfoEmitter::runHeader(std::ostream &OS) { // RegisterInfoEmitter::run - Main register file description emitter. // void RegisterInfoEmitter::run(std::ostream &OS) { - EmitSourceHeader("Register Information Source Fragment", OS); + EmitSourceFileHeader("Register Information Source Fragment", OS); // Start out by emitting each of the register classes... to do this, we build // a set of registers which belong to a register class, this is to ensure that diff --git a/support/tools/TableGen/RegisterInfoEmitter.h b/support/tools/TableGen/RegisterInfoEmitter.h index 79e9309a4278..65a03303cddd 100644 --- a/support/tools/TableGen/RegisterInfoEmitter.h +++ b/support/tools/TableGen/RegisterInfoEmitter.h @@ -9,10 +9,9 @@ #ifndef REGISTER_INFO_EMITTER_H #define REGISTER_INFO_EMITTER_H -#include -class RecordKeeper; +#include "TableGenBackend.h" -class RegisterInfoEmitter { +class RegisterInfoEmitter : public TableGenBackend { RecordKeeper &Records; public: RegisterInfoEmitter(RecordKeeper &R) : Records(R) {} diff --git a/utils/TableGen/CodeEmitterGen.cpp b/utils/TableGen/CodeEmitterGen.cpp index b3928b8c36e6..076945616f94 100644 --- a/utils/TableGen/CodeEmitterGen.cpp +++ b/utils/TableGen/CodeEmitterGen.cpp @@ -11,6 +11,8 @@ void CodeEmitterGen::run(std::ostream &o) { std::vector Insts = Records.getAllDerivedDefinitions("Instruction"); + EmitSourceFileHeader("Machine Code Emitter", o); + std::string Namespace = "V9::"; std::string ClassName = "SparcV9CodeEmitter::"; diff --git a/utils/TableGen/CodeEmitterGen.h b/utils/TableGen/CodeEmitterGen.h index 7ae3ef8d92c1..4b87da5067ee 100644 --- a/utils/TableGen/CodeEmitterGen.h +++ b/utils/TableGen/CodeEmitterGen.h @@ -7,11 +7,9 @@ #ifndef CODEMITTERGEN_H #define CODEMITTERGEN_H -#include -#include -class RecordKeeper; +#include "TableGenBackend.h" -class CodeEmitterGen { +class CodeEmitterGen : public TableGenBackend { RecordKeeper &Records; public: CodeEmitterGen(RecordKeeper &R) : Records(R) {} diff --git a/utils/TableGen/RegisterInfoEmitter.cpp b/utils/TableGen/RegisterInfoEmitter.cpp index 043fb3b5bebd..a4ad8d5a734a 100644 --- a/utils/TableGen/RegisterInfoEmitter.cpp +++ b/utils/TableGen/RegisterInfoEmitter.cpp @@ -11,13 +11,6 @@ #include "Support/StringExtras.h" #include -static void EmitSourceHeader(const std::string &Desc, std::ostream &o) { - o << "//===- TableGen'erated file -------------------------------------*-" - " C++ -*-===//\n//\n// " << Desc << "\n//\n// Automatically generate" - "d file, do not edit!\n//\n//===------------------------------------" - "----------------------------------===//\n\n"; -} - // runEnums - Print out enum values for all of the registers. void RegisterInfoEmitter::runEnums(std::ostream &OS) { std::vector Registers = Records.getAllDerivedDefinitions("Register"); @@ -27,7 +20,7 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) { std::string Namespace = Registers[0]->getValueAsString("Namespace"); - EmitSourceHeader("Target Register Enum Values", OS); + EmitSourceFileHeader("Target Register Enum Values", OS); if (!Namespace.empty()) OS << "namespace " << Namespace << " {\n"; @@ -41,22 +34,8 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) { OS << "}\n"; } -static Record *getTarget(RecordKeeper &RC) { - std::vector Targets = RC.getAllDerivedDefinitions("Target"); - - if (Targets.size() != 1) - throw std::string("ERROR: Multiple subclasses of Target defined!"); - return Targets[0]; -} - -static std::string getQualifiedName(Record *R) { - std::string Namespace = R->getValueAsString("Namespace"); - if (Namespace.empty()) return R->getName(); - return Namespace + "::" + R->getName(); -} - void RegisterInfoEmitter::runHeader(std::ostream &OS) { - EmitSourceHeader("Register Information Header Fragment", OS); + EmitSourceFileHeader("Register Information Header Fragment", OS); std::string ClassName = getTarget(Records)->getName() + "GenRegisterInfo"; @@ -72,7 +51,7 @@ void RegisterInfoEmitter::runHeader(std::ostream &OS) { // RegisterInfoEmitter::run - Main register file description emitter. // void RegisterInfoEmitter::run(std::ostream &OS) { - EmitSourceHeader("Register Information Source Fragment", OS); + EmitSourceFileHeader("Register Information Source Fragment", OS); // Start out by emitting each of the register classes... to do this, we build // a set of registers which belong to a register class, this is to ensure that diff --git a/utils/TableGen/RegisterInfoEmitter.h b/utils/TableGen/RegisterInfoEmitter.h index 79e9309a4278..65a03303cddd 100644 --- a/utils/TableGen/RegisterInfoEmitter.h +++ b/utils/TableGen/RegisterInfoEmitter.h @@ -9,10 +9,9 @@ #ifndef REGISTER_INFO_EMITTER_H #define REGISTER_INFO_EMITTER_H -#include -class RecordKeeper; +#include "TableGenBackend.h" -class RegisterInfoEmitter { +class RegisterInfoEmitter : public TableGenBackend { RecordKeeper &Records; public: RegisterInfoEmitter(RecordKeeper &R) : Records(R) {}