* bug#67554: [PATCH] Improve font-lock in lua-ts-mode @ 2023-11-30 23:51 john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors [not found] ` <handler.67554.B.170138919828765.ack@debbugs.gnu.org> 0 siblings, 1 reply; 5+ messages in thread From: john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2023-11-30 23:51 UTC (permalink / raw) To: 67554 Tags: patch While testing out ert-font-lock I found some inconsistencies and missing highlights. This also moves properties to level 4 font-lock and adds font-lock-comment-delimiter-face. ^ permalink raw reply [flat|nested] 5+ messages in thread
[parent not found: <handler.67554.B.170138919828765.ack@debbugs.gnu.org>]
* bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) [not found] ` <handler.67554.B.170138919828765.ack@debbugs.gnu.org> @ 2023-12-01 0:34 ` john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors 2023-12-02 13:51 ` Eli Zaretskii 0 siblings, 1 reply; 5+ messages in thread From: john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2023-12-01 0:34 UTC (permalink / raw) To: 67554 [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #1: 0001-Improve-font-locking-in-lua-ts-mode-bug-67554.patch --] [-- Type: text/x-patch, Size: 8909 bytes --] From 5a87b7b231a384c7035e75105bc173fc05f38336 Mon Sep 17 00:00:00 2001 From: john muhl <jm@pub.pink> Date: Tue, 14 Nov 2023 16:25:43 -0600 Subject: [PATCH] Improve font-locking in lua-ts-mode (bug#67554) * lisp/progmodes/lua-ts-mode.el (lua-ts-mode): Move property highlighting to level 4. (lua-ts--keywords): Remove `true', `false' and `nil' from keywords. (lua-ts--font-lock-settings): Highlight assignments, functions and labels in more places. Distinguish comment delimiters. (lua-ts--comment-font-lock): New function. --- lisp/progmodes/lua-ts-mode.el | 151 ++++++++++++++++++---------------- 1 file changed, 79 insertions(+), 72 deletions(-) diff --git a/lisp/progmodes/lua-ts-mode.el b/lisp/progmodes/lua-ts-mode.el index a910d759c83..7dd05b2757f 100644 --- a/lisp/progmodes/lua-ts-mode.el +++ b/lisp/progmodes/lua-ts-mode.el @@ -133,135 +133,141 @@ lua-ts--builtins "Lua built-in functions for tree-sitter font-locking.") (defvar lua-ts--keywords - '("and" "do" "else" "elseif" "end" "for" "function" - "goto" "if" "in" "local" "not" "or" "repeat" - "return" "then" "until" "while") + '("and" "do" "else" "elseif" "end" "for" "function" "goto" "if" + "in" "local" "not" "or" "repeat" "return" "then" "until" "while") "Lua keywords for tree-sitter font-locking and navigation.") +(defun lua-ts--comment-font-lock (node override start end &rest _) + "Apply font lock to comment NODE within START and END. +Applies `font-lock-comment-delimiter-face' and +`font-lock-comment-face' See `treesit-fontify-with-override' for +values of OVERRIDE." + (let* ((node-start (treesit-node-start node)) + (node-end (treesit-node-end node)) + (node-text (treesit-node-text node t)) + (delimiter-end (+ 2 node-start))) + (when (and (>= node-start start) + (<= delimiter-end end) + (string-match "\\`--" node-text)) + (treesit-fontify-with-override node-start + delimiter-end + font-lock-comment-delimiter-face + override)) + (treesit-fontify-with-override (max delimiter-end start) + (min node-end end) + font-lock-comment-face + override))) + (defvar lua-ts--font-lock-settings (treesit-font-lock-rules - :language 'lua + :default-language 'lua :feature 'bracket '(["(" ")" "[" "]" "{" "}"] @font-lock-bracket-face) - :language 'lua :feature 'delimiter '(["," ";"] @font-lock-delimiter-face) - :language 'lua :feature 'constant - '((variable_list - attribute: (attribute (["<" ">"] (identifier)))) - @font-lock-constant-face - (goto_statement (identifier) @font-lock-constant-face) - (label_statement) @font-lock-constant-face) + '([(variable_list + attribute: (attribute (["<" ">"] (identifier)))) + (label_statement) + (true) (false) (nil)] + @font-lock-constant-face) - :language 'lua :feature 'operator - '(["and" "not" "or" "+" "-" "*" "/" "%" "^" - "#" "==" "~=" "<=" ">=" "<" ">" "=" "&" - "~" "|" "<<" ">>" "//" ".."] - @font-lock-operator-face - (vararg_expression) @font-lock-operator-face) + '(["+" "-" "*" "/" "%" "^" "#" "==" "~=" "<=" ">=" + "<" ">" "=" "&" "~" "|" "<<" ">>" "//" ".." + (vararg_expression)] + @font-lock-operator-face) - :language 'lua :feature 'builtin `(((identifier) @font-lock-builtin-face (:match ,(regexp-opt lua-ts--builtins 'symbols) @font-lock-builtin-face))) - :language 'lua :feature 'function '((function_call name: (identifier) @font-lock-function-call-face) (function_call - name: (method_index_expression - method: (identifier) @font-lock-function-call-face)) + (method_index_expression + method: (identifier) @font-lock-function-call-face)) (function_call - name: (dot_index_expression (identifier) @font-lock-function-call-face))) + (dot_index_expression + field: (identifier) @font-lock-function-call-face))) - :language 'lua :feature 'punctuation '(["." ":"] @font-lock-punctuation-face) - :language 'lua :feature 'variable '((function_call - arguments: (arguments (identifier)) - @font-lock-variable-use-face) + (arguments (identifier) @font-lock-variable-use-face)) (function_call - name: (method_index_expression - table: (identifier) @font-lock-variable-use-face))) + (arguments + (binary_expression (identifier) @font-lock-variable-use-face))) + (function_call + (arguments + (bracket_index_expression (identifier) @font-lock-variable-use-face))) + (function_declaration + (parameters name: (identifier) @font-lock-variable-name-face))) - :language 'lua :feature 'number '((number) @font-lock-number-face) - :language 'lua :feature 'keyword - `((break_statement) @font-lock-keyword-face - (true) @font-lock-constant-face - (false) @font-lock-constant-face - (nil) @font-lock-constant-face - ,(vconcat lua-ts--keywords) - @font-lock-keyword-face) - - :language 'lua + `([(break_statement) + ,(vconcat lua-ts--keywords)] + @font-lock-keyword-face + (goto_statement ((identifier) @font-lock-constant-face))) + :feature 'string '((string) @font-lock-string-face) - :language 'lua :feature 'escape :override t '((escape_sequence) @font-lock-escape-face) - :language 'lua :feature 'comment - '((comment) @font-lock-comment-face + '((comment) @lua-ts--comment-font-lock (hash_bang_line) @font-lock-comment-face) - :language 'lua :feature 'definition '((function_declaration - name: (identifier) @font-lock-function-name-face) - (assignment_statement - (variable_list name: [(identifier)]) @font-lock-function-name-face - (expression_list value: (function_definition))) - (table_constructor - (field - name: (identifier) @font-lock-function-name-face - value: (function_definition))) - (function_declaration - name: (dot_index_expression (identifier) @font-lock-function-name-face)) + (identifier) @font-lock-function-name-face) (function_declaration - name: (method_index_expression (identifier) @font-lock-function-name-face)) + (dot_index_expression + field: (identifier) @font-lock-function-name-face)) (function_declaration (method_index_expression + method: (identifier) @font-lock-function-name-face)) + (assignment_statement + (variable_list + (identifier) @font-lock-function-name-face) + (expression_list value: (function_definition))) + (field + name: (identifier) @font-lock-function-name-face + value: (function_definition)) + (assignment_statement + (variable_list (dot_index_expression - table: (identifier) @font-lock-function-name-face - field: (identifier) @font-lock-property-name-face - ))) - (parameters - name: (identifier) @font-lock-variable-name-face) + field: (identifier) @font-lock-function-name-face)) + (expression_list + value: + (function_definition)))) + + :feature 'assignment + '((variable_list (identifier) @font-lock-variable-name-face) + (variable_list + (bracket_index_expression + field: (identifier) @font-lock-variable-name-face)) + (variable_list + (dot_index_expression + field: (identifier) @font-lock-variable-name-face)) (for_numeric_clause name: (identifier) @font-lock-variable-name-face)) - :language 'lua :feature 'property '((field name: (identifier) @font-lock-property-name-face) (dot_index_expression field: (identifier) @font-lock-property-use-face)) - :language 'lua - :feature 'assignment - '((variable_list - [(identifier) - (bracket_index_expression)] - @font-lock-variable-name-face) - (variable_list - (dot_index_expression - table: (identifier)) - @font-lock-variable-name-face)) - - :language 'lua :feature 'error :override t '((ERROR) @font-lock-warning-face)) @@ -665,13 +671,14 @@ lua-ts-mode (setq-local treesit-font-lock-settings lua-ts--font-lock-settings) (setq-local treesit-font-lock-feature-list '((comment definition) - (keyword property string) + (keyword string) (assignment builtin constant number) (bracket delimiter escape function operator + property punctuation variable))) -- 2.41.0 ^ permalink raw reply related [flat|nested] 5+ messages in thread
* bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) 2023-12-01 0:34 ` bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2023-12-02 13:51 ` Eli Zaretskii 2023-12-02 14:08 ` john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors 0 siblings, 1 reply; 5+ messages in thread From: Eli Zaretskii @ 2023-12-02 13:51 UTC (permalink / raw) To: john muhl; +Cc: 67554-done > Date: Thu, 30 Nov 2023 18:34:59 -0600 > From: john muhl via "Bug reports for GNU Emacs, > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org> > > > >From 5a87b7b231a384c7035e75105bc173fc05f38336 Mon Sep 17 00:00:00 2001 > From: john muhl <jm@pub.pink> > Date: Tue, 14 Nov 2023 16:25:43 -0600 > Subject: [PATCH] Improve font-locking in lua-ts-mode (bug#67554) > > * lisp/progmodes/lua-ts-mode.el (lua-ts-mode): Move property > highlighting to level 4. > (lua-ts--keywords): Remove `true', `false' and `nil' from > keywords. > (lua-ts--font-lock-settings): Highlight assignments, functions > and labels in more places. Distinguish comment delimiters. > (lua-ts--comment-font-lock): New function. Thanks, pushed to the master branch (with a couple of minor adjustments), and closing the bug. ^ permalink raw reply [flat|nested] 5+ messages in thread
* bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) 2023-12-02 13:51 ` Eli Zaretskii @ 2023-12-02 14:08 ` john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors 2023-12-02 14:51 ` Eli Zaretskii 0 siblings, 1 reply; 5+ messages in thread From: john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2023-12-02 14:08 UTC (permalink / raw) To: Eli Zaretskii; +Cc: 67554 Eli Zaretskii <eliz@gnu.org> writes: >> Date: Thu, 30 Nov 2023 18:34:59 -0600 >> From: john muhl via "Bug reports for GNU Emacs, >> the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org> >> >> >> >From 5a87b7b231a384c7035e75105bc173fc05f38336 Mon Sep 17 00:00:00 2001 >> From: john muhl <jm@pub.pink> >> Date: Tue, 14 Nov 2023 16:25:43 -0600 >> Subject: [PATCH] Improve font-locking in lua-ts-mode (bug#67554) >> >> * lisp/progmodes/lua-ts-mode.el (lua-ts-mode): Move property >> highlighting to level 4. >> (lua-ts--keywords): Remove `true', `false' and `nil' from >> keywords. >> (lua-ts--font-lock-settings): Highlight assignments, functions >> and labels in more places. Distinguish comment delimiters. >> (lua-ts--comment-font-lock): New function. > > Thanks, pushed to the master branch (with a couple of minor > adjustments), and closing the bug. Thanks for the help. The missing period in the doc string was inherited from ruby-ts-mode if you wanted to fix the same thing there (line 200). Or I could send a patch if that is somehow less work for you. ^ permalink raw reply [flat|nested] 5+ messages in thread
* bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) 2023-12-02 14:08 ` john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2023-12-02 14:51 ` Eli Zaretskii 0 siblings, 0 replies; 5+ messages in thread From: Eli Zaretskii @ 2023-12-02 14:51 UTC (permalink / raw) To: john muhl; +Cc: 67554 > From: john muhl <jm@pub.pink> > Cc: 67554@debbugs.gnu.org > Date: Sat, 02 Dec 2023 08:08:16 -0600 > > Eli Zaretskii <eliz@gnu.org> writes: > > > Thanks, pushed to the master branch (with a couple of minor > > adjustments), and closing the bug. > > Thanks for the help. The missing period in the doc string was > inherited from ruby-ts-mode if you wanted to fix the same thing > there (line 200). Or I could send a patch if that is somehow > less work for you. Fixed, thanks. ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2023-12-02 14:51 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2023-11-30 23:51 bug#67554: [PATCH] Improve font-lock in lua-ts-mode john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors [not found] ` <handler.67554.B.170138919828765.ack@debbugs.gnu.org> 2023-12-01 0:34 ` bug#67554: Acknowledgement ([PATCH] Improve font-lock in lua-ts-mode) john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors 2023-12-02 13:51 ` Eli Zaretskii 2023-12-02 14:08 ` john muhl via Bug reports for GNU Emacs, the Swiss army knife of text editors 2023-12-02 14:51 ` Eli Zaretskii
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).