(let [a (clojure.core.async/chan)]
(case a
a :foo
:bar))
#=> :bar
Я бы ожидал :foo
здесь. Что я делаю не так?
С другой стороны, (condp = chan ...)
выполняет свою работу.
PS:
В основном я пытаюсь сделать следующее:
(require '[clojure.core.async :as a])
(let [chan1 (a/chan 10)
chan2 (a/chan 10)]
(a/>!! chan1 true)
(let [[v c] (a/alts!! [chan1 chan2])]
(case c
chan1 :chan1
chan2 :chan2
:niether)))
#=> :neither