aboutsummaryrefslogtreecommitdiffstats
path: root/utils/TableGen/InstrEnumEmitter.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-01-06 00:49:05 +0000
committerChris Lattner <sabre@nondot.org>2008-01-06 00:49:05 +0000
commit030e6e51e61eeb8a8cb490900e28fc77403d6f6c (patch)
tree8423c799084b7d3928ee2b9ed43036133efb490f /utils/TableGen/InstrEnumEmitter.h
parent76c57f61f72a30a652eed2cbe2c50d071afdad02 (diff)
downloadexternal_llvm-030e6e51e61eeb8a8cb490900e28fc77403d6f6c.zip
external_llvm-030e6e51e61eeb8a8cb490900e28fc77403d6f6c.tar.gz
external_llvm-030e6e51e61eeb8a8cb490900e28fc77403d6f6c.tar.bz2
split enum emission out from InstrInfoEmitter into it's own tblgen backend.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45640 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/InstrEnumEmitter.h')
-rw-r--r--utils/TableGen/InstrEnumEmitter.h33
1 files changed, 33 insertions, 0 deletions
diff --git a/utils/TableGen/InstrEnumEmitter.h b/utils/TableGen/InstrEnumEmitter.h
new file mode 100644
index 0000000..b39fef2
--- /dev/null
+++ b/utils/TableGen/InstrEnumEmitter.h
@@ -0,0 +1,33 @@
+//===- InstrEnumEmitter.h - Generate Instruction Set Enums ------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This tablegen backend is responsible for emitting enums for each machine
+// instruction.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef INSTRENUM_EMITTER_H
+#define INSTRENUM_EMITTER_H
+
+#include "TableGenBackend.h"
+
+namespace llvm {
+
+class InstrEnumEmitter : public TableGenBackend {
+ RecordKeeper &Records;
+public:
+ InstrEnumEmitter(RecordKeeper &R) : Records(R) {}
+
+ // run - Output the instruction set description, returning true on failure.
+ void run(std::ostream &OS);
+};
+
+} // End llvm namespace
+
+#endif