aboutsummaryrefslogtreecommitdiffstats
path: root/runtime/queries/vrl
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/vrl
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/vrl')
-rw-r--r--runtime/queries/vrl/folds.scm6
-rw-r--r--runtime/queries/vrl/highlights.scm108
-rw-r--r--runtime/queries/vrl/indents.scm24
-rw-r--r--runtime/queries/vrl/injections.scm6
-rw-r--r--runtime/queries/vrl/locals.scm16
5 files changed, 160 insertions, 0 deletions
diff --git a/runtime/queries/vrl/folds.scm b/runtime/queries/vrl/folds.scm
new file mode 100644
index 000000000..6c6d587de
--- /dev/null
+++ b/runtime/queries/vrl/folds.scm
@@ -0,0 +1,6 @@
+[
+ (block)
+ (object)
+ (array)
+ (arguments)
+] @fold
diff --git a/runtime/queries/vrl/highlights.scm b/runtime/queries/vrl/highlights.scm
new file mode 100644
index 000000000..f74d6dd55
--- /dev/null
+++ b/runtime/queries/vrl/highlights.scm
@@ -0,0 +1,108 @@
+(comment) @comment @spell
+
+(null) @constant.builtin
+
+(timestamp) @constant
+
+(closure_variables
+ (ident) @variable.parameter)
+
+(integer) @number
+
+(float) @number.float
+
+[
+ (string)
+ (raw_string)
+] @string
+
+[
+ (raw_string_escape_sequence)
+ (escape_sequence)
+ (regex_escape_sequence)
+] @string.escape
+
+(string_template
+ "{{" @punctuation.special
+ (_)
+ "}}" @punctuation.special)
+
+(regex) @string.regexp
+
+(boolean) @boolean
+
+(ident) @variable
+
+(noop) @variable.builtin
+
+(function_call
+ (ident) @function.call)
+
+; VRL queries
+(query
+ [
+ (event)
+ (metadata)
+ ] @variable.builtin)
+
+(query
+ (path
+ [
+ (field) @variable
+ (string) @string
+ (index) @number
+ "." @punctuation.delimiter
+ ]))
+
+"return" @keyword.return
+
+"abort" @keyword.exception
+
+[
+ "if"
+ "else"
+] @keyword.conditional
+
+[
+ "="
+ "=="
+ "!="
+ "|="
+ ">"
+ ">="
+ "<"
+ "<="
+ "+"
+ "-"
+ "*"
+ "/"
+ "&&"
+ "||"
+ "??"
+ "|"
+ "!"
+] @operator
+
+[
+ "->"
+ ":"
+ ";"
+ ","
+] @punctuation.delimiter
+
+[
+ "("
+ ")"
+ "["
+ "]"
+ "{"
+ "}"
+] @punctuation.bracket
+
+(closure_variables
+ "|" @punctuation.bracket)
+
+(function_call
+ (ident) @keyword.exception
+ "!"
+ (#any-of? @keyword.exception "assert" "assert_eq"))
diff --git a/runtime/queries/vrl/indents.scm b/runtime/queries/vrl/indents.scm
new file mode 100644
index 000000000..1fc1249e0
--- /dev/null
+++ b/runtime/queries/vrl/indents.scm
@@ -0,0 +1,24 @@
+[
+ (block)
+ (object)
+ (array)
+ (arguments)
+] @indent.begin
+
+(block
+ "}" @indent.end)
+
+(object
+ "}" @indent.end)
+
+(array
+ "]" @indent.end)
+
+(arguments
+ ")" @indent.end)
+
+[
+ ")"
+ "]"
+ "}"
+] @indent.branch
diff --git a/runtime/queries/vrl/injections.scm b/runtime/queries/vrl/injections.scm
new file mode 100644
index 000000000..5aaf9bcd2
--- /dev/null
+++ b/runtime/queries/vrl/injections.scm
@@ -0,0 +1,6 @@
+((comment) @injection.content
+ (#set! injection.language "comment"))
+
+((regex) @injection.content
+ (#offset! @injection.content 0 2 0 -1)
+ (#set! injection.language "regex"))
diff --git a/runtime/queries/vrl/locals.scm b/runtime/queries/vrl/locals.scm
new file mode 100644
index 000000000..786da98c5
--- /dev/null
+++ b/runtime/queries/vrl/locals.scm
@@ -0,0 +1,16 @@
+(closure_variables
+ (ident) @local.definition.parameter)
+
+[
+ (ident)
+ (metadata)
+] @local.reference
+
+(query
+ (event) @local.reference)
+
+[
+ (block)
+ (closure)
+ (if_statement)
+] @local.scope