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
|
func main()
t := {"one": 1, "two": 2}
assert t == {"one": 1, "two": 2}
assert t["one"] == 1
assert t["two"] == 2
assert t["???"] == none
assert t["one"]! == 1
assert t["???"] or -1 == -1
t_str := ""
for k,v in t
t_str ++= "($k=$v)"
assert t_str == "(one=1)(two=2)"
assert t.length == 2
assert t.fallback == none
assert t.keys == ["one", "two"]
assert t.values == [1, 2]
t2 := {"three": 3; fallback=t}
assert t2 == {"three": 3; fallback={"one": 1, "two": 2}}
assert t2["one"] == 1
assert t2["three"] == 3
assert t2["???"] == none
assert t2.length == 1
assert t2.fallback == {"one": 1, "two": 2}
t2_str := ""
for k,v in t2
t2_str ++= "($k=$v)"
assert t2_str == "(three=3)"
assert {i: 10*i for i in 5} == {1: 10, 2: 20, 3: 30, 4: 40, 5: 50}
assert {i: 10*i for i in 5 if i mod 2 != 0} == {1: 10, 3: 30, 5: 50}
assert {x: 10*x for x in y if x > 1 for y in [3, 4, 5] if y < 5} == {2: 20, 3: 30, 4: 40}
>> t3 := @{1: 10, 2: 20, 3: 30}
>> t3.remove(3)
assert t3[] == {1: 10, 2: 20}
do
>> plain := {1: 10, 2: 20, 3: 30}
assert plain[2]! == 20
assert plain[2]! == 20
assert plain[456] or -999 == -999
assert plain.has(2) == yes
assert plain.has(456) == no
>> fallback := {4: 40; fallback=plain}
assert fallback.has(1) == yes
assert fallback[1] or -999 == 10
do
>> t4 := &{"one": 1}
>> t4["one"] = 999
>> t4["two"] = 222
assert t4[] == {"one": 999, "two": 222}
do
assert {1: 1, 2: 2} == {2: 2, 1: 1}
assert {1: 1, 2: 2} != {1: 1, 2: 999}
assert ({1: 1, 2: 2} <> {2: 2, 1: 1}) == Int32(0)
ints : [{Int:Int}] = [{}, {0: 0}, {99: 99}, {1: 1, 2: 2, 3: 3}, {1: 1, 99: 99, 3: 3}, {1: 1, 2: -99, 3: 3}, {1: 1, 99: -99, 3: 4}]
assert ints.sorted() == [{}, {0: 0}, {1: 1, 2: -99, 3: 3}, {1: 1, 2: 2, 3: 3}, {1: 1, 99: 99, 3: 3}, {1: 1, 99: -99, 3: 4}, {99: 99}]
do
# Default values:
counter := &{"x": 10; default=0}
assert counter["x"] == 10
assert counter["y"] == 0
assert counter.has("x") == yes
assert counter.has("y") == no
>> counter["y"] += 1
do
# Set operations
a := {"A":1, "B":2, "C":3}
b := {"B":2, "C":30, "D":40}
assert a.with(b) == {"A":1, "B":2, "C":30, "D":40}
assert a.with(b) == a ++ b
assert a.intersection(b) == {"B":2}
assert a.difference(b) == {"A":1, "D":40}
assert a.without(b) == {"A":1, "C":3}
do
# Set operations with sets
a := {"A", "B", "C"}
b := {"B", "C", "D"}
assert a.with(b) == {"A", "B", "C", "D"}
assert a.with(b) == a ++ b
assert a.intersection(b) == {"B", "C"}
assert a.difference(b) == {"A", "D"}
assert a.without(b) == {"A"}
|