//HuC6260 -- Video Color Encoder struct VCE : Thread { inline auto clock() const -> uint { return io.clock; } static auto Enter() -> void; auto main() -> void; auto step(uint clocks) -> void; auto refresh() -> void; auto power() -> void; //io.cpp auto read(uint3 addr) -> uint8; auto write(uint3 addr, uint8 data) -> void; //serialization.cpp auto serialize(serializer&) -> void; private: uint32 buffer[1365 * 263]; struct CRAM { //memory.cpp auto read(uint9 addr) -> uint9; auto write(uint9 addr, bool a0, uint8 data) -> void; uint9 data[0x200]; uint9 address; } cram; struct Timing { uint hclock = 0; uint vclock = 0; } timing; struct IO { uint clock = 4; bool extraLine = 0; bool grayscale = 0; } io; }; extern VCE vce;