mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-15 06:29:05 +00:00
Add new getValueAsBitsInit 'high-level' method
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7467 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -26,14 +26,7 @@ void CodeEmitterGen::run(std::ostream &o) {
|
|||||||
o << " case " << Namespace << R->getName() << ": {\n"
|
o << " case " << Namespace << R->getName() << ": {\n"
|
||||||
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
|
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
|
||||||
|
|
||||||
const RecordVal *InstVal = R->getValue("Inst");
|
BitsInit *BI = R->getValueAsBitsInit("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;
|
|
||||||
|
|
||||||
unsigned Value = 0;
|
unsigned Value = 0;
|
||||||
const std::vector<RecordVal> &Vals = R->getValues();
|
const std::vector<RecordVal> &Vals = R->getValues();
|
||||||
@@ -50,7 +43,7 @@ void CodeEmitterGen::run(std::ostream &o) {
|
|||||||
}
|
}
|
||||||
DEBUG(o << "\n");
|
DEBUG(o << "\n");
|
||||||
|
|
||||||
DEBUG(o << " // " << *InstVal << "\n");
|
DEBUG(o << " // " << *R->getValue("Inst") << "\n");
|
||||||
o << " Value = " << Value << "U;\n\n";
|
o << " Value = " << Value << "U;\n\n";
|
||||||
|
|
||||||
// Loop over all of the fields in the instruction adding in any
|
// Loop over all of the fields in the instruction adding in any
|
||||||
|
@@ -468,6 +468,23 @@ std::string Record::getValueAsString(const std::string &FieldName) const {
|
|||||||
"' does not have a string initializer!";
|
"' 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; }
|
void RecordKeeper::dump() const { std::cerr << *this; }
|
||||||
|
|
||||||
|
@@ -605,6 +605,12 @@ public:
|
|||||||
///
|
///
|
||||||
std::string getValueAsString(const std::string &FieldName) const;
|
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);
|
std::ostream &operator<<(std::ostream &OS, const Record &R);
|
||||||
|
@@ -26,14 +26,7 @@ void CodeEmitterGen::run(std::ostream &o) {
|
|||||||
o << " case " << Namespace << R->getName() << ": {\n"
|
o << " case " << Namespace << R->getName() << ": {\n"
|
||||||
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
|
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
|
||||||
|
|
||||||
const RecordVal *InstVal = R->getValue("Inst");
|
BitsInit *BI = R->getValueAsBitsInit("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;
|
|
||||||
|
|
||||||
unsigned Value = 0;
|
unsigned Value = 0;
|
||||||
const std::vector<RecordVal> &Vals = R->getValues();
|
const std::vector<RecordVal> &Vals = R->getValues();
|
||||||
@@ -50,7 +43,7 @@ void CodeEmitterGen::run(std::ostream &o) {
|
|||||||
}
|
}
|
||||||
DEBUG(o << "\n");
|
DEBUG(o << "\n");
|
||||||
|
|
||||||
DEBUG(o << " // " << *InstVal << "\n");
|
DEBUG(o << " // " << *R->getValue("Inst") << "\n");
|
||||||
o << " Value = " << Value << "U;\n\n";
|
o << " Value = " << Value << "U;\n\n";
|
||||||
|
|
||||||
// Loop over all of the fields in the instruction adding in any
|
// Loop over all of the fields in the instruction adding in any
|
||||||
|
@@ -468,6 +468,23 @@ std::string Record::getValueAsString(const std::string &FieldName) const {
|
|||||||
"' does not have a string initializer!";
|
"' 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; }
|
void RecordKeeper::dump() const { std::cerr << *this; }
|
||||||
|
|
||||||
|
@@ -605,6 +605,12 @@ public:
|
|||||||
///
|
///
|
||||||
std::string getValueAsString(const std::string &FieldName) const;
|
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);
|
std::ostream &operator<<(std::ostream &OS, const Record &R);
|
||||||
|
Reference in New Issue
Block a user