aboutsummaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-08-01 04:46:24 +0000
committerChris Lattner <sabre@nondot.org>2003-08-01 04:46:24 +0000
commit6f334ad8f5c9319b334e2ba68b89d0dd46156788 (patch)
tree45f1dc9731297510db825f999a327b83a4e21a39 /utils
parent1d1adea4937aa5c7b4bd0aa0463fe38fcdd22c7e (diff)
downloadexternal_llvm-6f334ad8f5c9319b334e2ba68b89d0dd46156788.zip
external_llvm-6f334ad8f5c9319b334e2ba68b89d0dd46156788.tar.gz
external_llvm-6f334ad8f5c9319b334e2ba68b89d0dd46156788.tar.bz2
Add new getValueAsBitsInit 'high-level' method
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7467 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r--utils/TableGen/CodeEmitterGen.cpp11
-rw-r--r--utils/TableGen/Record.cpp17
-rw-r--r--utils/TableGen/Record.h6
3 files changed, 25 insertions, 9 deletions
diff --git a/utils/TableGen/CodeEmitterGen.cpp b/utils/TableGen/CodeEmitterGen.cpp
index 0619967..dc61f8f 100644
--- a/utils/TableGen/CodeEmitterGen.cpp
+++ b/utils/TableGen/CodeEmitterGen.cpp
@@ -26,14 +26,7 @@ void CodeEmitterGen::run(std::ostream &o) {
o << " case " << Namespace << R->getName() << ": {\n"
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
- const RecordVal *InstVal = R->getValue("Inst");
- if (!InstVal)
- throw std::string("No 'Inst' record found in target description file!");
-
- Init *InitVal = InstVal->getValue();
- assert(dynamic_cast<BitsInit*>(InitVal) &&
- "Can only handle undefined bits<> types!");
- BitsInit *BI = (BitsInit*)InitVal;
+ BitsInit *BI = R->getValueAsBitsInit("Inst");
unsigned Value = 0;
const std::vector<RecordVal> &Vals = R->getValues();
@@ -50,7 +43,7 @@ void CodeEmitterGen::run(std::ostream &o) {
}
DEBUG(o << "\n");
- DEBUG(o << " // " << *InstVal << "\n");
+ DEBUG(o << " // " << *R->getValue("Inst") << "\n");
o << " Value = " << Value << "U;\n\n";
// Loop over all of the fields in the instruction adding in any
diff --git a/utils/TableGen/Record.cpp b/utils/TableGen/Record.cpp
index f282e4b..acb61ec 100644
--- a/utils/TableGen/Record.cpp
+++ b/utils/TableGen/Record.cpp
@@ -468,6 +468,23 @@ std::string Record::getValueAsString(const std::string &FieldName) const {
"' does not have a string initializer!";
}
+/// getValueAsBitsInit - This method looks up the specified field and returns
+/// its value as a BitsInit, throwing an exception if the field does not exist
+/// or if the value is not the right type.
+///
+BitsInit *Record::getValueAsBitsInit(const std::string &FieldName) const {
+ const RecordVal *R = getValue(FieldName);
+ if (R == 0 || R->getValue() == 0)
+ throw "Record '" + R->getName() + "' does not have a field named '" +
+ FieldName + "!\n";
+
+ if (BitsInit *BI = dynamic_cast<BitsInit*>(R->getValue()))
+ return BI;
+ throw "Record '" + R->getName() + "', field '" + FieldName +
+ "' does not have a BitsInit initializer!";
+}
+
+
void RecordKeeper::dump() const { std::cerr << *this; }
diff --git a/utils/TableGen/Record.h b/utils/TableGen/Record.h
index 467f12a..130bf5a 100644
--- a/utils/TableGen/Record.h
+++ b/utils/TableGen/Record.h
@@ -605,6 +605,12 @@ public:
///
std::string getValueAsString(const std::string &FieldName) const;
+ /// getValueAsBitsInit - This method looks up the specified field and returns
+ /// its value as a BitsInit, throwing an exception if the field does not exist
+ /// or if the value is not the right type.
+ ///
+ BitsInit *getValueAsBitsInit(const std::string &FieldName) const;
+
};
std::ostream &operator<<(std::ostream &OS, const Record &R);