rover/rover.fnl

67 lines
1.8 KiB
Plaintext
Raw Normal View History

2023-01-22 14:59:29 +00:00
(local { : view } (require :fennel))
2023-01-22 17:50:48 +00:00
(local { : merge } (require :lume))
2023-01-22 14:59:29 +00:00
(macro expect [text actual expected]
`(let [actual# ,actual]
(or (match actual#
,expected true
_# false)
(assert false (view {
:text ,text
:expected ,expected
:actual actual#
})))))
2023-01-22 17:51:53 +00:00
(fn execute [rover [cmd & cmds]]
(let [r1
(match rover.direction
2023-01-22 17:50:48 +00:00
:n (merge rover {:y (+ rover.y 1)})
:s (merge rover {:y (- rover.y 1)})
:w (merge rover {:x (- rover.x 1)})
:e (merge rover {:x (+ rover.x 1)}))]
(if (next cmds)
2023-01-22 17:51:53 +00:00
(r1:execute cmds)
r1)))
2023-01-22 14:59:29 +00:00
(fn rover [x y direction]
{: x
: y
: direction
2023-01-22 17:51:53 +00:00
: execute
})
(let [r (rover 7 15 :n)]
(expect
"rover knows (x,y) and the direction (N,S,E,W) it is facing"
r
{:x 7 :y 15 :direction :n}))
2023-01-22 14:59:29 +00:00
(let [r (rover 0 0 :n)]
(expect "The rover receives a character array of commands"
2023-01-22 17:51:53 +00:00
(r:execute [:f :f :f])
{}))
(let [r (rover 0 0 :n)]
2023-01-22 17:21:34 +00:00
(expect "Moves north when pointing north and asked to move forward"
2023-01-22 17:51:53 +00:00
(r:execute [:f]) {:x 0 :y 1 :direction :n}))
(let [r (rover 3 2 :s)]
2023-01-22 17:21:34 +00:00
(expect "Moves south when pointing south and asked to move forward"
2023-01-22 17:51:53 +00:00
(r:execute [:f]) {:x 3 :y 1 :direction :s}))
2023-01-22 17:21:34 +00:00
(let [r (rover 0 0 :w)]
(expect "Moves west when pointing west and asked to move forward"
2023-01-22 17:51:53 +00:00
(r:execute [:f]) {:x -1 :y 0 :direction :w}))
2023-01-22 17:15:23 +00:00
2023-01-22 17:21:34 +00:00
(let [r (rover 0 0 :e)]
(expect "Moves east when pointing east and asked to move forward"
2023-01-22 17:51:53 +00:00
(r:execute [:f]) {:x 1 :y 0 :direction :e}))
(let [r (rover 1 1 :s)]
(expect "The rover acts on multiple commands"
2023-01-22 17:51:53 +00:00
(r:execute [:f :f :f])
{:x 1 :y -2 :direction :s}))
(print "OK")