From 32809aad3494446725f44ff6de5ea3b9706e1c1d Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 7 Aug 2003 06:00:43 +0000 Subject: [PATCH] Add new method getVAlueAsDag llvm-svn: 7669 --- llvm/support/tools/TableGen/Record.cpp | 22 +++++++++++++++++++--- llvm/support/tools/TableGen/Record.h | 6 ++++++ 2 files changed, 25 insertions(+), 3 deletions(-) diff --git a/llvm/support/tools/TableGen/Record.cpp b/llvm/support/tools/TableGen/Record.cpp index 4032f40cdb85..a76c55cfb678 100644 --- a/llvm/support/tools/TableGen/Record.cpp +++ b/llvm/support/tools/TableGen/Record.cpp @@ -613,10 +613,26 @@ bool Record::getValueAsBit(const std::string &FieldName) const { throw "Record '" + getName() + "' does not have a field named '" + FieldName + "!\n"; - if (BitInit *DI = dynamic_cast(R->getValue())) - return DI->getValue(); + if (BitInit *BI = dynamic_cast(R->getValue())) + return BI->getValue(); throw "Record '" + getName() + "', field '" + FieldName + - "' does not have a list initializer!"; + "' does not have a bit initializer!"; +} + +/// getValueAsDag - This method looks up the specified field and returns its +/// value as an Dag, throwing an exception if the field does not exist or if +/// the value is not the right type. +/// +DagInit *Record::getValueAsDag(const std::string &FieldName) const { + const RecordVal *R = getValue(FieldName); + if (R == 0 || R->getValue() == 0) + throw "Record '" + getName() + "' does not have a field named '" + + FieldName + "!\n"; + + if (DagInit *DI = dynamic_cast(R->getValue())) + return DI; + throw "Record '" + getName() + "', field '" + FieldName + + "' does not have a dag initializer!"; } diff --git a/llvm/support/tools/TableGen/Record.h b/llvm/support/tools/TableGen/Record.h index b26e13ec8c3c..b62145164357 100644 --- a/llvm/support/tools/TableGen/Record.h +++ b/llvm/support/tools/TableGen/Record.h @@ -759,6 +759,12 @@ public: /// the value is not the right type. /// int getValueAsInt(const std::string &FieldName) const; + + /// getValueAsDag - This method looks up the specified field and returns its + /// value as an Dag, throwing an exception if the field does not exist or if + /// the value is not the right type. + /// + DagInit *getValueAsDag(const std::string &FieldName) const; }; std::ostream &operator<<(std::ostream &OS, const Record &R);