-
Notifications
You must be signed in to change notification settings - Fork 0
/
header_footer.go
64 lines (54 loc) · 2.45 KB
/
header_footer.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
package main
import "time"
func renderHeaderAndFooter(timestampsFromLines []int64, timeMarkerCount int, terminalWidth int) (string, string) {
if timeMarkerCount == 0 {
return "", ""
}
firstTimestamp := time.Unix(timestampsFromLines[0], 0).UTC()
lastTimestamp := time.Unix(timestampsFromLines[len(timestampsFromLines)-1], 0).UTC()
duration := lastTimestamp.Sub(firstTimestamp)
footerMarkerCount := timeMarkerCount / 2
if timeMarkerCount%2 != 0 {
// If we have an odd number of markers, then the footer has one more marker than the header
footerMarkerCount++
}
offsets := timeStemOffsets(timeMarkerCount, terminalWidth)
durationBetweenOffsets := time.Duration(duration.Nanoseconds() / int64(terminalWidth))
headerOffsets := offsets[footerMarkerCount:]
headerCanvas := renderHeader(headerOffsets, terminalWidth, firstTimestamp, durationBetweenOffsets)
footerOffsets := offsets[0:footerMarkerCount]
footerCanvas := renderFooter(footerOffsets, terminalWidth, firstTimestamp, durationBetweenOffsets)
return headerCanvas.String(), footerCanvas.String()
}
func renderHeader(markerOffsets []int, terminalWidth int, firstTimestamp time.Time, durationBetweenOffsets time.Duration) canvas {
canvas := newCanvas(canvasTypeHeader, terminalWidth, len(markerOffsets)+1)
needStackedMarkers := (len(firstTimestamp.Format(goAnsicTimeFormat))+1)*len(markerOffsets) >= (terminalWidth / 2)
for verticalOffset, horizontalOffset := range markerOffsets {
if needStackedMarkers {
verticalOffset += 2
} else {
verticalOffset = 2
}
timeMarker{
horizontalOffset: horizontalOffset,
time: firstTimestamp.Add(time.Duration(horizontalOffset) * durationBetweenOffsets),
}.render(canvas, verticalOffset, stemAlignmentRight)
}
return canvas
}
func renderFooter(markerOffsets []int, terminalWidth int, firstTimestamp time.Time, durationBetweenOffsets time.Duration) canvas {
canvas := newCanvas(canvasTypeFooter, terminalWidth, len(markerOffsets)+1)
needStackedMarkers := (len(firstTimestamp.Format(goAnsicTimeFormat))+1)*len(markerOffsets) >= (terminalWidth / 2)
for verticalOffset, horizontalOffset := range markerOffsets {
if needStackedMarkers {
verticalOffset = len(markerOffsets) - verticalOffset + 1
} else {
verticalOffset = 2
}
timeMarker{
horizontalOffset: horizontalOffset,
time: firstTimestamp.Add(time.Duration(horizontalOffset) * durationBetweenOffsets),
}.render(canvas, verticalOffset, stemAlignmentLeft)
}
return canvas
}