-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathtrackTracer.go
88 lines (72 loc) · 2.1 KB
/
trackTracer.go
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
package izapple2
import "fmt"
type trackTracer interface {
traceTrack(quarterTrack int, slot int, drive int)
}
// ///////////////
// TrackTracerLogger is a track tracer that logs to the console
type trackTracerLogger struct {
}
func makeTrackTracerLogger() *trackTracerLogger {
return &trackTracerLogger{}
}
func (tt *trackTracerLogger) traceTrack(quarterTrack int, slot int, drive int) {
fmt.Printf("Slot %v, drive %v, track %v\n", slot, drive, quarterTrack)
}
// ///////////////
// TrackTracerSummary is a track tracer that stores the track changes
type trackTracerSummary struct {
quarterTracks []int
}
func makeTrackTracerSummary() *trackTracerSummary {
var tt trackTracerSummary
tt.quarterTracks = make([]int, 0, 100)
return &tt
}
func (tt *trackTracerSummary) traceTrack(quarterTrack int, _slot int, _drive int) {
if tt == nil {
return
}
length := len(tt.quarterTracks)
if length == 0 {
// Second change, just record
tt.quarterTracks = append(tt.quarterTracks, quarterTrack)
return
}
last := tt.quarterTracks[length-1]
if quarterTrack == last {
// No changes
return
}
if length == 1 {
// Second change, just record
tt.quarterTracks = append(tt.quarterTracks, quarterTrack)
return
}
// We don't want to registers the initial jumps around 0 seen when initializing the disk to track 0
prevToLast := tt.quarterTracks[length-2]
if length == 2 && prevToLast == 0 && (last == 1 || last == 2) && quarterTrack == 0 {
tt.quarterTracks = tt.quarterTracks[0:0]
}
// We don't want to track each increment. If tracks goes from 1 to 14, we just want 1 and 14.
wasGoingUp := last > prevToLast
isGoingUp := quarterTrack > last
if isGoingUp == wasGoingUp {
// Same direction, update the last registry
tt.quarterTracks[length-1] = quarterTrack
} else {
// Change direction, add a new registry
tt.quarterTracks = append(tt.quarterTracks, quarterTrack)
}
}
func (tt *trackTracerSummary) isTraceAsExpected(expected []int) bool {
if len(tt.quarterTracks) != len(expected) {
return false
}
for i, v := range tt.quarterTracks {
if v != expected[i] {
return false
}
}
return true
}