#pragma once #include #include "Signal.h" #include "Register.h" #include "EventArgs.h" namespace EightBit { class Bus { public: virtual ~Bus() = default; Signal WritingByte; Signal WrittenByte; Signal ReadingByte; Signal ReadByte; register16_t& ADDRESS() { return m_address; } register16_t ADDRESS() const { return m_address; } uint8_t& DATA() { return m_data; } uint8_t DATA() const { return m_data; } uint8_t peek(); uint8_t peek(uint16_t address); void poke(uint8_t value); void poke(uint16_t address, uint8_t value); uint16_t peekWord(uint16_t address); uint8_t read(); template uint8_t read(const T address) { ADDRESS() = address; return read(); } void write(); void write(uint8_t value); template void write(const T offset, const uint8_t value) { ADDRESS() = offset; write(value); } protected: virtual uint8_t& reference(uint16_t address) = 0; uint8_t& reference(); private: uint8_t m_data = 0xff; register16_t m_address = 0xffff; }; }