summary refs log tree commit diff
path: root/lib/game/space-is-neighbor.fnl
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?}