|
1 | | -import * from "list"; |
| 1 | +import * from "list" |
2 | 2 |
|
3 | 3 | export record Rec { |
4 | 4 | foo: List<Number>, |
5 | | - bar: String |
6 | | -}; |
| 5 | + bar: String, |
| 6 | +} |
7 | 7 |
|
8 | 8 | export enum Poly { |
9 | 9 | PList(List<Number>), |
10 | 10 | PArray(Array<Poly>), |
11 | 11 | PAssoc(Rec), |
12 | 12 | PMulti(List<String>, Number, Rec), |
13 | | - PPoly(List<Poly>) |
14 | | -}; |
| 13 | + PPoly(List<Poly>), |
| 14 | +} |
15 | 15 |
|
16 | | -let test = (test) => { |
17 | | - let (input, expected) = test; |
| 16 | +let test = test => { |
| 17 | + let (input, expected) = test |
18 | 18 | let result = match (input) { |
19 | 19 | PList([]) => 1, |
20 | | - PList([a, b]) => a + b, |
| 20 | + PList([a, b] | [_, a, b]) => a + b, |
21 | 21 | PList([a, ..._]) => a, |
22 | | - PAssoc({foo: [], _}) => 1, |
23 | | - PAssoc({foo: [a, b], _}) => a + b, |
24 | | - PAssoc({foo: [a, ..._], _}) => a, |
25 | | - PMulti([], a, {foo: [], _}) => a, |
26 | | - PMulti([_, ..._], a, {foo: [b, ..._], _}) => a + b, |
27 | | - PMulti([], _, {foo: [b, ..._], _}) => b, |
28 | | - PMulti([_, ..._], a, {foo: [b, c, ..._], _}) => a + b + c, |
29 | | - PPoly([PList([a]), PAssoc({foo: [b], _}), PMulti([], c, {foo: [d], _})]) => a + b + c + d, |
| 22 | + PAssoc({ foo: [], _ }) => 1, |
| 23 | + PAssoc({ foo: [a, b], _ }) => a + b, |
| 24 | + PAssoc({ foo: [a, ..._], _ }) => a, |
| 25 | + PMulti([], a, { foo: [], _ }) => a, |
| 26 | + PMulti([_, ..._], a, { foo: [b, ..._], _ }) => a + b, |
| 27 | + PMulti([], _, { foo: [b, ..._], _ }) => b, |
| 28 | + PMulti([_, ..._], a, { foo: [b, c, ..._], _ }) => a + b + c, |
| 29 | + PPoly( |
| 30 | + [PList([a]), PAssoc({ foo: [b], _ }), PMulti([], c, { foo: [d], _ })] |
| 31 | + ) => |
| 32 | + a + |
| 33 | + b + |
| 34 | + c + |
| 35 | + d, |
30 | 36 | PPoly([]) => 42, |
| 37 | + PPoly([PList([]) | PPoly([])]) => 50, |
| 38 | + PPoly([PList([a, b]) | PPoly([PList([a, b]) | PPoly([PList([a, b])])])]) => |
| 39 | + a + |
| 40 | + b, |
31 | 41 | PPoly([_, ..._]) => 43, |
32 | | - PArray([>]) => 44, |
| 42 | + PArray([> ]) => 44, |
33 | 43 | PArray([> PList([a, b])]) => a + b, |
34 | 44 | PArray([> PPoly([PList([a, b])]), PList([c, d])]) => a + b + c + d, |
35 | | - PArray(_) => 45 |
36 | | - }; |
| 45 | + PArray(_) => 45, |
| 46 | + } |
| 47 | + if (result != expected) { |
| 48 | + print("Failed case " ++ toString(input) ++ ":") |
| 49 | + print("Expected " ++ toString(expected) ++ " but got " ++ toString(result)) |
| 50 | + } |
37 | 51 | result == expected |
38 | | -}; |
| 52 | +} |
39 | 53 |
|
40 | 54 | let tests = [ |
41 | 55 | (PList([]), 1), |
42 | 56 | (PList([2]), 2), |
43 | 57 | (PList([2, 7]), 9), |
44 | | - (PList([2, 7, 10]), 2), |
45 | | - (PAssoc({foo: [], bar: "bar"}), 1), |
46 | | - (PAssoc({foo: [2], bar: "bar"}), 2), |
47 | | - (PAssoc({foo: [2, 7], bar: "bar"}), 9), |
48 | | - (PAssoc({foo: [2, 7, 10], bar: "bar"}), 2), |
49 | | - (PMulti([], 17, {foo: [], bar: "bar"}), 17), |
50 | | - (PMulti(["foo"], 17, {foo: [3], bar: "bar"}), 20), |
51 | | - (PMulti([], 11, {foo: [4], bar: "bar"}), 4), |
52 | | - (PMulti(["foo"], 17, {foo: [3, 5], bar: "bar"}), 20), |
53 | | - (PPoly([PList([1]), PAssoc({foo: [2], bar: "bar"}), PMulti([], 3, {foo: [4], bar: "bar"})]), 10), |
| 58 | + (PList([2, 7, 10]), 17), |
| 59 | + (PList([2, 7, 10, 11]), 2), |
| 60 | + (PAssoc({ foo: [], bar: "bar" }), 1), |
| 61 | + (PAssoc({ foo: [2], bar: "bar" }), 2), |
| 62 | + (PAssoc({ foo: [2, 7], bar: "bar" }), 9), |
| 63 | + (PAssoc({ foo: [2, 7, 10], bar: "bar" }), 2), |
| 64 | + (PMulti([], 17, { foo: [], bar: "bar" }), 17), |
| 65 | + (PMulti(["foo"], 17, { foo: [3], bar: "bar" }), 20), |
| 66 | + (PMulti([], 11, { foo: [4], bar: "bar" }), 4), |
| 67 | + (PMulti(["foo"], 17, { foo: [3, 5], bar: "bar" }), 20), |
| 68 | + ( |
| 69 | + PPoly( |
| 70 | + [ |
| 71 | + PList([1]), |
| 72 | + PAssoc({ foo: [2], bar: "bar" }), |
| 73 | + PMulti([], 3, { foo: [4], bar: "bar" }), |
| 74 | + ] |
| 75 | + ), |
| 76 | + 10, |
| 77 | + ), |
54 | 78 | (PPoly([]), 42), |
55 | | - (PPoly([PPoly([])]), 43), |
| 79 | + (PPoly([PPoly([])]), 50), |
| 80 | + (PPoly([PList([])]), 50), |
| 81 | + (PPoly([PList([7, 8])]), 15), |
| 82 | + (PPoly([PPoly([PList([7, 8])])]), 15), |
| 83 | + (PPoly([PPoly([PPoly([PList([7, 8])])])]), 15), |
56 | 84 | (PArray([>]), 44), |
57 | 85 | (PArray([> PList([3, 4])]), 7), |
58 | 86 | (PArray([> PPoly([PList([3, 4])]), PList([5, 6])]), 18), |
59 | 87 | (PArray([> PList([3, 4]), PList([3, 4])]), 45), |
60 | | -]; |
| 88 | +] |
61 | 89 |
|
62 | 90 | print(every(test, tests)) |
0 commit comments