blob: 373feaf2815fc57406b7e1c81dd5f40a80f2a4af (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
(local {: contains
: head
: tail
} (require :lib.table))
(lambda space-is-neighbor? [all-neighbors from to]
;; i have learned to check that i'm passing the correct type of move
;; i.e. a number and not a string
(assert (= "number" (type from)) "from must be a number")
(assert (= "number" (type to)) "to must be a number")
(assert (= "table" (type all-neighbors)) "all-neighbors must be a table")
(let [neighborhood-list (icollect [_ n (ipairs all-neighbors)] (if (= from (head n)) n))
neighborhood (head neighborhood-list)
neighbors (tail neighborhood)
is-neighbor (contains neighbors to)]
is-neighbor))
{: space-is-neighbor?}
|