2024年Clojure问卷调查中分享你的想法!

欢迎!请查阅“关于”页面以了解更多关于该网站的工作信息。

0
core.match

以下由于存在{{recur}}导致爆炸

`
(defn rec [expr]
(match expr

     [:global] 'GLOBAL
     [:constant x] x
     [:variable x] x
     [:lazy-variable x] `(deref ~x)
     [:if test if-true if-false] `(if ~(rec test)
                                    ~(rec if-true)
                                    ~(rec if-false))
     [:delist list index] `(get ~(rec list) ~(rec index))
     [:depair pair key] `(get ~(rec pair) ~(match key :first 0 :second 1))
     [:list elements] (map rec elements)
     [:fold-recur index-arg list-sym] `(recur (+ 1 ~index-arg) (rest ~list-sym))
     [:zip left right] `(map vector ~(rec left) ~(rec right))
     [:filter list arg body] `(filter (fn [~arg] ~(rec body) ~(rec list)))
     [:len list] `(count ~(rec list))
     [:pair first second] [(rec first) (rec second)]
     [:block arg body] `(fn [~arg] ~(rec body))
     [:app f arg] `(~(rec f) ~(rec arg))
     [:query e annotations] `(QUERY ~(rec e) ~annotations)
     [:lookup key] `(LOOKUP ~key)
     [:let name value expr] `(let [~name ~value] expr)
     ; ... about 15 more
     ))

`

3个回答

0

由 jneen发表的评论

一种蹩脚的解决方案是从外部作用域获取{{'recur}}符号的插值。

`
(def recur-sym 'recur)

(match expr
... (~recur-sym ...)) ``

0

由 dnolen发表的评论

现在有了 tools.analyzer,解决这个问题将不再困难。

0
参考资料:https://clojure.atlassian.net/browse/MATCH-95 (由 dnolen 报告)
...