mirror of
https://github.com/penpot/penpot.git
synced 2025-01-10 08:50:57 -05:00
89 lines
3.1 KiB
Clojure
89 lines
3.1 KiB
Clojure
(ns hooks.export
|
|
(:require [clj-kondo.hooks-api :as api]))
|
|
|
|
(defn export
|
|
[{:keys [:node]}]
|
|
(let [[_ sname] (:children node)
|
|
result (api/list-node
|
|
[(api/token-node (symbol "def"))
|
|
(api/token-node (symbol (name (:value sname))))
|
|
sname])]
|
|
{:node result}))
|
|
|
|
(def registry (atom {}))
|
|
|
|
(defn potok-reify
|
|
[{:keys [:node :filename] :as params}]
|
|
(let [[rnode rtype & other] (:children node)
|
|
rsym (symbol (str "event-type-" (name (:k rtype))))
|
|
reg (get @registry filename #{})]
|
|
(when-not (:namespaced? rtype)
|
|
(let [{:keys [:row :col]} (meta rtype)]
|
|
(api/reg-finding! {:message "ptk/reify type should be namespaced"
|
|
:type :potok/reify-type
|
|
:row row
|
|
:col col})))
|
|
|
|
(if (contains? reg rsym)
|
|
(let [{:keys [:row :col]} (meta rtype)]
|
|
(api/reg-finding! {:message (str "duplicate type: " (name (:k rtype)))
|
|
:type :potok/reify-type
|
|
:row row
|
|
:col col}))
|
|
(swap! registry update filename (fnil conj #{}) rsym))
|
|
|
|
(let [result (api/list-node
|
|
(into [(api/token-node (symbol "deftype"))
|
|
(api/token-node rsym)
|
|
(api/vector-node [])]
|
|
other))]
|
|
{:node result})))
|
|
|
|
(defn clojure-specify
|
|
[{:keys [:node]}]
|
|
(let [[rnode rtype & other] (:children node)
|
|
result (api/list-node
|
|
(into [(api/token-node (symbol "extend-type"))
|
|
(api/token-node (gensym (:string-value rtype)))]
|
|
other))]
|
|
{:node result}))
|
|
|
|
|
|
(defn service-defmethod
|
|
[{:keys [:node]}]
|
|
(let [[rnode rtype ?meta & other] (:children node)
|
|
rsym (gensym (name (:k rtype)))
|
|
|
|
[?docs other] (if (api/string-node? ?meta)
|
|
[?meta other]
|
|
[nil (cons ?meta other)])
|
|
|
|
[?meta other] (let [?meta (first other)]
|
|
(if (api/map-node? ?meta)
|
|
[?meta (rest other)]
|
|
[nil other]))
|
|
|
|
nodes [(api/token-node (symbol "do"))
|
|
(api/list-node
|
|
[(api/token-node (symbol "declare"))
|
|
(api/token-node rsym)])
|
|
|
|
(when ?docs
|
|
(api/list-node
|
|
[(api/token-node (symbol "comment")) ?docs]))
|
|
|
|
(when ?meta
|
|
(api/list-node
|
|
[(api/token-node (symbol "reset-meta!"))
|
|
(api/token-node rsym)
|
|
?meta]))
|
|
(api/list-node
|
|
(into [(api/token-node (symbol "defmethod"))
|
|
(api/token-node rsym)
|
|
rtype]
|
|
other))]
|
|
result (api/list-node (filterv some? nodes))]
|
|
|
|
;; (prn "=====>" rtype)
|
|
;; (prn (api/sexpr result))
|
|
{:node result}))
|