1
0
Fork 0
mirror of synced 2024-05-03 12:13:22 +12:00
FiraCode/clojure/fira_code/coll.clj
Nikita Prokopov 524a28629b Catching bugs
2020-05-15 03:51:54 +02:00

25 lines
466 B
Clojure

(ns fira-code.coll)
(defn index-of [pred xs]
(let [res (reduce (fn [i x] (if (pred x) (reduced i) (inc i))) 0 xs)]
(if (>= res (count xs))
-1
res)))
(defn group-by-to [key-fn value-fn xs]
(reduce-kv
(fn [m k vs]
(assoc m k (value-fn vs)))
{}
(group-by key-fn xs)))
(defn multimap-by [f & kvs]
(reduce
(fn [m [k v]]
(if (contains? m k)
(update m k f v)
(assoc m k v)))
{} (partition 2 kvs)))