aboutsummaryrefslogtreecommitdiffstats
path: root/runtime/queries/snakemake/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/snakemake/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/snakemake/highlights.scm')
-rw-r--r--runtime/queries/snakemake/highlights.scm82
1 files changed, 82 insertions, 0 deletions
diff --git a/runtime/queries/snakemake/highlights.scm b/runtime/queries/snakemake/highlights.scm
new file mode 100644
index 000000000..8781b405c
--- /dev/null
+++ b/runtime/queries/snakemake/highlights.scm
@@ -0,0 +1,82 @@
+; inherits: python
+
+; Compound directives
+[
+ "rule"
+ "checkpoint"
+ "module"
+] @keyword
+
+; Top level directives (eg. configfile, include)
+(module
+ (directive
+ name: _ @keyword))
+
+; Subordinate directives (eg. input, output)
+body: (_
+ (directive
+ name: _ @label))
+
+; rule/module/checkpoint names
+(rule_definition
+ name: (identifier) @type)
+
+(module_definition
+ name: (identifier) @type)
+
+(checkpoint_definition
+ name: (identifier) @type)
+
+; Rule imports
+(rule_import
+ [
+ "use"
+ "rule"
+ "from"
+ "exclude"
+ "as"
+ "with"
+ ] @keyword.import)
+
+; Rule inheritance
+(rule_inheritance
+ "use" @keyword
+ "rule" @keyword
+ "with" @keyword)
+
+; Wildcard names
+(wildcard
+ (identifier) @variable)
+
+(wildcard
+ (flag) @variable.parameter.builtin)
+
+; builtin variables
+((identifier) @variable.builtin
+ (#any-of? @variable.builtin "checkpoints" "config" "gather" "rules" "scatter" "workflow"))
+
+; References to directive labels in wildcard interpolations
+; the #any-of? queries are moved above the #has-ancestor? queries to
+; short-circuit the potentially expensive tree traversal, if possible
+; see:
+; https://github.com/nvim-treesitter/nvim-treesitter/pull/4302#issuecomment-1685789790
+; directive labels in wildcard context
+((wildcard
+ (identifier) @label)
+ (#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
+
+((wildcard
+ (attribute
+ object: (identifier) @label))
+ (#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
+
+((wildcard
+ (subscript
+ value: (identifier) @label))
+ (#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
+
+; directive labels in block context (eg. within 'run:')
+((identifier) @label
+ (#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards")
+ (#has-ancestor? @label "directive")
+ (#has-ancestor? @label "block"))