22 24
This commit is contained in:
parent
064f6405ad
commit
eb47539b33
3 changed files with 11 additions and 11 deletions
File diff suppressed because one or more lines are too long
|
|
@ -2,12 +2,12 @@
|
||||||
(:require [koan-engine.core :refer :all]))
|
(:require [koan-engine.core :refer :all]))
|
||||||
|
|
||||||
(defn get-odds-and-evens [coll]
|
(defn get-odds-and-evens [coll]
|
||||||
(let [{odds true evens false} (group-by __ coll)]
|
(let [{odds true evens false} (group-by odd? coll)]
|
||||||
[odds evens]))
|
[odds evens]))
|
||||||
|
|
||||||
(meditations
|
(meditations
|
||||||
"To categorize a collection by some function, use group-by."
|
"To categorize a collection by some function, use group-by."
|
||||||
(= __ (group-by count ["hello" "world" "foo" "bar"]))
|
(= {3 ["foo" "bar"] 5 ["hello" "world"]} (group-by count ["hello" "world" "foo" "bar"]))
|
||||||
|
|
||||||
"You can simulate filter + remove in one pass"
|
"You can simulate filter + remove in one pass"
|
||||||
(= (get-odds-and-evens [1 2 3 4 5])
|
(= (get-odds-and-evens [1 2 3 4 5])
|
||||||
|
|
@ -15,7 +15,7 @@
|
||||||
[[1 3 5] [2 4]])
|
[[1 3 5] [2 4]])
|
||||||
|
|
||||||
"You can also group by a primary key"
|
"You can also group by a primary key"
|
||||||
(= __
|
(= {1 [{:id 1 :name "Bob"} {:id 1 :last-name "Smith"}] 2 [{:id 2 :name "Jennifer"}]}
|
||||||
(group-by :id [{:id 1 :name "Bob"}
|
(group-by :id [{:id 1 :name "Bob"}
|
||||||
{:id 2 :name "Jennifer"}
|
{:id 2 :name "Jennifer"}
|
||||||
{:id 1 :last-name "Smith"} ]))
|
{:id 1 :last-name "Smith"} ]))
|
||||||
|
|
@ -23,13 +23,13 @@
|
||||||
"But be careful when you group by a non-required key"
|
"But be careful when you group by a non-required key"
|
||||||
(= {"Bob" [{:name "Bob" :id 1}]
|
(= {"Bob" [{:name "Bob" :id 1}]
|
||||||
"Jennifer" [{:name "Jennifer" :id 2}]
|
"Jennifer" [{:name "Jennifer" :id 2}]
|
||||||
__ [{:last-name "Smith" :id 1}]}
|
nil [{:last-name "Smith" :id 1}]}
|
||||||
(group-by :name [{:id 1 :name "Bob"}
|
(group-by :name [{:id 1 :name "Bob"}
|
||||||
{:id 2 :name "Jennifer"}
|
{:id 2 :name "Jennifer"}
|
||||||
{:id 1 :last-name "Smith"}]))
|
{:id 1 :last-name "Smith"}]))
|
||||||
|
|
||||||
"The true power of group-by comes with custom functions"
|
"The true power of group-by comes with custom functions"
|
||||||
(= __
|
(= {:naughty-list [{:name "Jimmy" :bad true} {:name "Joe" :bad true}] :nice-list [{:name "Jane" :bad false}]}
|
||||||
(group-by #(if (:bad %) :naughty-list :nice-list)
|
(group-by #(if (:bad %) :naughty-list :nice-list)
|
||||||
[{:name "Jimmy" :bad true}
|
[{:name "Jimmy" :bad true}
|
||||||
{:name "Jane" :bad false}
|
{:name "Jane" :bad false}
|
||||||
|
|
|
||||||
|
|
@ -9,8 +9,8 @@
|
||||||
|
|
||||||
(defmacro infix-concise [form]
|
(defmacro infix-concise [form]
|
||||||
`(~(second form) ; Note the syntax-quote (`) and unquote (~) characters!
|
`(~(second form) ; Note the syntax-quote (`) and unquote (~) characters!
|
||||||
__
|
~(first form)
|
||||||
__))
|
~(nth form 2)))
|
||||||
|
|
||||||
(defmacro recursive-infix [form]
|
(defmacro recursive-infix [form]
|
||||||
(cond (not (seq? form))
|
(cond (not (seq? form))
|
||||||
|
|
@ -27,13 +27,13 @@
|
||||||
|
|
||||||
(meditations
|
(meditations
|
||||||
"Macros are like functions created at compile time"
|
"Macros are like functions created at compile time"
|
||||||
(= __ (hello "Macros!"))
|
(= "Hello, Macros!" (hello "Macros!"))
|
||||||
|
|
||||||
"I can haz infix?"
|
"I can haz infix?"
|
||||||
(= __ (infix (9 + 1)))
|
(= 10 (infix (9 + 1)))
|
||||||
|
|
||||||
"Remember, these are nothing but code transformations"
|
"Remember, these are nothing but code transformations"
|
||||||
(= __ (macroexpand '(infix (9 + 1))))
|
(= '(+ 9 1) (macroexpand '(infix (9 + 1))))
|
||||||
|
|
||||||
"You can do better than that - hand crafting FTW!"
|
"You can do better than that - hand crafting FTW!"
|
||||||
(= '(* 10 2) (macroexpand '(infix-concise (10 * 2))))
|
(= '(* 10 2) (macroexpand '(infix-concise (10 * 2))))
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue