From ee3b619f7f4d401782cf841467d008c50b181f44 Mon Sep 17 00:00:00 2001 From: p4v4n Date: Fri, 1 Mar 2024 09:34:09 +0530 Subject: [PATCH 1/9] Check for tree-sitter before activating clojure-ts-mode --- clojure-ts-mode.el | 45 ++++++++++++++++++++++++--------------------- 1 file changed, 24 insertions(+), 21 deletions(-) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 753e97b..716c09a 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -993,27 +993,30 @@ See `clojure-ts--font-lock-settings' for usage of MARKDOWN-AVAILABLE." (add-to-list 'auto-mode-alist '("\\.cljd\\'" . clojure-ts-clojuredart-mode)) (add-to-list 'auto-mode-alist '("\\.jank\\'" . clojure-ts-jank-mode))) -;; Redirect clojure-mode to clojure-ts-mode if clojure-mode is present -(if (require 'clojure-mode nil 'noerror) - (progn - (add-to-list 'major-mode-remap-alist '(clojure-mode . clojure-ts-mode)) - (add-to-list 'major-mode-remap-alist '(clojurescript-mode . clojure-ts-clojurescript-mode)) - (add-to-list 'major-mode-remap-alist '(clojurec-mode . clojure-ts-clojurec-mode)) - (clojure-ts--register-novel-modes)) - ;; Clojure-mode is not present, setup auto-modes ourselves - ;; Regular clojure/edn files - ;; I believe dtm is for datomic queries and datoms, which are just edn. - (add-to-list 'auto-mode-alist - '("\\.\\(clj\\|dtm\\|edn\\)\\'" . clojure-ts-mode)) - (add-to-list 'auto-mode-alist '("\\.cljs\\'" . clojure-ts-clojurescript-mode)) - (add-to-list 'auto-mode-alist '("\\.cljc\\'" . clojure-ts-clojurec-mode)) - ;; boot build scripts are Clojure source files - (add-to-list 'auto-mode-alist '("\\(?:build\\|profile\\)\\.boot\\'" . clojure-ts-mode)) - ;; babashka scripts are Clojure source files - (add-to-list 'interpreter-mode-alist '("bb" . clojure-ts-mode)) - ;; nbb scripts are ClojureScript source files - (add-to-list 'interpreter-mode-alist '("nbb" . clojure-ts-clojurescript-mode)) - (clojure-ts--register-novel-modes)) +(if (treesit-available-p) + ;; Redirect clojure-mode to clojure-ts-mode if clojure-mode is present + (if (require 'clojure-mode nil 'noerror) + (progn + (add-to-list 'major-mode-remap-alist '(clojure-mode . clojure-ts-mode)) + (add-to-list 'major-mode-remap-alist '(clojurescript-mode . clojure-ts-clojurescript-mode)) + (add-to-list 'major-mode-remap-alist '(clojurec-mode . clojure-ts-clojurec-mode)) + (clojure-ts--register-novel-modes)) + ;; When Clojure-mode is not present, setup auto-modes ourselves + (progn + ;; Regular clojure/edn files + ;; I believe dtm is for datomic queries and datoms, which are just edn. + (add-to-list 'auto-mode-alist + '("\\.\\(clj\\|dtm\\|edn\\)\\'" . clojure-ts-mode)) + (add-to-list 'auto-mode-alist '("\\.cljs\\'" . clojure-ts-clojurescript-mode)) + (add-to-list 'auto-mode-alist '("\\.cljc\\'" . clojure-ts-clojurec-mode)) + ;; boot build scripts are Clojure source files + (add-to-list 'auto-mode-alist '("\\(?:build\\|profile\\)\\.boot\\'" . clojure-ts-mode)) + ;; babashka scripts are Clojure source files + (add-to-list 'interpreter-mode-alist '("bb" . clojure-ts-mode)) + ;; nbb scripts are ClojureScript source files + (add-to-list 'interpreter-mode-alist '("nbb" . clojure-ts-clojurescript-mode)) + (clojure-ts--register-novel-modes))) + (message "Clojure TS Mode is not activated as tree-sitter support is missing.")) (defvar clojure-ts--find-ns-query (treesit-query-compile From 649bf1120f10250d464d4e9ad1905b481d2e504c Mon Sep 17 00:00:00 2001 From: Bozhidar Batsov Date: Tue, 4 Jun 2024 10:46:09 +0300 Subject: [PATCH 2/9] Improve the package version reporting --- clojure-ts-mode.el | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 99f28cd..d2be3e7 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -54,7 +54,6 @@ ;;; Code: (require 'treesit) -(require 'lisp-mnt) (declare-function treesit-parser-create "treesit.c") (declare-function treesit-node-eq "treesit.c") @@ -71,8 +70,7 @@ :link '(emacs-commentary-link :tag "Commentary" "clojure-mode")) (defconst clojure-ts-mode-version - (eval-when-compile - (lm-version (or load-file-name buffer-file-name))) + "0.2.2" "The current version of `clojure-ts-mode'.") (defcustom clojure-ts-comment-macro-font-lock-body nil @@ -884,7 +882,10 @@ forms like deftype, defrecord, reify, proxy, etc." (defun clojure-ts-mode-display-version () "Display the current `clojure-mode-version' in the minibuffer." (interactive) - (message "clojure-ts-mode (version %s)" clojure-ts-mode-version)) + (let ((pkg-version (package-get-version))) + (if pkg-version + (message "clojure-ts-mode %s (package: %s)" clojure-ts-mode-version pkg-version) + (message "clojure-ts-mode %s" clojure-ts-mode-version)))) (defconst clojure-ts-grammar-recipes '((clojure "https://github.com/sogaiu/tree-sitter-clojure.git" From 3c0f8be0daf2701e70a2712cd7d5548988121a0a Mon Sep 17 00:00:00 2001 From: Danny Freeman Date: Mon, 17 Jun 2024 22:58:41 -0400 Subject: [PATCH 3/9] Update warning when tree-sitter is not supported --- clojure-ts-mode.el | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 716c09a..d4b6acb 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -1016,7 +1016,7 @@ See `clojure-ts--font-lock-settings' for usage of MARKDOWN-AVAILABLE." ;; nbb scripts are ClojureScript source files (add-to-list 'interpreter-mode-alist '("nbb" . clojure-ts-clojurescript-mode)) (clojure-ts--register-novel-modes))) - (message "Clojure TS Mode is not activated as tree-sitter support is missing.")) + (message "Clojure TS Mode will not be activated as tree-sitter support is missing.")) (defvar clojure-ts--find-ns-query (treesit-query-compile From 19df2d536d56dfc799aec1e534472e3fe10fec29 Mon Sep 17 00:00:00 2001 From: Danny Freeman Date: Mon, 1 Jul 2024 08:21:28 -0400 Subject: [PATCH 4/9] Do not require test-helper.el ert-runner will load this file when it is directly under the project test/ directory. I've moved some of the test clojure files under test/samples to help keep test directory clean and a little more focused Fixes #44 --- test/clojure-ts-mode-util-test.el | 1 - test/samples/bug43.clj | 7 +++++++ test/{ => samples}/docstrings.clj | 0 test/{ => samples}/indentation.clj | 0 test/{ => samples}/native.jank | 0 test/{ => samples}/test.clj | 0 test/{utils => }/test-helper.el | 1 - 7 files changed, 7 insertions(+), 2 deletions(-) create mode 100644 test/samples/bug43.clj rename test/{ => samples}/docstrings.clj (100%) rename test/{ => samples}/indentation.clj (100%) rename test/{ => samples}/native.jank (100%) rename test/{ => samples}/test.clj (100%) rename test/{utils => }/test-helper.el (98%) diff --git a/test/clojure-ts-mode-util-test.el b/test/clojure-ts-mode-util-test.el index b4c2e13..5581a2c 100644 --- a/test/clojure-ts-mode-util-test.el +++ b/test/clojure-ts-mode-util-test.el @@ -23,7 +23,6 @@ (require 'clojure-ts-mode) (require 'buttercup) -(require 'test-helper "test/utils/test-helper") (describe "clojure-ts-mode-version" (it "should not be nil" diff --git a/test/samples/bug43.clj b/test/samples/bug43.clj new file mode 100644 index 0000000..85cfda1 --- /dev/null +++ b/test/samples/bug43.clj @@ -0,0 +1,7 @@ +^{:a 1} + (def b 2) + +^{:a 1} +(defn a + "hello" ;; <- + [] "world") diff --git a/test/docstrings.clj b/test/samples/docstrings.clj similarity index 100% rename from test/docstrings.clj rename to test/samples/docstrings.clj diff --git a/test/indentation.clj b/test/samples/indentation.clj similarity index 100% rename from test/indentation.clj rename to test/samples/indentation.clj diff --git a/test/native.jank b/test/samples/native.jank similarity index 100% rename from test/native.jank rename to test/samples/native.jank diff --git a/test/test.clj b/test/samples/test.clj similarity index 100% rename from test/test.clj rename to test/samples/test.clj diff --git a/test/utils/test-helper.el b/test/test-helper.el similarity index 98% rename from test/utils/test-helper.el rename to test/test-helper.el index b7ac0d4..38bce56 100644 --- a/test/utils/test-helper.el +++ b/test/test-helper.el @@ -46,5 +46,4 @@ and point left there." (delete-char -1) ,@body))) -(provide 'test-helper) ;;; test-helper.el ends here From d577270f458e26ab9719d34af213f471306e8d39 Mon Sep 17 00:00:00 2001 From: Daniel Compton Date: Thu, 25 Jul 2024 10:25:52 +1200 Subject: [PATCH 5/9] Update README.md to show CIDER and inf-clojure status --- README.md | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index bbe54cc..62d8414 100644 --- a/README.md +++ b/README.md @@ -214,9 +214,7 @@ After installing the package do the following. ### Does `clojure-ts-mode` work with CIDER? -~~Not yet out of the box, but that [should change soon](https://github.com/clojure-emacs/cider/pull/3461). Feel free to help out with the remaining work, so we can expedite the process.~~ - -Support for `clojure-ts-mode` has landed on the `master` branch of CIDER (and will be part of CIDER 1.14 when it's released). Make sure to grab the latest CIDER from MELPA/GitHub. +Yes! Preliminary support for `clojure-ts-mode` was released in [CIDER 1.14](https://github.com/clojure-emacs/cider/releases/tag/v1.14.0). Make sure to grab the latest CIDER from MELPA/GitHub. Note that `clojure-mode` is still needed for some APIs that haven't yet been ported to `clojure-ts-mode`. For now, when you take care of the keybindings for the CIDER commands you use and ensure `cider-mode` is enabled for `clojure-ts-mode` buffers in your config, most functionality should already work: @@ -228,7 +226,7 @@ Check out [this article](https://metaredux.com/posts/2024/02/19/cider-preliminar ### Does `clojure-ts-mode` work with `inf-clojure`? -[Ditto.](https://github.com/clojure-emacs/inf-clojure/pull/215) +Currently, there is an [open PR](https://github.com/clojure-emacs/inf-clojure/pull/215) adding support for inf-clojure. ## License From eb9aab37163395d92ce4f950c802de31b91ee3a3 Mon Sep 17 00:00:00 2001 From: Kolmas <169401425+Kolmas225@users.noreply.github.com> Date: Thu, 25 Jul 2024 12:57:13 +0800 Subject: [PATCH 6/9] Fix missing `comment-add` variable in `clojure-ts-mode-variables` (#46) Set `comment-add` to 1 in `clojure-ts-mode-variables`. This resolves #26. --- CHANGELOG.md | 1 + clojure-ts-mode.el | 1 + 2 files changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7af2ea8..cdf049d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,7 @@ ## main (unreleased) - [#38]: Add support for `in-ns` forms in `clojure-ts-find-ns`. +- [#46]: Fix missing `comment-add` variable in `clojure-ts-mode-variables` mentioned in [#26] ## 0.2.2 (2024-02-16) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 97abfbb..2390cf9 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -912,6 +912,7 @@ forms like deftype, defrecord, reify, proxy, etc." (defun clojure-ts-mode-variables (&optional markdown-available) "Initialize buffer-local variables for `clojure-ts-mode'. See `clojure-ts--font-lock-settings' for usage of MARKDOWN-AVAILABLE." + (setq-local comment-add 1) (setq-local comment-start ";") (setq-local treesit-font-lock-settings (clojure-ts--font-lock-settings markdown-available)) From 0e6816e76ea31c0f0e4d39d8f016c262e57dcb10 Mon Sep 17 00:00:00 2001 From: Roman Rudakov Date: Thu, 25 Jul 2024 13:33:09 +0200 Subject: [PATCH 7/9] Add imenu support for deftest --- CHANGELOG.md | 1 + clojure-ts-mode.el | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index cdf049d..65aa179 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ - [#38]: Add support for `in-ns` forms in `clojure-ts-find-ns`. - [#46]: Fix missing `comment-add` variable in `clojure-ts-mode-variables` mentioned in [#26] +- Add imenu support for `deftest` definitions. ## 0.2.2 (2024-02-16) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 2390cf9..60fbcb7 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -578,7 +578,7 @@ Can be called directly, but intended for use as `treesit-defun-name-function'." (treesit-node-text name))))))) (defvar clojure-ts--function-type-regexp - (rx string-start (or (seq "defn" (opt "-")) "defmethod") string-end) + (rx string-start (or (seq "defn" (opt "-")) "defmethod" "deftest") string-end) "Regular expression for matching definition nodes that resemble functions.") (defun clojure-ts--function-node-p (node) From fd7e5dab9efe08c0e2bdf7ca6ada2a063915f2ec Mon Sep 17 00:00:00 2001 From: Daanturo Date: Sun, 29 Sep 2024 17:38:37 +0700 Subject: [PATCH 8/9] Let clojure-ts-mode derive from clojure-mode for Emacs 30+ Emacs 30 defines the function `derived-mode-add-parents` that is used for the built-in *-ts-mode, this will make (provided-mode-derived-p 'clojure-ts-mode 'clojure-mode) return true just like other treesit major modes. --- CHANGELOG.md | 1 + clojure-ts-mode.el | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 65aa179..c669d0e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ - [#38]: Add support for `in-ns` forms in `clojure-ts-find-ns`. - [#46]: Fix missing `comment-add` variable in `clojure-ts-mode-variables` mentioned in [#26] - Add imenu support for `deftest` definitions. +- [#53]: Let `clojure-ts-mode` derive from `clojure-mode` for Emacs 30+. ## 0.2.2 (2024-02-16) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 60fbcb7..4fe25e9 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -966,6 +966,11 @@ See `clojure-ts--font-lock-settings' for usage of MARKDOWN-AVAILABLE." (when (fboundp 'transpose-sexps-default-function) (setq-local transpose-sexps-function #'transpose-sexps-default-function))))) +;; For Emacs 30+, so that `clojure-ts-mode' is treated as deriving from +;; `clojure-mode' +(when (fboundp #'derived-mode-add-parents) + (derived-mode-add-parents 'clojure-ts-mode '(clojure-mode))) + ;;;###autoload (define-derived-mode clojure-ts-clojurescript-mode clojure-ts-mode "ClojureScript[TS]" "Major mode for editing ClojureScript code. From dc74c4546f3bd9e026eef5b0519e8b5aff9781cc Mon Sep 17 00:00:00 2001 From: Bozhidar Batsov Date: Mon, 30 Sep 2024 15:16:00 +0200 Subject: [PATCH 9/9] Fix a lint warning --- clojure-ts-mode.el | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clojure-ts-mode.el b/clojure-ts-mode.el index 4fe25e9..8a68839 100644 --- a/clojure-ts-mode.el +++ b/clojure-ts-mode.el @@ -968,7 +968,7 @@ See `clojure-ts--font-lock-settings' for usage of MARKDOWN-AVAILABLE." ;; For Emacs 30+, so that `clojure-ts-mode' is treated as deriving from ;; `clojure-mode' -(when (fboundp #'derived-mode-add-parents) +(when (fboundp 'derived-mode-add-parents) (derived-mode-add-parents 'clojure-ts-mode '(clojure-mode))) ;;;###autoload