forked from BetterThanTomorrow/joyride
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathport_arrow_form.cljs
31 lines (25 loc) · 971 Bytes
/
port_arrow_form.cljs
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
(ns port-arrow-form
(:require ["vscode" :as vscode]
[joyride.core :as joyride]
[promesa.core :as p]
[rewrite-clj.zip :as z]
[util.editor :as e]))
;; A small helper for porting midje to clojure.test, which demos
;; several useful techniques for manipulating Clojure code.
;; This code relies on the active selection
(defn log [x]
(.appendLine (joyride.core/output-channel) (str x)))
(defn get-arrow-clause
"Make a pseudo-form since we're just using this for parsing."
[text]
(let [zloc (z/down (z/of-string (str "[ " text " ]")))
lhs (z/sexpr zloc)
arrow (-> zloc z/right z/string)
rhs (-> zloc z/right z/right z/sexpr)]
[lhs arrow rhs]))
(defn main []
(log "port-arrow-form started")
(-> (p/let [[lhs _ rhs] (get-arrow-clause (e/current-selection-text))]
(e/replace-range! (str `(~'is (~'= ~rhs ~lhs)))))))
(when (= (joyride/invoked-script) joyride/*file*)
(main))