aboutsummaryrefslogtreecommitdiffstats
path: root/runtime/queries/tera/highlights.scm
diff options
context:
space:
mode:
authorChristian Clason <c.clason@uni-graz.at>2023-06-12 09:54:30 -0600
committerChristian Clason <c.clason@uni-graz.at>2025-05-12 18:43:40 +0200
commit692b051b09935653befdb8f7ba8afdb640adf17b (patch)
tree167162b6b129ae04f68c5735078521a72917c742 /runtime/queries/tera/highlights.scm
parentfeat(c-family): inherit injections (diff)
downloadnvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar.gz
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar.bz2
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar.lz
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar.xz
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.tar.zst
nvim-treesitter-692b051b09935653befdb8f7ba8afdb640adf17b.zip
feat!: drop modules, general refactor and cleanup
Diffstat (limited to 'runtime/queries/tera/highlights.scm')
-rw-r--r--runtime/queries/tera/highlights.scm153
1 files changed, 153 insertions, 0 deletions
diff --git a/runtime/queries/tera/highlights.scm b/runtime/queries/tera/highlights.scm
new file mode 100644
index 000000000..f41ad826f
--- /dev/null
+++ b/runtime/queries/tera/highlights.scm
@@ -0,0 +1,153 @@
+; Variables
+;----------
+(identifier) @variable
+
+((identifier) @variable.builtin
+ (#any-of? @variable.builtin "loop" "__tera_context"))
+
+; Properties
+;-----------
+(member_expression
+ property: (identifier)? @variable.member)
+
+; Literals
+;-----------
+(string) @string
+
+(bool) @boolean
+
+(number) @number
+
+; Tokens
+;-----------
+[
+ "."
+ ","
+ "::"
+ (frontmatter_delimiter)
+] @punctuation.delimiter
+
+[
+ "*"
+ "/"
+ "%"
+ "|"
+ "+"
+ "-"
+ "~"
+ "="
+ "=="
+ "!="
+ "<"
+ ">"
+ "<="
+ ">="
+] @operator
+
+[
+ "("
+ ")"
+ "["
+ "]"
+ "{%"
+ "%}"
+ "-%}"
+ "{%-"
+ "}}"
+ "{{"
+ "-}}"
+ "{{-"
+] @punctuation.bracket
+
+; Tags
+;-----------
+(comment_tag) @comment @spell
+
+; Keywords
+;-----------
+[
+ "if"
+ "elif"
+ "else"
+ "endif"
+] @keyword.conditional
+
+[
+ "for"
+ "endfor"
+] @keyword.repeat
+
+[
+ "include"
+ "import"
+ "extends"
+] @keyword.import
+
+[
+ "in"
+ "and"
+ "or"
+ "not"
+ "is"
+] @keyword.operator
+
+[
+ "break"
+ "continue"
+] @keyword.return
+
+[
+ "set"
+ "set_global"
+ "filter"
+ "endfilter"
+ "block"
+ "endblock"
+ "macro"
+ "endmacro"
+ "raw"
+ "endraw"
+ "as"
+] @keyword
+
+; Functions
+;-----------
+(macro_statement
+ name: (identifier) @function
+ (parameter_list
+ parameter: (identifier) @variable.parameter
+ (optional_parameter
+ name: (identifier) @variable.parameter)))
+
+(call_expression
+ scope: (identifier)? @module
+ name: (identifier) @function.call)
+
+(call_expression
+ scope: (identifier) @module.builtin
+ name: (identifier) @function.call
+ (#eq? @module.builtin "self"))
+
+(call_expression
+ name: (identifier) @function.builtin
+ (#any-of? @function.builtin
+ ; Functions - https://keats.github.io/tera/docs/#built-in-functions
+ "range" "now" "throw" "get_random" "get_env"))
+
+(test_expression
+ test: (identifier) @function.call)
+
+(test_expression
+ test: (identifier) @function.builtin
+ (#any-of? @function.builtin
+ ; Tests - https://keats.github.io/tera/docs/#built-in-tests
+ "defined" "undefined" "odd" "even" "string" "number" "divisibleby" "iterable" "object"
+ "starting_with" "ending_with" "containing" "matching"))
+
+(filter_expression
+ filter: (identifier) @function.method.call)
+
+; Namespaces
+;-----------
+(import_statement
+ scope: (identifier) @module)