2021-05-31 09:06:14 +02:00
|
|
|
(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}))
|
2021-06-17 13:26:38 +02:00
|
|
|
|
2021-09-06 15:58:36 +02:00
|
|
|
(def registry (atom {}))
|
|
|
|
|
2023-07-25 11:20:52 +02:00
|
|
|
|
2021-06-17 13:26:38 +02:00
|
|
|
(defn potok-reify
|
2021-09-06 15:58:36 +02:00
|
|
|
[{:keys [:node :filename] :as params}]
|
2021-06-17 13:26:38 +02:00
|
|
|
(let [[rnode rtype & other] (:children node)
|
2021-09-06 15:58:36 +02:00
|
|
|
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))]
|
2023-12-22 16:22:27 +01:00
|
|
|
|
|
|
|
;; (prn (api/sexpr result))
|
|
|
|
|
2021-09-06 15:58:36 +02:00
|
|
|
{:node result})))
|
2021-06-18 10:23:03 +02:00
|
|
|
|
2023-07-20 10:49:46 +02:00
|
|
|
(defn penpot-with-atomic
|
|
|
|
[{:keys [node]}]
|
2023-09-01 11:37:47 +02:00
|
|
|
(let [[params & body] (rest (:children node))]
|
|
|
|
(if (api/vector-node? params)
|
|
|
|
(let [[sym val opts] (:children params)]
|
|
|
|
(when-not (and sym val)
|
|
|
|
(throw (ex-info "No sym and val provided" {})))
|
|
|
|
{:node (api/list-node
|
|
|
|
(list*
|
|
|
|
(api/token-node 'let)
|
|
|
|
(api/vector-node [sym val])
|
|
|
|
opts
|
|
|
|
body))})
|
2023-07-20 10:49:46 +02:00
|
|
|
|
2023-09-01 11:37:47 +02:00
|
|
|
{:node (api/list-node
|
|
|
|
(into [(api/token-node 'let)
|
|
|
|
(api/vector-node [params params])]
|
|
|
|
body))})))
|
2023-06-20 11:11:55 +02:00
|
|
|
|
2023-09-06 14:43:05 +02:00
|
|
|
(defn rumext-fnc
|
|
|
|
[{:keys [node]}]
|
|
|
|
(let [[cname mdata params & body] (rest (:children node))
|
|
|
|
[params body] (if (api/vector-node? mdata)
|
|
|
|
[mdata (cons params body)]
|
|
|
|
[params body])]
|
|
|
|
(let [result (api/list-node
|
|
|
|
(into [(api/token-node 'fn)
|
|
|
|
params]
|
|
|
|
(cons mdata body)))]
|
|
|
|
{:node result})))
|
|
|
|
|
|
|
|
|
2023-12-22 16:22:27 +01:00
|
|
|
(defn rumext-lazycomponent
|
|
|
|
[{:keys [node]}]
|
|
|
|
(let [[cname mdata params & body] (rest (:children node))
|
|
|
|
[params body] (if (api/vector-node? mdata)
|
|
|
|
[mdata (cons params body)]
|
|
|
|
[params body])]
|
|
|
|
(let [result (api/list-node [(api/token-node 'constantly) nil])]
|
|
|
|
;; (prn (api/sexpr result))
|
|
|
|
{:node result})))
|
|
|
|
|
|
|
|
|
2023-06-20 11:11:55 +02:00
|
|
|
(defn penpot-defrecord
|
|
|
|
[{:keys [:node]}]
|
|
|
|
(let [[rnode rtype rparams & other] (:children node)
|
|
|
|
|
|
|
|
nodes [(api/token-node (symbol "do"))
|
|
|
|
(api/list-node
|
|
|
|
(into [(api/token-node (symbol (name (:value rnode)))) rtype rparams] other))
|
|
|
|
(api/list-node
|
|
|
|
[(api/token-node (symbol "defn"))
|
|
|
|
(api/token-node (symbol (str "pos->" (:string-value rtype))))
|
|
|
|
(api/vector-node
|
|
|
|
(->> (:children rparams)
|
|
|
|
(mapv (fn [t]
|
|
|
|
(api/token-node (symbol (str "_" (:string-value t))))))))
|
|
|
|
(api/token-node nil)])]
|
|
|
|
|
|
|
|
result (api/list-node nodes)]
|
|
|
|
|
|
|
|
;; (prn "=====>" (into {} rparams))
|
|
|
|
;; (prn (api/sexpr result))
|
|
|
|
{:node result}))
|
|
|
|
|
2021-06-18 10:23:03 +02:00
|
|
|
(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}))
|
2021-06-18 10:53:03 +02:00
|
|
|
|
|
|
|
(defn service-defmethod
|
|
|
|
[{:keys [:node]}]
|
2021-11-18 16:43:52 +01:00
|
|
|
(let [[rnode rtype ?meta & other] (:children node)
|
2021-06-18 10:53:03 +02:00
|
|
|
rsym (gensym (name (:k rtype)))
|
2022-07-13 14:29:47 +02:00
|
|
|
|
|
|
|
[?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)
|
2021-11-18 16:43:52 +01:00
|
|
|
;; (prn (api/sexpr result))
|
2021-06-18 10:53:03 +02:00
|
|
|
{:node result}))
|