clojure-koans/src/path_to_enlightenment.clj

44 lines
1.1 KiB
Clojure
Raw Normal View History

(ns path-to-enlightenment
2010-10-29 15:07:11 +00:00
(:use [clojure.test])
(:require [clojure.set]))
(def __ nil)
(def ___ (fn [& args] nil))
(defmacro meditations [& forms]
(let [pairs (partition 2 forms)]
`(do
2010-05-06 22:38:34 +00:00
~@(map
(fn [[doc# code#]]
`(when-not (is ~code# ~doc#)
(System/exit 0)))
pairs))))
2010-07-12 23:19:54 +00:00
(def ordered-koans
["equalities"
2010-07-12 23:11:15 +00:00
"lists"
"vectors"
"sets"
"maps"
"functions"
"conditionals"
"higher_order_functions"
"runtime_polymorphism"
"sequence_comprehensions"
2010-11-17 04:23:33 +00:00
"creating_functions"
2010-11-06 22:38:31 +00:00
"recursion"
2010-11-10 02:19:10 +00:00
"destructuring"
"refs"])
2010-07-11 21:04:37 +00:00
(defn require-version [[required-major required-minor]]
(let [{:keys [major minor]} *clojure-version*]
(if (or (< major required-major)
(and (== major required-major) (< minor required-minor)))
(throw (Exception. (str "Clojure version " required-major "."
required-minor " or higher required."))))))
2010-07-12 23:19:54 +00:00
(defn run []
(require-version [1 3])
2010-07-13 14:41:25 +00:00
(apply load (doall (map (partial str "koans/") ordered-koans)))
2010-07-12 23:19:54 +00:00
(println "You have achieved clojure enlightenment. Namaste."))