-
Notifications
You must be signed in to change notification settings - Fork 55
/
build.clj
77 lines (71 loc) · 2.92 KB
/
build.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
(ns build
(:require [build-shared]
[clojure.edn :as edn]
[clojure.tools.build.api :as b]))
(def version (build-shared/lib-version))
(def lib (build-shared/lib-artifact-name))
(def class-dir "target/classes")
(def basis (b/create-basis {:project "deps.edn"}))
(def jar-file (format "target/%s.jar" (name lib)))
(defn jar
"Build library jar file.
Supports `:version-override` for local testing, otherwise official version is used.
For example, when testing 3rd party libs against rewrite-clj HEAD we use the suffix: canary."
[{:keys [version-override] :as opts}]
(b/delete {:path class-dir})
(b/delete {:path jar-file})
(let [version (or version-override version)]
(println "jarring version" version)
(b/write-pom {:class-dir class-dir
:lib lib
:version version
:basis basis
:src-dirs ["src"]
:scm {:url "https://github.com/clj-commons/rewrite-clj"
:connection "scm:git:[email protected]:clj-commons/rewrite-clj.git"
:developerConnection "scm:git:[email protected]:clj-commons/rewrite-clj.git"
:tag (format "v%s" version)}
:pom-data [[:description "Rewrite Clojure code and edn"]
[:url "https://github.com/clj-commons/rewrite-clj"]
[:licenses
[:license
[:name "The MIT License"]
[:url "http://opensource.org/licenses/MIT"]]]
[:properties
[:project.build.sourceEncoding "UTF-8"]]]})
(b/copy-dir {:src-dirs ["src" "resources"]
:target-dir class-dir})
(b/jar {:class-dir class-dir
:jar-file jar-file})
(assoc opts :built-version version)))
(defn install
"Install built jar to local maven repo, optionally specify `:version-override` for local testing."
[opts]
(let [{:keys [built-version]} (jar opts)]
(println "installing version" built-version)
(b/install {:class-dir class-dir
:lib lib
:version built-version
:basis basis
:jar-file jar-file})))
(defn deploy [_]
(jar {})
(println "deploy")
((requiring-resolve 'deps-deploy.deps-deploy/deploy)
{:installer :remote
:artifact jar-file
:pom-file (b/pom-path {:lib lib :class-dir class-dir})}))
(defn download-deps
"Download all deps for all aliases"
[_]
(let [aliases (->> "deps.edn"
slurp
edn/read-string
:aliases
keys)]
;; one at a time because aliases with :replace-deps will... well... you know.
(println "Bring down default deps")
(b/create-basis {})
(doseq [a (sort aliases)]
(println "Bring down deps for alias" a)
(b/create-basis {:aliases [a]}))))