我想出了下面的函数,它按预期工作,但它使用了 eval,这很可怕,并且在我打算使用它的 ClojureScript 中不存在。
(defn path [d p]
(eval
(concat '[-> d]
(flatten (map
#(conj (repeat (dec %) 'z/right) 'z/down)
(path-to-vector p))))))
我如何将其转换为宏?我的尝试如下所示:
(defmacro path [d p]
`(concat (-> ~d)
(flatten
(map #(conj (repeat (dec %) z/right) z/down)
(path-to-vector ~p)))))
但这显然行不通。