aboutsummaryrefslogtreecommitdiff
path: root/src/Order.gleam
blob: 00f6750c3f32fcc0378eef28990dd14c51033103 (plain)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
module Order

type Order =
  | LT
  | EQ
  | GT

import Order:*

; // Fix GitHub syntax highlighting

pub fn reverse(order) {
  case order {
  | LT => GT
  | EQ => EQ
  | GT => LT
  }
}

test reverse {
  reverse(LT) |> Assert.equal(_, GT)
  reverse(EQ) |> Assert.equal(_, EQ)
  reverse(GT) |> Assert.equal(_, LT)
}

pub fn to_int(order) {
  case order {
  | LT => -1
  | EQ => 0
  | GT => 1
  }
}

test to_int {
  to_int(LT) |> Assert.equal(_, -1)
  to_int(EQ) |> Assert.equal(_, 0)
  to_int(GT) |> Assert.equal(_, 1)
}

pub fn compare(a, b) {
  case {a, b} {
  | {LT, LT} => EQ
  | {LT, _} => LT
  | {EQ, EQ} => EQ
  | {GT, GT} => EQ
  | {EQ, GT} => LT
  | _ => GT
  }
}

test compare {
  compare(LT, LT) |> Assert.equal(_, EQ)
  compare(LT, EQ) |> Assert.equal(_, LT)
  compare(LT, GT) |> Assert.equal(_, LT)
  compare(EQ, LT) |> Assert.equal(_, GT)
  compare(EQ, EQ) |> Assert.equal(_, EQ)
  compare(EQ, GT) |> Assert.equal(_, LT)
  compare(GT, LT) |> Assert.equal(_, GT)
  compare(GT, EQ) |> Assert.equal(_, GT)
  compare(GT, GT) |> Assert.equal(_, EQ)
}

pub fn max(a, b) {
  case {a, b} {
  | {GT, _} => GT
  | {EQ, LT} => EQ
  | _ => b
  }
}

test max {
  max(LT, LT) |> Assert.equal(_, LT)
  max(LT, EQ) |> Assert.equal(_, EQ)
  max(LT, GT) |> Assert.equal(_, GT)
  max(EQ, LT) |> Assert.equal(_, EQ)
  max(EQ, EQ) |> Assert.equal(_, EQ)
  max(EQ, GT) |> Assert.equal(_, GT)
  max(GT, LT) |> Assert.equal(_, GT)
  max(GT, EQ) |> Assert.equal(_, GT)
  max(GT, GT) |> Assert.equal(_, GT)
}

pub fn min(a, b) {
  case {a, b} {
  | {LT, _} => LT
  | {EQ, GT} => EQ
  | _ => b
  }
}

test min {
  min(LT, LT) |> Assert.equal(_, LT)
  min(LT, EQ) |> Assert.equal(_, LT)
  min(LT, GT) |> Assert.equal(_, LT)
  min(EQ, LT) |> Assert.equal(_, LT)
  min(EQ, EQ) |> Assert.equal(_, EQ)
  min(EQ, GT) |> Assert.equal(_, EQ)
  min(GT, LT) |> Assert.equal(_, LT)
  min(GT, EQ) |> Assert.equal(_, EQ)
  min(GT, GT) |> Assert.equal(_, GT)
}