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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
use crate::proc::Processor;
use crate::proc::range::ProcessorRange;
#[derive(Copy, Clone)]
pub struct Checkpoint {
read_next: usize,
write_next: usize,
}
impl Checkpoint {
pub fn get_written_range_since(&self, amount: usize) -> ProcessorRange {
ProcessorRange {
start: self.write_next,
end: self.write_next + amount,
}
}
pub fn new(proc: &Processor) -> Checkpoint {
Checkpoint {
read_next: proc.read_next,
write_next: proc.write_next,
}
}
pub fn last_written(&self, proc: &mut Processor) -> Option<u8> {
if proc.write_next <= self.write_next {
None
} else {
Some(proc.code[proc.write_next - 1])
}
}
pub fn write_skipped(&mut self, proc: &mut Processor) -> () {
debug_assert_eq!(proc.write_next, self.write_next);
let src_start = self.read_next;
let src_end = proc.read_next;
proc.code.copy_within(src_start..src_end, self.write_next);
proc.write_next += src_end - src_start;
}
pub fn erase_written(&self, proc: &mut Processor) -> () {
proc.write_next = self.write_next;
}
pub fn consumed_range(&self, proc: &mut Processor) -> ProcessorRange {
ProcessorRange { start: self.read_next, end: proc.read_next }
}
pub fn written_range(&self, proc: &mut Processor) -> ProcessorRange {
ProcessorRange { start: self.write_next, end: proc.write_next }
}
pub fn consumed_count(&self, proc: &mut Processor) -> usize {
proc.read_next - self.read_next
}
pub fn written_count(&self, proc: &mut Processor) -> usize {
proc.write_next - self.write_next
}
}