]> git.eshelyaron.com Git - emacs.git/commitdiff
Eliminate redundant variable treesit-admin--builtin-language-sources
authorPeter Oliver <git@mavit.org.uk>
Wed, 11 Jun 2025 00:41:08 +0000 (01:41 +0100)
committerEshel Yaron <me@eshelyaron.com>
Sun, 22 Jun 2025 08:08:27 +0000 (10:08 +0200)
Nowadays, each mode populates treesit-language-source-alist when the
mode is required; we do not need to duplicate the information.

* admin/tree-sitter/treesit-admin.el
(treesit-admin--builtin-language-sources)
(treesit-admin-verify-major-mode-queries)
(treesit-admin--generate-compatibility-report): Eliminate variable
treesit-admin--builtin-language-sources.
(treesit-admin--generate-compatibility-report): bash-ts-mode is “clever”
and switches back to sh-mode if it thinks the current buffer does not
contain a Bash script (bug#78747).
(treesit-admin--builtin-modes): Add missing modes.
(treesit-admin--builtin-features): New variable, telling us which
features to require to populate treesit-language-source-alist.
(treesit-admin--populated-treesit-language-source-alist): New function,
to add everything we know to treesit-language-source-alist.
(treesit-admin--unversioned-treesit-language-source-alist): Return a
copy of treesit-language-source-alist with the version requirements
removed.
* test/infra/Dockerfile.emba: Make use of
treesit-admin--populated-treesit-language-source-alist (bug#78748).

(cherry picked from commit 6181e0cec5158c5b66bf861c32e49674b2a110e9)

admin/tree-sitter/treesit-admin.el
test/infra/Dockerfile.emba

index f41c45920390b06f105101b40252bfc21038f152..1bb8b927e5c47203c50a4ccabdc3fc084126c5fe 100644 (file)
 
 ;;; Query validation
 
-(defvar treesit-admin--builtin-language-sources
-  '((c "https://github.com/tree-sitter/tree-sitter-c" "v0.23.4")
-    (cpp "https://github.com/tree-sitter/tree-sitter-cpp" "v0.23.4")
-    (cmake "https://github.com/uyha/tree-sitter-cmake" "v0.5.0")
-    (dockerfile "https://github.com/camdencheek/tree-sitter-dockerfile" "v0.2.0")
-    (go "https://github.com/tree-sitter/tree-sitter-go" "v0.23.4")
-    (ruby "https://github.com/tree-sitter/tree-sitter-ruby" "v0.23.1")
-    (javascript "https://github.com/tree-sitter/tree-sitter-javascript" "v0.23.1")
-    (typescript "https://github.com/tree-sitter/tree-sitter-typescript"
-                "v0.23.2" "typescript/src")
-    (tsx "https://github.com/tree-sitter/tree-sitter-typescript"
-         "v0.23.2" "tsx/src")
-    (json "https://github.com/tree-sitter/tree-sitter-json" "v0.24.8")
-    (rust "https://github.com/tree-sitter/tree-sitter-rust" "v0.23.2")
-    (php "https://github.com/tree-sitter/tree-sitter-php"
-         "v0.23.11" "php/src")
-    (css "https://github.com/tree-sitter/tree-sitter-css" "v0.23.1")
-    (phpdoc "https://github.com/claytonrcarter/tree-sitter-phpdoc")
-    (doxygen "https://github.com/tree-sitter-grammars/tree-sitter-doxygen" "v1.1.0")
-    (lua "https://github.com/tree-sitter-grammars/tree-sitter-lua" "v0.3.0")
-    (python "https://github.com/tree-sitter/tree-sitter-python" "v0.23.6")
-    (html "https://github.com/tree-sitter/tree-sitter-html" "v0.23.2")
-    (elixir "https://github.com/elixir-lang/tree-sitter-elixir" "v0.3.3")
-    (heex "https://github.com/phoenixframework/tree-sitter-heex" "v0.7.0")
-    (java "https://github.com/tree-sitter/tree-sitter-java" "v0.23.5")
-    (jsdoc "https://github.com/tree-sitter/tree-sitter-jsdoc" "v0.23.2")
-    (toml "https://github.com/tree-sitter-grammars/tree-sitter-toml" "v0.7.0")
-    (yaml "https://github.com/tree-sitter-grammars/tree-sitter-yaml" "v0.7.0"))
-  "A list of sources for the builtin modes.
-The source information are in the format of
-`treesit-language-source-alist'.  This is for development only.")
-
 (defvar treesit-admin--builtin-modes
-  '( c-ts-mode c++-ts-mode cmake-ts-mode dockerfile-ts-mode
-     go-ts-mode ruby-ts-mode js-ts-mode typescript-ts-mode tsx-ts-mode
-     json-ts-mode rust-ts-mode php-ts-mode css-ts-mode lua-ts-mode
-     html-ts-mode elixir-ts-mode heex-ts-mode java-ts-mode)
+  '(bash-ts-mode
+    c++-ts-mode
+    c-ts-mode
+    cmake-ts-mode
+    csharp-ts-mode
+    css-ts-mode
+    dockerfile-ts-mode
+    elixir-ts-mode
+    go-ts-mode
+    heex-ts-mode
+    html-ts-mode
+    java-ts-mode
+    js-ts-mode
+    json-ts-mode
+    lua-ts-mode
+    markdown-ts-mode
+    php-ts-mode
+    python-ts-mode
+    ruby-ts-mode
+    rust-ts-mode
+    toml-ts-mode
+    tsx-ts-mode
+    typescript-ts-mode)
   "Builtin tree-sitter modes that we check.")
 
+(defvar treesit-admin--builtin-features
+  '(c-ts-mode
+    cmake-ts-mode
+    csharp-mode
+    css-mode
+    dockerfile-ts-mode
+    elixir-ts-mode
+    go-ts-mode
+    heex-ts-mode
+    html-ts-mode
+    java-ts-mode
+    js
+    json-ts-mode
+    lua-ts-mode
+    markdown-ts-mode
+    php-ts-mode
+    python
+    ruby-ts-mode
+    rust-ts-mode
+    sh-script
+    toml-ts-mode
+    treesit-x
+    typescript-ts-mode
+    yaml-ts-mode)
+  "Built in features that modify treesit-language-source-alist when loaded.")
+
+(defun treesit-admin--populated-treesit-language-source-alist ()
+  "Ensure that treesit-language-source-alist is fully populated.
+This is done by `require'ing all of the features that extend it."
+  (dolist (feature treesit-admin--builtin-features)
+    (require feature))
+  treesit-language-source-alist)
+
+(defun treesit-admin--unversioned-treesit-language-source-alist ()
+  "Return a copy of treesit-language-source-alist, with any revisions removed."
+  (mapcar
+   (lambda (source)
+     (if (nthcdr 2 source)
+         (let ((unversioned-source (copy-sequence source)))
+           (setcar (nthcdr 2 unversioned-source) nil)
+           unversioned-source)
+       source))
+   (treesit-admin--populated-treesit-language-source-alist)))
+
 (defun treesit-admin--verify-major-mode-queries (modes source-alist grammar-dir)
   "Verify font-lock queries in MODES.
 
@@ -228,7 +259,7 @@ queries that has problems with latest grammar."
   (interactive)
   (treesit-admin--verify-major-mode-queries
    treesit-admin--builtin-modes
-   treesit-admin--builtin-language-sources
+   (treesit-admin--populated-treesit-language-source-alist)
    "/tmp/tree-sitter-grammars"))
 
 ;;; Compatibility report
@@ -268,6 +299,8 @@ Return non-nil if all queries are valid, nil otherwise."
   (let ((settings
          (with-temp-buffer
            (ignore-errors
+             (when (eq mode 'bash-ts-mode)
+               (insert "#!/bin/bash"))
              ;; TODO: A more generic way to find all queries.
              (let ((c-ts-mode-enable-doxygen t)
                    (c-ts-mode-enable-doxygen t)
@@ -387,7 +420,7 @@ EMACS-EXECUTABLES is a list of Emacs executables to check for."
                     (buffer-string))
                   (treesit-admin--last-compatible-grammar-for-modes
                    modes
-                   treesit-admin--builtin-language-sources
+                   (treesit-admin--unversioned-treesit-language-source-alist)
                    "/tmp/treesit-grammar"
                    emacs)))
           emacs-executables))
index 6be67a95e7539ce6360e294e0e7198da4ea9401f..62350e6aff9adbef226d65850a92a1c8a9035429 100644 (file)
@@ -138,12 +138,9 @@ RUN src/emacs -Q --batch \
         (treesit-library-abi-version t) (treesit-library-abi-version))' \
     --eval '(message "\nInstalling grammars\n===================")' \
     --eval '(setq treesit-extra-load-path (list "/root/.emacs.d/tree-sitter"))' \
-    --eval '(dolist (feature (quote (c-ts-mode cmake-ts-mode csharp-mode \
-        dockerfile-ts-mode elixir-ts-mode heex-ts-mode go-ts-mode java-ts-mode \
-        js json-ts-mode lua-ts-mode php-ts-mode python ruby-ts-mode rust-ts-mode \
-        sh-script typescript-ts-mode css-mode html-ts-mode markdown-ts-mode \
-        toml-ts-mode yaml-ts-mode treesit-x))) (require feature))' \
-    --eval '(dolist (lang (mapcar (quote car) treesit-language-source-alist)) \
+    -l admin/tree-sitter/treesit-admin.el \
+    --eval '(dolist (lang (mapcar (quote car) \
+                                  (treesit-admin--populated-treesit-language-source-alist))) \
         (treesit-install-language-grammar lang "/root/.emacs.d/tree-sitter"))' \
     --eval '(message "\ntreesit-language-source-alist")' \
     --eval '(message "=============================")' \
@@ -152,9 +149,6 @@ RUN src/emacs -Q --batch \
     --eval \
         '(dolist (lang (sort (mapcar (quote car) treesit-language-source-alist))) \
          (message "%s ABI version %d" lang (treesit-language-abi-version lang)))' \
-    -l admin/tree-sitter/treesit-admin.el \
-    --eval '(setq treesit-admin--builtin-language-sources \
-        treesit-language-source-alist)' \
     --eval '(message "\ntreesit-admin-check-manual-coverage")' \
     --eval '(message "===================================")' \
     -f treesit-admin-check-manual-coverage \