summaryrefslogtreecommitdiff
path: root/utils/TableGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-08-06 04:31:26 +0000
committerChris Lattner <sabre@nondot.org>2003-08-06 04:31:26 +0000
commit18a6a94e1fc5cd10d50a91598b1465f31e307266 (patch)
tree87b9e18c1bddabbf26815827395722ec0a2339ba /utils/TableGen
parent2c0f2c74bea4f40acb03b0c7c85d9cfc35feff2d (diff)
downloadllvm-18a6a94e1fc5cd10d50a91598b1465f31e307266.tar.gz
llvm-18a6a94e1fc5cd10d50a91598b1465f31e307266.tar.bz2
llvm-18a6a94e1fc5cd10d50a91598b1465f31e307266.tar.xz
Add more helper methods
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7626 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen')
-rw-r--r--utils/TableGen/TableGenBackend.cpp21
-rw-r--r--utils/TableGen/TableGenBackend.h10
2 files changed, 30 insertions, 1 deletions
diff --git a/utils/TableGen/TableGenBackend.cpp b/utils/TableGen/TableGenBackend.cpp
index f00c6eedb7..c0a67e3392 100644
--- a/utils/TableGen/TableGenBackend.cpp
+++ b/utils/TableGen/TableGenBackend.cpp
@@ -5,13 +5,32 @@
//===----------------------------------------------------------------------===//
#include "TableGenBackend.h"
+#include "Record.h"
#include <iostream>
void TableGenBackend::EmitSourceFileHeader(const std::string &Desc,
- std::ostream &OS) {
+ std::ostream &OS) const {
OS << "//===- TableGen'erated file -------------------------------------*-"
" C++ -*-===//\n//\n// " << Desc << "\n//\n// Automatically generate"
"d file, do not edit!\n//\n//===------------------------------------"
"----------------------------------===//\n\n";
}
+/// getQualifiedName - Return the name of the specified record, with a
+/// namespace qualifier if the record contains one.
+///
+std::string TableGenBackend::getQualifiedName(Record *R) const {
+ std::string Namespace = R->getValueAsString("Namespace");
+ if (Namespace.empty()) return R->getName();
+ return Namespace + "::" + R->getName();
+}
+
+/// getTarget - Return the current instance of the Target class.
+///
+Record *TableGenBackend::getTarget(RecordKeeper &RC) const {
+ std::vector<Record*> Targets = RC.getAllDerivedDefinitions("Target");
+
+ if (Targets.size() != 1)
+ throw std::string("ERROR: Multiple subclasses of Target defined!");
+ return Targets[0];
+}
diff --git a/utils/TableGen/TableGenBackend.h b/utils/TableGen/TableGenBackend.h
index b9e8c49d4c..ae71d2c66b 100644
--- a/utils/TableGen/TableGenBackend.h
+++ b/utils/TableGen/TableGenBackend.h
@@ -10,6 +10,8 @@
#include <string>
#include <iosfwd>
+class Record;
+class RecordKeeper;
struct TableGenBackend {
@@ -19,8 +21,16 @@ struct TableGenBackend {
public: // Useful helper routines...
+ /// EmitSourceFileHeader - Output a LLVM style file header to the specified
+ /// ostream.
void EmitSourceFileHeader(const std::string &Desc, std::ostream &OS) const;
+ /// getQualifiedName - Return the name of the specified record, with a
+ /// namespace qualifier if the record contains one.
+ std::string getQualifiedName(Record *R) const;
+
+ /// getTarget - Return the current instance of the Target class.
+ Record *getTarget(RecordKeeper &RC) const;
};
#endif