Use the target name instead of hard-coding SparcV9.
authorMisha Brukman <brukman+llvm@gmail.com>
Tue, 10 Aug 2004 18:31:01 +0000 (18:31 +0000)
committerMisha Brukman <brukman+llvm@gmail.com>
Tue, 10 Aug 2004 18:31:01 +0000 (18:31 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15616 91177308-0d34-0410-b5e6-96231b3b80d8

utils/TableGen/CodeEmitterGen.cpp

index 2bdac25c49b3c5e613e8dd558b6e86a5b175e757..b2c5138140665615b3930c7d80828c4a1f60a906 100644 (file)
 using namespace llvm;
 
 void CodeEmitterGen::run(std::ostream &o) {
+  CodeGenTarget Target;
   std::vector<Record*> Insts = Records.getAllDerivedDefinitions("Instruction");
 
   EmitSourceFileHeader("Machine Code Emitter", o);
 
-  std::string Namespace = "V9::";
-  std::string ClassName = "SparcV9CodeEmitter::";
+  std::string Namespace = Insts[0]->getValueAsString("Namespace") + "::";
 
   //const std::string &Namespace = Inst->getValue("Namespace")->getName();
-  o << "unsigned " << ClassName
+  o << "unsigned " << Target.getName() << "CodeEmitter::"
     << "getBinaryCodeForInstr(MachineInstr &MI) {\n"
     << "  unsigned Value = 0;\n"
     << "  DEBUG(std::cerr << MI);\n"