diff options
author | Sean Silva <silvas@purdue.edu> | 2012-10-03 21:29:18 +0000 |
---|---|---|
committer | Sean Silva <silvas@purdue.edu> | 2012-10-03 21:29:18 +0000 |
commit | f42a6741de5eda904a7c7b02731f0b019bbe0c5c (patch) | |
tree | 802e9874f47a1c64769f490a68a7ffaacac47b07 | |
parent | ec7559db6d4d7e8f3cbeea8b7f2174318b3e8918 (diff) |
tblgen: Put new TableGenMain API in place.
In order to avoid rev-lock with Clang when moving to the new API, also
preserve the current API temporarily and insert a shim to implement the
new API in terms of the old.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@165165 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/TableGen/Main.h | 8 | ||||
-rw-r--r-- | lib/TableGen/Main.cpp | 19 |
2 files changed, 27 insertions, 0 deletions
diff --git a/include/llvm/TableGen/Main.h b/include/llvm/TableGen/Main.h index deaef4a990..663779f176 100644 --- a/include/llvm/TableGen/Main.h +++ b/include/llvm/TableGen/Main.h @@ -21,6 +21,14 @@ class TableGenAction; /// Run the table generator, performing the specified Action on parsed records. int TableGenMain(char *argv0, TableGenAction &Action); +class RecordKeeper; +class raw_ostream; +typedef bool TableGenMainFn(raw_ostream &OS, RecordKeeper &Records); + +/// Perform the action using Records, and write output to OS. +/// \returns true on error, false otherwise +int TableGenMain(char *argv0, TableGenMainFn *MainFn); + } #endif diff --git a/lib/TableGen/Main.cpp b/lib/TableGen/Main.cpp index 7aeef563b8..83bc66f460 100644 --- a/lib/TableGen/Main.cpp +++ b/lib/TableGen/Main.cpp @@ -22,6 +22,7 @@ #include "llvm/Support/ToolOutputFile.h" #include "llvm/Support/system_error.h" #include "llvm/TableGen/Error.h" +#include "llvm/TableGen/Main.h" #include "llvm/TableGen/Record.h" #include "llvm/TableGen/TableGenAction.h" #include <algorithm> @@ -47,8 +48,26 @@ namespace { cl::value_desc("directory"), cl::Prefix); } +namespace { +// XXX: this is a crutch for transitioning to the new TableGenMain API +// (with a TableGenMainFn* instead of a pointless class). +class StubTransitionalTableGenAction : public TableGenAction { + TableGenMainFn *MainFn; +public: + StubTransitionalTableGenAction(TableGenMainFn *M) : MainFn(M) {} + bool operator()(raw_ostream &OS, RecordKeeper &Records) { + return MainFn(OS, Records); + } +}; +} + namespace llvm { +int TableGenMain(char *argv0, TableGenMainFn *MainFn) { + StubTransitionalTableGenAction Action(MainFn); + return TableGenMain(argv0, Action); +} + int TableGenMain(char *argv0, TableGenAction &Action) { RecordKeeper Records; |