diff options
author | Konrad Hinsen <konrad.hinsen@laposte.net> | 2009-02-08 17:29:44 +0000 |
---|---|---|
committer | Konrad Hinsen <konrad.hinsen@laposte.net> | 2009-02-08 17:29:44 +0000 |
commit | 9bb63b7b8cd0bdbdee32ac71d7aeab9405acf3a2 (patch) | |
tree | f2fdb4b018883aeb28b3cff13c55b548dcb14477 /src/clojure/contrib/accumulators/examples.clj | |
parent | 4e820101c55e7bd6340c334bd419f91b4e21bfc9 (diff) |
accumulators: renamed add-coll to add-items and added queue accumulator
Diffstat (limited to 'src/clojure/contrib/accumulators/examples.clj')
-rw-r--r-- | src/clojure/contrib/accumulators/examples.clj | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/src/clojure/contrib/accumulators/examples.clj b/src/clojure/contrib/accumulators/examples.clj index 3821ca88..a3d7b026 100644 --- a/src/clojure/contrib/accumulators/examples.clj +++ b/src/clojure/contrib/accumulators/examples.clj @@ -11,48 +11,53 @@ ; Vector accumulator: combine is concat, add is conj (combine [:a :b] [:c :d] [:x :y]) (add [:a :b] :c) -(add-coll empty-vector [:a :b :a]) +(add-items empty-vector [:a :b :a]) ; List accumulator: combine is concat, add is conj (combine '(:a :b) '(:c :d) '(:x :y)) (add '(:a :b) :c) -(add-coll empty-list [:a :b :a]) +(add-items empty-list [:a :b :a]) + +; Queue accumulator +(let [q1 (add-items empty-queue [:a :b :a]) + q2 (add-items empty-queue [:x :y])] + (combine q1 q2)) ; Set accumulator: combine is union, add is conj (combine #{:a :b} #{:c :d} #{:a :d}) (add #{:a :b} :c) -(add-coll empty-set [:a :b :a]) +(add-items empty-set [:a :b :a]) ; Map accumulator: combine is merge, add is conj (combine {:a 1} {:b 2 :c 3} {}) (add {:a 1} [:b 2]) -(add-coll empty-map [[:a 1] [:b 2] [:a 0]]) +(add-items empty-map [[:a 1] [:b 2] [:a 0]]) ; Counter accumulator -(let [c1 (add-coll empty-counter [:a :b :a]) - c2 (add-coll empty-counter [:x :y])] +(let [c1 (add-items empty-counter [:a :b :a]) + c2 (add-items empty-counter [:x :y])] (combine c1 c2)) ; Counter-with-total accumulator -(let [c1 (add-coll empty-counter-with-total [:a :b :a]) - c2 (add-coll empty-counter-with-total [:x :y])] +(let [c1 (add-items empty-counter-with-total [:a :b :a]) + c2 (add-items empty-counter-with-total [:x :y])] (combine c1 c2)) ; Sum accumulator: combine is addition -(let [s1 (add-coll empty-sum [1 2 3]) - s2 (add-coll empty-sum [-1 -2 -3])] +(let [s1 (add-items empty-sum [1 2 3]) + s2 (add-items empty-sum [-1 -2 -3])] (combine s1 s2)) ; Product accumulator: combine is multiplication -(let [p1 (add-coll empty-product [2 3]) - p2 (add-coll empty-product [(/ 1 2)])] +(let [p1 (add-items empty-product [2 3]) + p2 (add-items empty-product [(/ 1 2)])] (combine p1 p2)) ; String accumulator: combine is concatenation (combine "a" "b" "c" "def") (add "a" (char 44)) -(add-coll empty-string [(char 55) (char 56) (char 57)]) +(add-items empty-string [(char 55) (char 56) (char 57)]) ; Accumulator tuples permit to update several accumulators in parallel (let [pair (empty-tuple [empty-vector empty-string])] - (add-coll pair [[1 "a"] [2 "b"]])) + (add-items pair [[1 "a"] [2 "b"]])) |