-
-
Notifications
You must be signed in to change notification settings - Fork 30
/
tools.clj
96 lines (82 loc) · 2.79 KB
/
tools.clj
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
(require '[clojure.java.shell :as shell]
'[cljs.build.api :as api]
'[cljs.repl :as repl]
'[cljs.repl.node :as node])
(require '[rebel-readline.core]
'[rebel-readline.clojure.line-reader]
'[rebel-readline.cljs.service.local]
'[rebel-readline.cljs.repl])
(defmulti task first)
(defmethod task :default
[args]
(let [all-tasks (-> task methods (dissoc :default) keys sort)
interposed (->> all-tasks (interpose ", ") (apply str))]
(println "Unknown or missing task. Choose one of:" interposed)
(System/exit 1)))
(defmethod task "repl:node"
[args]
(rebel-readline.core/with-line-reader
(rebel-readline.clojure.line-reader/create
(rebel-readline.cljs.service.local/create))
(cljs.repl/repl
(node/repl-env)
:prompt (fn []) ;; prompt is handled by line-reader
:read (rebel-readline.cljs.repl/create-repl-read)
:output-dir "out/repl"
:cache-analysis false)))
(def options
{:main 'cuerdas.core-test
:output-to "out/tests.js"
:output-dir "out"
:target :nodejs
:optimizations :none
:pretty-print true
:install-deps true
:verbose true})
(defn build
[optimizations]
(api/build (api/inputs "src" "test")
(cond-> (assoc options :optimizations optimizations)
(= optimizations :none)
(assoc :source-map true)
(= optimizations :advanced)
(assoc :pseudo-names true
:pretty-print true))))
(defmethod task "build"
[[_ type]]
(case type
"none" (build :none)
"simple" (build :simple)
"advanced" (build :advanced)
(do (println "Unknown argument to test task:" type)
(System/exit 1))))
(defmethod task "test"
[[_ type]]
(letfn [(run-tests []
(let [{:keys [out err]} (shell/sh "node" "out/tests.js")]
(println out err)))
(test-once []
(build :none)
(run-tests)
(shutdown-agents))
(test-watch []
(println "Start watch loop...")
(try
(api/watch (api/inputs "src" "test")
(assoc options
:parallel-build false
:watch-fn run-tests
:cache-analysis false
:optimizations :none
:source-map false))
(catch Exception e
(println "ERROR:" e)
(Thread/sleep 2000)
(test-watch))))]
(case type
(nil "once") (test-once)
"watch" (test-watch)
(do (println "Unknown argument to test task:" type)
(System/exit 1)))))
;;; Build script entrypoint. This should be the last expression.
(task *command-line-args*)