summary refs log tree commit diff
path: root/lib/space-is-neighbor.fnl
blob: 380607c6171c86c5b5ecdd9885302288d4e5033f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
(local {: contains} (require :lib.contains))
(local {: head} (require :lib.head))
(local {: tail} (require :lib.tail))

(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?}