From 61dbfc067e49307ecda7603c07e5f461c06311f0 Mon Sep 17 00:00:00 2001 From: Michael Davis Date: Sun, 17 Apr 2022 12:12:43 -0500 Subject: [PATCH 1/2] highlight HEEx braces as keywords Special HEEx templating tokens are highlighted as keywords similar to EJS/ERB highlights. The braces are templating tokens too. For example you can conveniently interpolate an attribute's value like so:
For consistency these should be highlighted like the other templating tokens. --- runtime/queries/heex/highlights.scm | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/runtime/queries/heex/highlights.scm b/runtime/queries/heex/highlights.scm index 301f57c84606..d63853b5c773 100644 --- a/runtime/queries/heex/highlights.scm +++ b/runtime/queries/heex/highlights.scm @@ -11,8 +11,6 @@ "--%>" "-->" "/>" - "{" - "}" ; These could be `@keyword`s but the closing `>` wouldn't be highlighted ; as `@keyword` "<:" @@ -21,6 +19,8 @@ ; Non-comment or tag delimiters [ + "{" + "}" "<%" "<%=" "<%%=" From 10cded6c737f017ba20e251a3453165a5e809da2 Mon Sep 17 00:00:00 2001 From: Michael Davis Date: Thu, 14 Apr 2022 17:12:55 -0500 Subject: [PATCH 2/2] update tree-sitter-erlang changes: * fixed highlights for callbacks and ifdef/ifndef attributes * all attributes are now highlighted as keywords for simplicity * fixed precedence between unused variable and macro highlights * the 'quoted_atom' rule has been consolidated into 'atom' which improves highlights in scenarios where the pattern matches an atom --- languages.toml | 2 +- runtime/queries/erlang/highlights.scm | 26 +++++++++++++------------- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/languages.toml b/languages.toml index 70baabaf5648..fd14fc573de4 100644 --- a/languages.toml +++ b/languages.toml @@ -974,7 +974,7 @@ language-server = { command = "erlang_ls" } [[grammar]] name = "erlang" -source = { git = "https://github.com/the-mikedavis/tree-sitter-erlang", rev = "1e81393b8f0a81b35ff1679a9420fafbd2cf3511" } +source = { git = "https://github.com/the-mikedavis/tree-sitter-erlang", rev = "3f611cfdc790214c3f9f9cf1658b3ae8039c54b8" } [[language]] name = "kotlin" diff --git a/runtime/queries/erlang/highlights.scm b/runtime/queries/erlang/highlights.scm index 067e0f82c891..1e0753497969 100644 --- a/runtime/queries/erlang/highlights.scm +++ b/runtime/queries/erlang/highlights.scm @@ -46,10 +46,16 @@ ]) (#eq? @keyword "define")) +(attribute + name: (atom) @keyword + (arguments + (_) @keyword.directive) + (#match? @keyword "ifn?def")) + (attribute name: (atom) @keyword module: (atom) @module - (#eq? @keyword "spec")) + (#eq? @keyword "(spec|callback)")) ; Functions (function name: (atom) @function) @@ -69,10 +75,7 @@ (record name: (atom) @type) ; Keywords -((attribute name: (atom) @keyword) - (#match? - @keyword - "^(define|export|export_type|include|include_lib|ifdef|ifndef|if|elif|else|endif|vsn|on_load|behaviour|record|file|type|opaque|spec)$")) +(attribute name: (atom) @keyword) ["case" "fun" "if" "of" "when" "end" "receive" "try" "catch" "after" "begin" "maybe"] @keyword @@ -86,10 +89,6 @@ (unary_operator operator: _ @operator) ["/" ":" "#" "->"] @operator -; Comments -((variable) @comment.discard - (#match? @comment.discard "^_")) - (tripledot) @comment.discard (comment) @comment @@ -99,12 +98,13 @@ "?"+ @keyword.directive name: (_) @keyword.directive) +; Comments +((variable) @comment.discard + (#match? @comment.discard "^_")) + ; Basic types (variable) @variable -[ - (atom) - (quoted_atom) -] @string.special.symbol +(atom) @string.special.symbol (string) @string (character) @constant.character