forked from clj-commons/etaoin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.clj
76 lines (67 loc) · 2.72 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
(ns build
(:require [clojure.edn :as edn]
[clojure.java.io :as io]
[clojure.tools.build.api :as b]
[deps-deploy.deps-deploy :as dd]))
(defn version-string []
(let [{:keys [major minor release qualifier]} (-> "version.edn"
slurp
edn/read-string)]
(format "%s.%s.%s%s"
major minor release (if qualifier
(str "-" qualifier)
""))))
(def lib 'etaoin/etaoin)
(def version (version-string)) ;; the expectations is some pre-processing has bumped the version when releasing
(def class-dir "target/classes")
(def basis (b/create-basis {:project "deps.edn"}))
(def jar-file (format "target/%s.jar" (name lib)))
(def built-jar-version-file "target/built-jar-version.txt")
(defn clean [_]
(b/delete {:path "target"}))
(defn jar
"Build library jar file.
Also writes built version to target/built-jar-version.txt for easy peasy pickup by any interested downstream operation.
We use the optional :version-suffix to optionally distinguish local installs from productin releases.
For example, when installing for a cljdoc preview suffix is: cljdoc-preview."
[{:keys [version-suffix] :as opts}]
(let [version (if version-suffix
(format "%s-%s" version version-suffix)
version)]
(b/write-pom {:class-dir class-dir
:lib lib
:version version
:scm {:tag (format "v%s" version)}
:basis basis
:src-dirs ["src"]})
(b/copy-dir {:src-dirs ["src" "resources"]
:target-dir class-dir})
(b/jar {:class-dir class-dir
:jar-file jar-file})
(spit built-jar-version-file version)
(assoc opts :built-jar-version version)))
(defn- built-version* []
(when (not (.exists (io/file built-jar-version-file)))
(throw (ex-info (str "Built jar version file not found: " built-jar-version-file) {})))
(slurp built-jar-version-file))
(defn built-version
;; NOTE: Used by release script and github workflow
"Spit out version of jar built (with no trailing newline).
A separate task because I don't know what build.tools might spit to stdout."
[_]
(print (built-version*))
(flush))
(defn install [opts]
(clean opts)
(let [{:keys [built-jar-version]} (jar opts)]
(b/install {:class-dir class-dir
:lib lib
:version built-jar-version
:basis basis
:jar-file jar-file})))
(defn deploy [opts]
(dd/deploy
{:installer :remote
:artifact jar-file
:pom-file (b/pom-path {:lib lib :class-dir class-dir})})
opts)