diff --git a/Processors/Z80/State/State.cpp b/Processors/Z80/State/State.cpp index c9b90f2de..52b3e6022 100644 --- a/Processors/Z80/State/State.cpp +++ b/Processors/Z80/State/State.cpp @@ -195,6 +195,18 @@ State::Registers::Registers() { } } +std::unordered_map State::Registers::pretty_names() const { + return { + { "afDash", "af'" }, + { "bcDash", "bc'" }, + { "deDash", "de'" }, + { "hlDash", "hl'" }, + { "program_counter", "pc" }, + { "stack_pointer", "sp" }, + { "interrupt_mode", "im" }, + }; +} + State::ExecutionState::ExecutionState() { if(needs_declare()) { DeclareField(is_halted); diff --git a/Processors/Z80/State/State.hpp b/Processors/Z80/State/State.hpp index f5676aa60..d62156448 100644 --- a/Processors/Z80/State/State.hpp +++ b/Processors/Z80/State/State.hpp @@ -38,6 +38,8 @@ struct State: public Reflection::StructImpl { int interrupt_mode; bool iff1, iff2; + std::unordered_map pretty_names() const override; + Registers(); } registers; diff --git a/Reflection/Struct.cpp b/Reflection/Struct.cpp index 46a1c65a8..b27652301 100644 --- a/Reflection/Struct.cpp +++ b/Reflection/Struct.cpp @@ -205,6 +205,7 @@ void Reflection::Struct::append(std::ostringstream &stream, const std::string &k std::string Reflection::Struct::description() const { std::ostringstream stream; + const auto name_map = pretty_names(); stream << "{"; @@ -212,7 +213,10 @@ std::string Reflection::Struct::description() const { for(const auto &key: all_keys()) { if(!is_first) stream << ", "; is_first = false; - stream << key << ": "; + + // Use the pretty name for this key, if defined. + const auto mapped_key = name_map.find(key); + stream << (mapped_key != name_map.end() ? mapped_key->second : key) << ": "; const auto count = count_of(key); const auto type = type_of(key); diff --git a/Reflection/Struct.hpp b/Reflection/Struct.hpp index 24dbd489d..0e4cb3227 100644 --- a/Reflection/Struct.hpp +++ b/Reflection/Struct.hpp @@ -27,6 +27,14 @@ namespace Reflection { #define DeclareField(Name) declare(&Name, #Name) struct Struct { + /*! + Maps from internal key names to more human-friendly ones; e.g. might contain + a mapping from afDash to af'. + */ + virtual std::unordered_map pretty_names() const { + return {}; + } + virtual std::vector all_keys() const = 0; virtual const std::type_info *type_of(const std::string &name) const = 0; virtual size_t count_of(const std::string &name) const = 0;