mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
Add new method getVAlueAsDag
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7669 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
018c9e4d26
commit
784a793636
@ -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<BitInit*>(R->getValue()))
|
||||
return DI->getValue();
|
||||
if (BitInit *BI = dynamic_cast<BitInit*>(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<DagInit*>(R->getValue()))
|
||||
return DI;
|
||||
throw "Record '" + getName() + "', field '" + FieldName +
|
||||
"' does not have a dag initializer!";
|
||||
}
|
||||
|
||||
|
||||
|
@ -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);
|
||||
|
@ -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<BitInit*>(R->getValue()))
|
||||
return DI->getValue();
|
||||
if (BitInit *BI = dynamic_cast<BitInit*>(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<DagInit*>(R->getValue()))
|
||||
return DI;
|
||||
throw "Record '" + getName() + "', field '" + FieldName +
|
||||
"' does not have a dag initializer!";
|
||||
}
|
||||
|
||||
|
||||
|
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user