Make the code a little more like the JSON schema.

Signed-off-by: Adrian Conlon <adrian.conlon@gmail.com>
This commit is contained in:
Adrian Conlon 2021-10-22 11:24:45 +01:00
parent 2890cc5dbb
commit 8b7607f5e9
2 changed files with 25 additions and 25 deletions

View File

@ -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(' ')

View File

@ -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")); }
}; };