mirror of
https://github.com/masscollaborationlabs/emacs.git
synced 2025-07-08 05:09:37 +00:00
Simplify imenu setup for {cmake,dockerfile}-ts-modes
* lisp/progmodes/cmake-ts-mode.el (treesit-induce-sparse-tree, treesit-node-child, treesit-node-start, cmake-ts-mode--imenu, cmake-ts-mode--imenu-1): Remove. (treesit-search-subtree): Declare. (cmake-ts-mode--function-name): New function. (cmake-ts-mode): Use it. * lisp/progmodes/dockerfile-ts-mode.el (treesit-induce-sparse-tree, treesit-node-start, dockerfile-ts-mode--imenu, dockerfile-ts-mode--imenu-1): Remove. (dockerfile-ts-mode--stage-name): New function. (dockerfile-ts-mode): Use it.
This commit is contained in:
parent
7338af9c98
commit
1ef8b90ae0
2 changed files with 22 additions and 71 deletions
|
@ -32,10 +32,8 @@
|
||||||
|
|
||||||
(declare-function treesit-parser-create "treesit.c")
|
(declare-function treesit-parser-create "treesit.c")
|
||||||
(declare-function treesit-query-capture "treesit.c")
|
(declare-function treesit-query-capture "treesit.c")
|
||||||
(declare-function treesit-induce-sparse-tree "treesit.c")
|
|
||||||
(declare-function treesit-node-child "treesit.c")
|
|
||||||
(declare-function treesit-node-start "treesit.c")
|
|
||||||
(declare-function treesit-node-type "treesit.c")
|
(declare-function treesit-node-type "treesit.c")
|
||||||
|
(declare-function treesit-search-subtree "treesit.c")
|
||||||
|
|
||||||
(defcustom cmake-ts-mode-indent-offset 2
|
(defcustom cmake-ts-mode-indent-offset 2
|
||||||
"Number of spaces for each indentation step in `cmake-ts-mode'."
|
"Number of spaces for each indentation step in `cmake-ts-mode'."
|
||||||
|
@ -195,37 +193,14 @@ Check if a node type is available, then return the right font lock rules."
|
||||||
'((ERROR) @font-lock-warning-face))
|
'((ERROR) @font-lock-warning-face))
|
||||||
"Tree-sitter font-lock settings for `cmake-ts-mode'.")
|
"Tree-sitter font-lock settings for `cmake-ts-mode'.")
|
||||||
|
|
||||||
(defun cmake-ts-mode--imenu ()
|
(defun cmake-ts-mode--function-name (node)
|
||||||
"Return Imenu alist for the current buffer."
|
"Return the function name of NODE.
|
||||||
(let* ((node (treesit-buffer-root-node))
|
Return nil if there is no name or if NODE is not a function node."
|
||||||
(func-tree (treesit-induce-sparse-tree
|
(pcase (treesit-node-type node)
|
||||||
node "function_def" nil 1000))
|
("function_command"
|
||||||
(func-index (cmake-ts-mode--imenu-1 func-tree)))
|
(treesit-node-text
|
||||||
(append
|
(treesit-search-subtree node "^argument$" nil nil 2)
|
||||||
(when func-index `(("Function" . ,func-index))))))
|
t))))
|
||||||
|
|
||||||
(defun cmake-ts-mode--imenu-1 (node)
|
|
||||||
"Helper for `cmake-ts-mode--imenu'.
|
|
||||||
Find string representation for NODE and set marker, then recurse
|
|
||||||
the subtrees."
|
|
||||||
(let* ((ts-node (car node))
|
|
||||||
(children (cdr node))
|
|
||||||
(subtrees (mapcan #'cmake-ts-mode--imenu-1
|
|
||||||
children))
|
|
||||||
(name (when ts-node
|
|
||||||
(pcase (treesit-node-type ts-node)
|
|
||||||
("function_def"
|
|
||||||
(treesit-node-text
|
|
||||||
(treesit-node-child (treesit-node-child ts-node 0) 2) t)))))
|
|
||||||
(marker (when ts-node
|
|
||||||
(set-marker (make-marker)
|
|
||||||
(treesit-node-start ts-node)))))
|
|
||||||
(cond
|
|
||||||
((or (null ts-node) (null name)) subtrees)
|
|
||||||
(subtrees
|
|
||||||
`((,name ,(cons name marker) ,@subtrees)))
|
|
||||||
(t
|
|
||||||
`((,name . ,marker))))))
|
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(define-derived-mode cmake-ts-mode prog-mode "CMake"
|
(define-derived-mode cmake-ts-mode prog-mode "CMake"
|
||||||
|
@ -242,7 +217,8 @@ the subtrees."
|
||||||
(setq-local comment-start-skip (rx "#" (* (syntax whitespace))))
|
(setq-local comment-start-skip (rx "#" (* (syntax whitespace))))
|
||||||
|
|
||||||
;; Imenu.
|
;; Imenu.
|
||||||
(setq-local imenu-create-index-function #'cmake-ts-mode--imenu)
|
(setq-local treesit-simple-imenu-settings
|
||||||
|
`(("Function" "\\`function_command\\'" nil cmake-ts-mode--function-name)))
|
||||||
(setq-local which-func-functions nil)
|
(setq-local which-func-functions nil)
|
||||||
|
|
||||||
;; Indent.
|
;; Indent.
|
||||||
|
|
|
@ -31,10 +31,8 @@
|
||||||
(eval-when-compile (require 'rx))
|
(eval-when-compile (require 'rx))
|
||||||
|
|
||||||
(declare-function treesit-parser-create "treesit.c")
|
(declare-function treesit-parser-create "treesit.c")
|
||||||
(declare-function treesit-induce-sparse-tree "treesit.c")
|
|
||||||
(declare-function treesit-node-child "treesit.c")
|
(declare-function treesit-node-child "treesit.c")
|
||||||
(declare-function treesit-node-child-by-field-name "treesit.c")
|
(declare-function treesit-node-child-by-field-name "treesit.c")
|
||||||
(declare-function treesit-node-start "treesit.c")
|
|
||||||
(declare-function treesit-node-type "treesit.c")
|
(declare-function treesit-node-type "treesit.c")
|
||||||
|
|
||||||
(defvar dockerfile-ts-mode--syntax-table
|
(defvar dockerfile-ts-mode--syntax-table
|
||||||
|
@ -118,38 +116,15 @@ continuation to the previous entry."
|
||||||
'((ERROR) @font-lock-warning-face))
|
'((ERROR) @font-lock-warning-face))
|
||||||
"Tree-sitter font-lock settings.")
|
"Tree-sitter font-lock settings.")
|
||||||
|
|
||||||
(defun dockerfile-ts-mode--imenu ()
|
(defun dockerfile-ts-mode--stage-name (node)
|
||||||
"Return Imenu alist for the current buffer."
|
"Return the stage name of NODE.
|
||||||
(let* ((node (treesit-buffer-root-node))
|
Return nil if there is no name or if NODE is not a stage node."
|
||||||
(stage-tree (treesit-induce-sparse-tree
|
(pcase (treesit-node-type node)
|
||||||
node "from_instruction"
|
("from_instruction"
|
||||||
nil 1000))
|
(treesit-node-text
|
||||||
(stage-index (dockerfile-ts-mode--imenu-1 stage-tree)))
|
(or (treesit-node-child-by-field-name node "as")
|
||||||
(when stage-index `(("Stage" . ,stage-index)))))
|
(treesit-node-child node 1))
|
||||||
|
t))))
|
||||||
(defun dockerfile-ts-mode--imenu-1 (node)
|
|
||||||
"Helper for `dockerfile-ts-mode--imenu'.
|
|
||||||
Find string representation for NODE and set marker, then recurse
|
|
||||||
the subtrees."
|
|
||||||
(let* ((ts-node (car node))
|
|
||||||
(children (cdr node))
|
|
||||||
(subtrees (mapcan #'dockerfile-ts-mode--imenu-1
|
|
||||||
children))
|
|
||||||
(name (when ts-node
|
|
||||||
(pcase (treesit-node-type ts-node)
|
|
||||||
("from_instruction"
|
|
||||||
(treesit-node-text
|
|
||||||
(or (treesit-node-child-by-field-name ts-node "as")
|
|
||||||
(treesit-node-child ts-node 1)) t)))))
|
|
||||||
(marker (when ts-node
|
|
||||||
(set-marker (make-marker)
|
|
||||||
(treesit-node-start ts-node)))))
|
|
||||||
(cond
|
|
||||||
((or (null ts-node) (null name)) subtrees)
|
|
||||||
(subtrees
|
|
||||||
`((,name ,(cons name marker) ,@subtrees)))
|
|
||||||
(t
|
|
||||||
`((,name . ,marker))))))
|
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(define-derived-mode dockerfile-ts-mode prog-mode "Dockerfile"
|
(define-derived-mode dockerfile-ts-mode prog-mode "Dockerfile"
|
||||||
|
@ -166,8 +141,8 @@ the subtrees."
|
||||||
(setq-local comment-start-skip (rx "#" (* (syntax whitespace))))
|
(setq-local comment-start-skip (rx "#" (* (syntax whitespace))))
|
||||||
|
|
||||||
;; Imenu.
|
;; Imenu.
|
||||||
(setq-local imenu-create-index-function
|
(setq-local treesit-simple-imenu-settings
|
||||||
#'dockerfile-ts-mode--imenu)
|
`(("Stage" "\\`from_instruction\\'" nil dockerfile-ts-mode--stage-name)))
|
||||||
(setq-local which-func-functions nil)
|
(setq-local which-func-functions nil)
|
||||||
|
|
||||||
;; Indent.
|
;; Indent.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue