1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
use super::{ActiveInterrupt, Memory};

pub struct LoggingMemory {
  backing: Box<dyn Memory>,
  message: String,
  offset: u16,
}

impl LoggingMemory {
  pub fn new(backing: impl Memory + 'static, message: &str, offset: u16) -> LoggingMemory {
    LoggingMemory {
      backing: Box::new(backing),
      message: message.to_owned(),
      offset,
    }
  }
}

impl Memory for LoggingMemory {
  fn read(&mut self, address: u16) -> u8 {
    let value = self.backing.read(address);
    println!(
      "[Memory Read]: {} address {:04X}, value {:02X}",
      self.message,
      address + self.offset,
      value
    );
    value
  }

  fn write(&mut self, address: u16, value: u8) {
    self.backing.write(address, value);
    println!(
      "[Memory Write]: {} address {:04X}, value {:02X}",
      self.message,
      address + self.offset,
      value
    );
  }

  fn reset(&mut self) {
    self.backing.reset();
    println!("[Memory Reset]: {}", self.message);
  }

  fn poll(&mut self, cycles_since_poll: u64, total_cycle_count: u64) -> ActiveInterrupt {
    // println!("[Memory Poll]: {}", self.message);
    self.backing.poll(cycles_since_poll, total_cycle_count)
  }
}