2021-05-31 02:06:14 -05: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 06:26:38 -05:00
|
|
|
|
2021-09-06 08:58:36 -05:00
|
|
|
(def registry (atom {}))
|
|
|
|
|
2021-06-17 06:26:38 -05:00
|
|
|
(defn potok-reify
|
2021-09-06 08:58:36 -05:00
|
|
|
[{:keys [:node :filename] :as params}]
|
2021-06-17 06:26:38 -05:00
|
|
|
(let [[rnode rtype & other] (:children node)
|
2021-09-06 08:58:36 -05: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))]
|
|
|
|
{:node result})))
|
2021-06-18 03:23:03 -05: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 03:53:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
(defn service-defmethod
|
|
|
|
[{:keys [:node]}]
|
|
|
|
(let [[rnode rtype & other] (:children node)
|
|
|
|
rsym (gensym (name (:k rtype)))
|
|
|
|
result (api/list-node
|
|
|
|
[(api/token-node (symbol "do"))
|
|
|
|
(api/list-node
|
|
|
|
[(api/token-node (symbol "declare"))
|
|
|
|
(api/token-node rsym)])
|
|
|
|
(api/list-node
|
|
|
|
(into [(api/token-node (symbol "defmethod"))
|
|
|
|
(api/token-node rsym)
|
|
|
|
rtype]
|
|
|
|
other))])]
|
|
|
|
{:node result}))
|
|
|
|
|
|
|
|
|