我正在尝试从“Land of Lisp”重写向导游戏 http://landoflisp.com/wizards_game.lisp
(def *nodes* {:living-room "you are in the living-room. a wizard is snoring loudly on the couch."
:garden "you are in a beautiful garden. there is a well in front of you."
:attic "you are in the attic. there is a giant welding torch in the corner."})
(def *edges* {:living-room '((garden west door) (attic upstairs ladder))
:garden '(living-room east door)
:attic '(living-room downstairs ladder)})
(defn describe-location [location nodes]
(nodes location))
(defn describe-path-raw [edge]
`(there is a ~(last edge) going ~(second edge) from here.))
(defn describe-path [edge]
(map #(symbol (name %)) (describe-path-raw edge)))
(defn describe-paths [location edges]
(apply concat (map describe-path-raw (location edges))))
尝试时:
(println (describe-paths :attic *edges*))
我得到了这个例外:
线程“主”java.lang.RuntimeException 中的异常:java.lang.IllegalArgumentException:不知道如何从以下位置创建 ISeq:clojure.lang.Symbol (wizard-game.clj:0)
我还没有 Lispy 的眼睛,我做错了什么?