评论者:nberger
bq. 我们讨论过是否将 nil 作为 collect 中的非标签标志,但我并不特别喜欢这个想法。
也许我们可以使用一个命名空间关键字来表示应该忽略标签?例如,{{clojure.test.check.stats/ignore}}。这样,我们可以通过创建一个在预判不匹配时返回 {{stats/ignore}} 的函数,通过 terms of collect 实现 {{classify}}
`
(defn collect
[prop label-fn]
(gen/fmap
(fn [{:keys [args] :as result-map}]
(let [label (apply label-fn args)]
(if (= ::ignore label)
result-map
(update result-map :labels conj label))))
prop))
(defn classify
[prop pred label]
(collect prop (fn [& args]
(if (apply pred args)
label
::ignore))))
`
另一种选择是在 {{collect}} 中添加一个额外的参数,以接收关于是否应将 nil 作为标签处理或忽略的标志。我更喜欢 {{:stats/ignore}}