aboutsummaryrefslogtreecommitdiffstats
path: root/runtime/queries/javascript
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/javascript
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/javascript')
-rw-r--r--runtime/queries/javascript/folds.scm1
-rw-r--r--runtime/queries/javascript/highlights.scm56
-rw-r--r--runtime/queries/javascript/indents.scm1
-rw-r--r--runtime/queries/javascript/injections.scm1
-rw-r--r--runtime/queries/javascript/locals.scm69
5 files changed, 128 insertions, 0 deletions
diff --git a/runtime/queries/javascript/folds.scm b/runtime/queries/javascript/folds.scm
new file mode 100644
index 000000000..b6d9b28bf
--- /dev/null
+++ b/runtime/queries/javascript/folds.scm
@@ -0,0 +1 @@
+; inherits: ecma,jsx
diff --git a/runtime/queries/javascript/highlights.scm b/runtime/queries/javascript/highlights.scm
new file mode 100644
index 000000000..257a731ad
--- /dev/null
+++ b/runtime/queries/javascript/highlights.scm
@@ -0,0 +1,56 @@
+; inherits: ecma,jsx
+
+; Parameters
+(formal_parameters
+ (identifier) @variable.parameter)
+
+(formal_parameters
+ (rest_pattern
+ (identifier) @variable.parameter))
+
+; ({ a }) => null
+(formal_parameters
+ (object_pattern
+ (shorthand_property_identifier_pattern) @variable.parameter))
+
+; ({ a = b }) => null
+(formal_parameters
+ (object_pattern
+ (object_assignment_pattern
+ (shorthand_property_identifier_pattern) @variable.parameter)))
+
+; ({ a: b }) => null
+(formal_parameters
+ (object_pattern
+ (pair_pattern
+ value: (identifier) @variable.parameter)))
+
+; ([ a ]) => null
+(formal_parameters
+ (array_pattern
+ (identifier) @variable.parameter))
+
+; ({ a } = { a }) => null
+(formal_parameters
+ (assignment_pattern
+ (object_pattern
+ (shorthand_property_identifier_pattern) @variable.parameter)))
+
+; ({ a = b } = { a }) => null
+(formal_parameters
+ (assignment_pattern
+ (object_pattern
+ (object_assignment_pattern
+ (shorthand_property_identifier_pattern) @variable.parameter))))
+
+; a => null
+(arrow_function
+ parameter: (identifier) @variable.parameter)
+
+; optional parameters
+(formal_parameters
+ (assignment_pattern
+ left: (identifier) @variable.parameter))
+
+; punctuation
+(optional_chain) @punctuation.delimiter
diff --git a/runtime/queries/javascript/indents.scm b/runtime/queries/javascript/indents.scm
new file mode 100644
index 000000000..b6d9b28bf
--- /dev/null
+++ b/runtime/queries/javascript/indents.scm
@@ -0,0 +1 @@
+; inherits: ecma,jsx
diff --git a/runtime/queries/javascript/injections.scm b/runtime/queries/javascript/injections.scm
new file mode 100644
index 000000000..b6d9b28bf
--- /dev/null
+++ b/runtime/queries/javascript/injections.scm
@@ -0,0 +1 @@
+; inherits: ecma,jsx
diff --git a/runtime/queries/javascript/locals.scm b/runtime/queries/javascript/locals.scm
new file mode 100644
index 000000000..6d6846fc7
--- /dev/null
+++ b/runtime/queries/javascript/locals.scm
@@ -0,0 +1,69 @@
+; inherits: ecma,jsx
+
+; Both properties are matched here.
+;
+; class Foo {
+; this.#bar = "baz";
+; this.quuz = "qux";
+; }
+(field_definition
+ property: [
+ (property_identifier)
+ (private_property_identifier)
+ ] @local.definition.var)
+
+; this.foo = "bar"
+(assignment_expression
+ left: (member_expression
+ object: (this)
+ property: (property_identifier) @local.definition.var))
+
+(formal_parameters
+ (identifier) @local.definition.parameter)
+
+; function(arg = []) {
+(formal_parameters
+ (assignment_pattern
+ left: (identifier) @local.definition.parameter))
+
+; x => x
+(arrow_function
+ parameter: (identifier) @local.definition.parameter)
+
+; ({ a }) => null
+(formal_parameters
+ (object_pattern
+ (shorthand_property_identifier_pattern) @local.definition.parameter))
+
+; ({ a: b }) => null
+(formal_parameters
+ (object_pattern
+ (pair_pattern
+ value: (identifier) @local.definition.parameter)))
+
+; ([ a ]) => null
+(formal_parameters
+ (array_pattern
+ (identifier) @local.definition.parameter))
+
+(formal_parameters
+ (rest_pattern
+ (identifier) @local.definition.parameter))
+
+; Both methods are matched here.
+;
+; class Foo {
+; #bar(x) { x }
+; baz(y) { y }
+; }
+(method_definition
+ [
+ (property_identifier)
+ (private_property_identifier)
+ ] @local.definition.function
+ (#set! definition.var.scope parent))
+
+; this.foo()
+(member_expression
+ object: (this)
+ property: (property_identifier) @local.reference)