mirror of
https://github.com/MoleskiCoder/EightBit.git
synced 2025-01-17 10:30:13 +00:00
Make the code a little more like the JSON schema.
Signed-off-by: Adrian Conlon <adrian.conlon@gmail.com>
This commit is contained in:
parent
2890cc5dbb
commit
8b7607f5e9
@ -122,15 +122,15 @@ bool TestRunner::check(std::string what, uint16_t address, uint8_t expected, uin
|
|||||||
|
|
||||||
void TestRunner::initialiseState() {
|
void TestRunner::initialiseState() {
|
||||||
|
|
||||||
const auto starting = test().initial_state();
|
const auto initial = test().initial();
|
||||||
|
|
||||||
CPU().PC().word = starting.pc();
|
CPU().PC().word = initial.pc();
|
||||||
CPU().S() = starting.s();
|
CPU().S() = initial.s();
|
||||||
CPU().A() = starting.a();
|
CPU().A() = initial.a();
|
||||||
CPU().X() = starting.x();
|
CPU().X() = initial.x();
|
||||||
CPU().Y() = starting.y();
|
CPU().Y() = initial.y();
|
||||||
CPU().P() = starting.p();
|
CPU().P() = initial.p();
|
||||||
for (auto entry : starting.ram()) {
|
for (auto entry : initial.ram()) {
|
||||||
const byte_t byte(entry);
|
const byte_t byte(entry);
|
||||||
RAM().poke(byte.address(), byte.value());
|
RAM().poke(byte.address(), byte.value());
|
||||||
}
|
}
|
||||||
@ -138,8 +138,6 @@ void TestRunner::initialiseState() {
|
|||||||
|
|
||||||
bool TestRunner::checkState() {
|
bool TestRunner::checkState() {
|
||||||
|
|
||||||
const auto finished = test().final_state();
|
|
||||||
|
|
||||||
const auto& expected_cycles = test().cycles();
|
const auto& expected_cycles = test().cycles();
|
||||||
const auto& actual_cycles = m_actualCycles;
|
const auto& actual_cycles = m_actualCycles;
|
||||||
m_cycle_count_mismatch = expected_cycles.size() != actual_cycles.size();
|
m_cycle_count_mismatch = expected_cycles.size() != actual_cycles.size();
|
||||||
@ -154,15 +152,16 @@ bool TestRunner::checkState() {
|
|||||||
check("Cycle action", expected.action(), actual.action());
|
check("Cycle action", expected.action(), actual.action());
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto pc_good = check("PC", finished.pc(), CPU().PC().word);
|
const auto final = test().final();
|
||||||
const auto s_good = check("S", finished.s(), CPU().S());
|
const auto pc_good = check("PC", final.pc(), CPU().PC().word);
|
||||||
const auto a_good = check("A", finished.a(), CPU().A());
|
const auto s_good = check("S", final.s(), CPU().S());
|
||||||
const auto x_good = check("X", finished.x(), CPU().X());
|
const auto a_good = check("A", final.a(), CPU().A());
|
||||||
const auto y_good = check("Y", finished.y(), CPU().Y());
|
const auto x_good = check("X", final.x(), CPU().X());
|
||||||
const auto p_good = check("P", finished.p(), CPU().P());
|
const auto y_good = check("Y", final.y(), CPU().Y());
|
||||||
|
const auto p_good = check("P", final.p(), CPU().P());
|
||||||
|
|
||||||
bool ram_problem = false;
|
bool ram_problem = false;
|
||||||
for (const auto entry : finished.ram()) {
|
for (const auto entry : final.ram()) {
|
||||||
const byte_t byte(entry);
|
const byte_t byte(entry);
|
||||||
const auto ram_good = check("RAM", byte.address(), byte.value(), RAM().peek(byte.address()));
|
const auto ram_good = check("RAM", byte.address(), byte.value(), RAM().peek(byte.address()));
|
||||||
if (!ram_good && !ram_problem)
|
if (!ram_good && !ram_problem)
|
||||||
@ -213,12 +212,13 @@ void TestRunner::check() {
|
|||||||
|
|
||||||
disassemble(pc);
|
disassemble(pc);
|
||||||
|
|
||||||
raise("PC", test().final_state().pc(), CPU().PC().word);
|
const auto final = test().final();
|
||||||
raise("S", test().final_state().s(), CPU().S());
|
raise("PC", final.pc(), CPU().PC().word);
|
||||||
raise("A", test().final_state().a(), CPU().A());
|
raise("S", final.s(), CPU().S());
|
||||||
raise("X", test().final_state().x(), CPU().X());
|
raise("A", final.a(), CPU().A());
|
||||||
raise("Y", test().final_state().y(), CPU().Y());
|
raise("X", final.x(), CPU().X());
|
||||||
raise("P", test().final_state().p(), CPU().P());
|
raise("Y", final.y(), CPU().Y());
|
||||||
|
raise("P", final.p(), CPU().P());
|
||||||
|
|
||||||
os()
|
os()
|
||||||
<< std::dec << std::setfill(' ')
|
<< std::dec << std::setfill(' ')
|
||||||
|
@ -18,7 +18,7 @@ public:
|
|||||||
test_t(simdjson::dom::element input) noexcept;
|
test_t(simdjson::dom::element input) noexcept;
|
||||||
|
|
||||||
[[nodiscard]] auto name() const noexcept { return at("name"); }
|
[[nodiscard]] auto name() const noexcept { return at("name"); }
|
||||||
[[nodiscard]] auto initial_state() const noexcept { return state_t(at("initial")); }
|
[[nodiscard]] auto initial() const noexcept { return state_t(at("initial")); }
|
||||||
[[nodiscard]] auto final_state() const noexcept { return state_t(at("final")); }
|
[[nodiscard]] auto final() const noexcept { return state_t(at("final")); }
|
||||||
[[nodiscard]] auto cycles() const noexcept { return cycles_t(array_at("cycles")); }
|
[[nodiscard]] auto cycles() const noexcept { return cycles_t(array_at("cycles")); }
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user