mirror of
https://github.com/nvim-treesitter/nvim-treesitter.git
synced 2026-07-01 11:06:54 -04:00
parent
939556333f
commit
fee71c102c
6 changed files with 171 additions and 20 deletions
|
|
@ -63,20 +63,20 @@ body: (_
|
||||||
; directive labels in wildcard context
|
; directive labels in wildcard context
|
||||||
((wildcard
|
((wildcard
|
||||||
(identifier) @label)
|
(identifier) @label)
|
||||||
(#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
|
(#any-of? @label "input" "jobid" "log" "output" "params" "resources" "rule" "threads" "wildcards"))
|
||||||
|
|
||||||
((wildcard
|
((wildcard
|
||||||
(attribute
|
(attribute
|
||||||
object: (identifier) @label))
|
object: (identifier) @label))
|
||||||
(#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
|
(#any-of? @label "input" "jobid" "log" "output" "params" "resources" "rule" "threads" "wildcards"))
|
||||||
|
|
||||||
((wildcard
|
((wildcard
|
||||||
(subscript
|
(subscript
|
||||||
value: (identifier) @label))
|
value: (identifier) @label))
|
||||||
(#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards"))
|
(#any-of? @label "input" "jobid" "log" "output" "params" "resources" "rule" "threads" "wildcards"))
|
||||||
|
|
||||||
; directive labels in block context (eg. within 'run:')
|
; directive labels in block context (eg. within 'run:')
|
||||||
((identifier) @label
|
((identifier) @label
|
||||||
(#any-of? @label "input" "log" "output" "params" "resources" "threads" "wildcards")
|
(#any-of? @label "input" "jobid" "log" "output" "params" "resources" "rule" "threads" "wildcards")
|
||||||
(#has-ancestor? @label "directive")
|
(#has-ancestor? @label "directive")
|
||||||
(#has-ancestor? @label "block"))
|
(#has-ancestor? @label "block"))
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,12 @@
|
||||||
; inherits: python
|
; inherits: python
|
||||||
|
|
||||||
((rule_definition) @indent.begin
|
([
|
||||||
(#set! indent.immediate 1))
|
(rule_definition)
|
||||||
|
(checkpoint_definition)
|
||||||
((checkpoint_definition) @indent.begin
|
(rule_inheritance)
|
||||||
(#set! indent.immediate 1))
|
(module_definition)
|
||||||
|
(directive)
|
||||||
((rule_inheritance) @indent.begin
|
] @indent.begin
|
||||||
(#set! indent.immediate 1))
|
(#set! indent.immediate 1))
|
||||||
|
|
||||||
((rule_import
|
((rule_import
|
||||||
|
|
@ -14,12 +14,20 @@
|
||||||
":") @indent.begin
|
":") @indent.begin
|
||||||
(#set! indent.immediate 1))
|
(#set! indent.immediate 1))
|
||||||
|
|
||||||
((module_definition) @indent.begin
|
; ; end indentation after last parameter node (no following ',')
|
||||||
(#set! indent.immediate 1))
|
; ; accommodate different levels of nesting
|
||||||
|
; ; see also queries/python/indents.scm: return_statement
|
||||||
((directive) @indent.begin
|
(directive
|
||||||
(#set! indent.immediate 1))
|
(directive_parameters
|
||||||
|
[
|
||||||
; end indentation after last parameter node (no following ',')
|
(_) @indent.dedent
|
||||||
(directive_parameters
|
(_
|
||||||
(_) @indent.end .)
|
[
|
||||||
|
(_)
|
||||||
|
")"
|
||||||
|
"}"
|
||||||
|
"]"
|
||||||
|
] .) @indent.dedent
|
||||||
|
]
|
||||||
|
. ; anchor at end: no subsequent ','
|
||||||
|
))
|
||||||
|
|
|
||||||
|
|
@ -2,3 +2,39 @@
|
||||||
|
|
||||||
(rule_definition
|
(rule_definition
|
||||||
name: (identifier) @local.definition.type) @local.scope
|
name: (identifier) @local.definition.type) @local.scope
|
||||||
|
|
||||||
|
(rule_inheritance
|
||||||
|
alias: (as_pattern_target) @local.definition.type) @local.scope
|
||||||
|
|
||||||
|
(checkpoint_definition
|
||||||
|
name: (identifier) @local.definition.type) @local.scope
|
||||||
|
|
||||||
|
(module_definition
|
||||||
|
name: (identifier) @local.definition.type) @local.scope
|
||||||
|
|
||||||
|
; use rule A from X
|
||||||
|
(rule_import
|
||||||
|
(rule_import_list
|
||||||
|
(identifier) @local.definition.import)
|
||||||
|
.
|
||||||
|
module_name: (identifier) .) @local.scope
|
||||||
|
|
||||||
|
; use rule A from X as A_fromX
|
||||||
|
; use rule A from X as *_fromX
|
||||||
|
; use rule * from X as *_fromX
|
||||||
|
(rule_import
|
||||||
|
alias: (as_pattern_target) @local.definition.import .) @local.scope
|
||||||
|
|
||||||
|
; use rule A from X with:
|
||||||
|
(rule_import
|
||||||
|
(rule_import_list
|
||||||
|
(identifier) @local.definition.type)
|
||||||
|
.
|
||||||
|
module_name: (identifier)
|
||||||
|
.
|
||||||
|
"with") @local.scope
|
||||||
|
|
||||||
|
; use rule A from X as Y with:
|
||||||
|
(rule_import
|
||||||
|
alias: (as_pattern_target) @local.definition.type
|
||||||
|
"with") @local.scope
|
||||||
|
|
|
||||||
22
tests/indent/snakemake/blocks.smk
Normal file
22
tests/indent/snakemake/blocks.smk
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
rule A:
|
||||||
|
"""doc"""
|
||||||
|
|
||||||
|
if True:
|
||||||
|
rule B:
|
||||||
|
"""doc"""
|
||||||
|
|
||||||
|
use rule other from somewhere
|
||||||
|
|
||||||
|
use rule other2 from somewhere as other_alias
|
||||||
|
|
||||||
|
use rule other3 from somewhere with:
|
||||||
|
input: 2
|
||||||
|
|
||||||
|
use rule other4 from somewhere as other_alias2 with:
|
||||||
|
input: 2
|
||||||
|
|
||||||
|
checkpoint C:
|
||||||
|
input: "1"
|
||||||
|
|
||||||
|
module A:
|
||||||
|
snakefile: "x.smk"
|
||||||
36
tests/indent/snakemake/directive_parameters.smk
Normal file
36
tests/indent/snakemake/directive_parameters.smk
Normal file
|
|
@ -0,0 +1,36 @@
|
||||||
|
rule A:
|
||||||
|
input: a
|
||||||
|
output: b
|
||||||
|
params:
|
||||||
|
a = 1,
|
||||||
|
b = 2,
|
||||||
|
c = 3
|
||||||
|
shell:
|
||||||
|
"""
|
||||||
|
touch {output}
|
||||||
|
"""
|
||||||
|
|
||||||
|
rule B:
|
||||||
|
input: a,
|
||||||
|
output: a,
|
||||||
|
b
|
||||||
|
params:
|
||||||
|
|
||||||
|
rule C:
|
||||||
|
# test dedent after variably nested nodes
|
||||||
|
params:
|
||||||
|
1
|
||||||
|
params:
|
||||||
|
"1"
|
||||||
|
params:
|
||||||
|
a = 1
|
||||||
|
params:
|
||||||
|
a = "1"
|
||||||
|
params:
|
||||||
|
a = call(1)
|
||||||
|
params:
|
||||||
|
a = call("1")
|
||||||
|
params:
|
||||||
|
a = config["a"]
|
||||||
|
params:
|
||||||
|
b = call(config["a"])
|
||||||
49
tests/indent/snakemake_spec.lua
Normal file
49
tests/indent/snakemake_spec.lua
Normal file
|
|
@ -0,0 +1,49 @@
|
||||||
|
local Runner = require('tests.indent.common').Runner
|
||||||
|
local XFAIL = require('tests.indent.common').XFAIL
|
||||||
|
|
||||||
|
local run = Runner:new(it, 'tests/indent/snakemake', {
|
||||||
|
tabstop = 4,
|
||||||
|
shiftwidth = 4,
|
||||||
|
softtabstop = 0,
|
||||||
|
expandtab = true,
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('indent Snakemake:', function()
|
||||||
|
describe('whole file:', function()
|
||||||
|
run:whole_file('.', {
|
||||||
|
expected_failures = {},
|
||||||
|
})
|
||||||
|
end)
|
||||||
|
|
||||||
|
describe('new line:', function()
|
||||||
|
run:new_line('blocks.smk', { on_line = 1, text = 'input: 1', indent = 4 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 2, text = 'input: 1', indent = 4 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 5, text = 'input: 1', indent = 8 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 6, text = 'input: 1', indent = 8 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 8, text = 'pass', indent = 0 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 10, text = 'pass', indent = 0 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 12, text = 'pass', indent = 4 })
|
||||||
|
run:new_line('blocks.smk', { on_line = 15, text = 'pass', indent = 4 })
|
||||||
|
run:new_line('directive_parameters.smk', { on_line = 4, text = 'before_a = 0,', indent = 8 })
|
||||||
|
run:new_line('directive_parameters.smk', { on_line = 5, text = 'after_a = 1.1,', indent = 8 })
|
||||||
|
run:new_line(
|
||||||
|
'directive_parameters.smk',
|
||||||
|
{ on_line = 7, text = '"""dedent_after_last_param"""', indent = 4 }
|
||||||
|
)
|
||||||
|
run:new_line(
|
||||||
|
'directive_parameters.smk',
|
||||||
|
{ on_line = 14, text = 'b = "indent_after_param_with_comma"', indent = 8 }
|
||||||
|
)
|
||||||
|
run:new_line(
|
||||||
|
'directive_parameters.smk',
|
||||||
|
{ on_line = 15, text = 'b = "indent_after_param_with_comma"', indent = 8 }
|
||||||
|
)
|
||||||
|
run:new_line(
|
||||||
|
'directive_parameters.smk',
|
||||||
|
{ on_line = 17, text = 'b = "indent_after_opening"', indent = 8 }
|
||||||
|
)
|
||||||
|
for _, line in ipairs({ 22, 24, 26, 28, 30, 32, 34, 36 }) do
|
||||||
|
run:new_line('directive_parameters.smk', { on_line = line, text = '"doc"', indent = 4 })
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue