如果我经营一个有借书人和书籍的图书馆:
(s/def ::brs (s/coll-of ::br/borrower))
(s/def ::bks (s/coll-of ::bk/book))
我想要一个将项目添加到任一集合的通用函数:
(defn add-item [x xs]
(if (some #{x} xs)
xs
(cons x xs)))
我如何编写一个规范以确保我不能向借款人添加一本书,反之亦然?
因为这个规范:
(s/fdef add-item
:args (s/fspec :args (s/or :is-brs (s/and (s/cat :x ::br/borrower) (s/cat :xs ::brs))
:is-bks (s/and (s/cat :x ::bk/book) (s/cat :xs ::bks))))
:ret (s/or :ret-brs ::brs
:ret-bks ::bks))
不管用。:-(
感谢您的帮助!