From ac9205ef2d4c778b66c8c97862ebbce16a930102 Mon Sep 17 00:00:00 2001 From: Steve Purcell Date: Tue, 5 Sep 2023 18:08:17 +1200 Subject: [PATCH] Don't fail silently when grammar is missing These conditional clauses _are_ found in some `-ts` modes, but only in the case where the parent mode is the non-`ts` version of the mode: in such cases, the clause quietly "downgrades" the mode to the non-`ts` version when the grammar is missing, so that the `-ts` mode can be enabled unconditionally in `auto-mode-alist`. In other cases, like `noir-ts-mode`, the mode is non-functional without the grammar and should throw an error instead. It is unclear how best to handle the `###autoload`-ed addition to `auto-mode-alist`, since we'd expect to be able to install the same package config in Emacsen with and without tree-sitter. It's probably safest to guard the `auto-mode-alist` expression in a `(when (treesit-read-p 'lang) ...)` form too. --- noir-ts-mode.el | 55 +++++++++++++++++++++++++------------------------ 1 file changed, 28 insertions(+), 27 deletions(-) diff --git a/noir-ts-mode.el b/noir-ts-mode.el index 9cc93f2..dd094ac 100644 --- a/noir-ts-mode.el +++ b/noir-ts-mode.el @@ -74,12 +74,12 @@ table) "Syntax table for `noir-ts-mode'.") - (defvar noir-ts-mode--keywords +(defvar noir-ts-mode--keywords '("as" "else" "fn" "for" "if" "impl" "in" "let" "mod" "global" "assert" "constrain" "struct" "use" (crate) (super) (return) (self) (mutable) (viewer) (comptime)) - "Noir keywords for tree-sitter font-locking.") + "Noir keywords for tree-sitter font-locking.") (defvar noir-ts-mode--operators '("!" "!=" "%" "&" "&=" "&&" "*" "+" "+=" "," "-" "-=" @@ -125,7 +125,7 @@ '((function_definition (identifier) @font-lock-function-name-face) (function_call - (identifier) @font-lock-function-call-face)) + (identifier) @font-lock-function-call-face)) :feature 'builtin :override t @@ -193,38 +193,39 @@ :group 'noir :syntax-table noir-ts-mode--syntax-table - (when (treesit-ready-p 'noir) - (treesit-parser-create 'noir) + (unless (treesit-ready-p 'noir) + (error "Language grammar for %s is missing" 'noir)) - ;; Comments. - (setq-local comment-start "// ") - (setq-local comment-end "") - (setq-local comment-start-skip (rx (or "//" "/*"))) - (setq-local comment-end-skip (rx (or "\n" "*/"))) + (treesit-parser-create 'noir) - ;; Indent. - (setq-local indent-tabs-mode nil - treesit-simple-indent-rules noir-ts-mode--indent-rules) + ;; Comments. + (setq-local comment-start "// ") + (setq-local comment-end "") + (setq-local comment-start-skip (rx (or "//" "/*"))) + (setq-local comment-end-skip (rx (or "\n" "*/"))) - ;; Font-lock - (setq-local treesit-font-lock-settings noir-ts-mode--font-lock-settings) - (setq-local treesit-font-lock-feature-list - '((comment) - (keyword string) - (constant variable type function-name builtin number) - (bracket delimiter operator))) + ;; Indent. + (setq-local indent-tabs-mode nil + treesit-simple-indent-rules noir-ts-mode--indent-rules) - ;; Navigation. - (setq-local treesit-defun-type-regexp - (regexp-opt '("function_definition" - "struct_method" - "struct_definition"))) + ;; Font-lock + (setq-local treesit-font-lock-settings noir-ts-mode--font-lock-settings) + (setq-local treesit-font-lock-feature-list + '((comment) + (keyword string) + (constant variable type function-name builtin number) + (bracket delimiter operator))) + ;; Navigation. + (setq-local treesit-defun-type-regexp + (regexp-opt '("function_definition" + "struct_method" + "struct_definition"))) - (treesit-major-mode-setup))) + + (treesit-major-mode-setup)) (provide 'noir-ts-mode) ;;; noir-ts-mode.el ends here -