From c956302b4ff21fd0dbc4b06cfddb1aa39df4758c Mon Sep 17 00:00:00 2001 From: Dieter Komendera Date: Tue, 15 Oct 2024 21:14:29 +0200 Subject: [PATCH] Better solution for indentation of forms with meta, add tests --- clojure-ts-mode.el | 13 ++++++------- test/indentation.clj | 18 ++++++++++++++++++ 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 0760f7c..2e37916 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -810,12 +810,11 @@ forms like deftype, defrecord, reify, proxy, etc." (clojure-ts--match-fn-docstring parent) (clojure-ts--match-method-docstring parent)))) -(defun clojure-ts--match-toplevel-with-meta (_node parent _bol) - "Match NODE when it is toplevel form and it has metadata" - (let* ((grandparent (treesit-node-parent parent))) - (and (string-equal "source" (treesit-node-type grandparent)) - (clojure-ts--list-node-p parent) - (treesit-node-child-by-field-name parent "meta")))) +(defun clojure-ts--match-with-meta (node _parent _bol) + "Match NODE when it has metadata" + (let ((prev-sibling (treesit-node-prev-sibling node))) + (and prev-sibling + (string-equal (treesit-node-type prev-sibling) "meta_lit")))) (defun clojure-ts--semantic-indent-rules () "Return a list of indentation rules for `treesit-simple-indent-rules'." @@ -829,7 +828,7 @@ forms like deftype, defrecord, reify, proxy, etc." (clojure-ts--match-threading-macro-arg prev-sibling 0) ;; https://guide.clojure.style/#vertically-align-fn-args (clojure-ts--match-function-call-arg (nth-sibling 2 nil) 0) - (clojure-ts--match-toplevel-with-meta parent 0) + (clojure-ts--match-with-meta parent 0) ;; Literal Sequences ((parent-is "list_lit") parent 1) ;; https://guide.clojure.style/#one-space-indent ((parent-is "vec_lit") parent 1) ;; https://guide.clojure.style/#bindings-alignment diff --git a/test/indentation.clj b/test/indentation.clj index a5fe041..2d96431 100644 --- a/test/indentation.clj +++ b/test/indentation.clj @@ -118,3 +118,21 @@ ([a] a) ([a b] b))}) + +^:foo +(def a 1) + +^{:foo true} +(def b 2) + +^{:foo true} +[1 2] + +(comment + ^{:a 1} + (def a 2)) + +(defn hinted + (^String []) + (^java.util.List + [a & args]))