-
Notifications
You must be signed in to change notification settings - Fork 122
/
tracker_sort.go
81 lines (63 loc) · 2.27 KB
/
tracker_sort.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
package progress
import "sort"
// SortBy helps sort a list of Trackers by various means.
type SortBy int
const (
// SortByNone doesn't do any sorting == sort by insertion order.
SortByNone SortBy = iota
// SortByMessage sorts by the Message alphabetically in ascending order.
SortByMessage
// SortByMessageDsc sorts by the Message alphabetically in descending order.
SortByMessageDsc
// SortByPercent sorts by the Percentage complete in ascending order.
SortByPercent
// SortByPercentDsc sorts by the Percentage complete in descending order.
SortByPercentDsc
// SortByValue sorts by the Value in ascending order.
SortByValue
// SortByValueDsc sorts by the Value in descending order.
SortByValueDsc
)
// Sort applies the sorting method defined by SortBy.
func (sb SortBy) Sort(trackers []*Tracker) {
switch sb {
case SortByMessage:
sort.Sort(sortByMessage(trackers))
case SortByMessageDsc:
sort.Sort(sortDsc{sortByMessage(trackers)})
case SortByPercent:
sort.Sort(sortByPercent(trackers))
case SortByPercentDsc:
sort.Sort(sortDsc{sortByPercent(trackers)})
case SortByValue:
sort.Sort(sortByValue(trackers))
case SortByValueDsc:
sort.Sort(sortDsc{sortByValue(trackers)})
default:
// no sort
}
}
type sortByMessage []*Tracker
func (sb sortByMessage) Len() int { return len(sb) }
func (sb sortByMessage) Swap(i, j int) { sb[i], sb[j] = sb[j], sb[i] }
func (sb sortByMessage) Less(i, j int) bool { return sb[i].message() < sb[j].message() }
type sortByPercent []*Tracker
func (sb sortByPercent) Len() int { return len(sb) }
func (sb sortByPercent) Swap(i, j int) { sb[i], sb[j] = sb[j], sb[i] }
func (sb sortByPercent) Less(i, j int) bool {
if sb[i].PercentDone() == sb[j].PercentDone() {
return sb[i].timeStart.Before(sb[j].timeStart)
}
return sb[i].PercentDone() < sb[j].PercentDone()
}
type sortByValue []*Tracker
func (sb sortByValue) Len() int { return len(sb) }
func (sb sortByValue) Swap(i, j int) { sb[i], sb[j] = sb[j], sb[i] }
func (sb sortByValue) Less(i, j int) bool {
if sb[i].value == sb[j].value {
return sb[i].timeStart.Before(sb[j].timeStart)
}
return sb[i].value < sb[j].value
}
type sortDsc struct{ sort.Interface }
func (sd sortDsc) Less(i, j int) bool { return !sd.Interface.Less(i, j) && sd.Interface.Less(j, i) }