mirror of
https://github.com/helix-editor/helix.git
synced 2024-11-27 03:43:29 +04:00
58758fee61
* WIP: Rework indentation system * Add ComplexNode for context-aware indentation (including a proof of concept for assignment statements in rust) * Add switch statements to Go indents.toml (fixes the second half of issue #1523) Remove commented-out code * Migrate all existing indentation queries. Add more options to ComplexNode and use them to improve C/C++ indentation. * Add comments & replace Option<Vec<_>> with Vec<_> * Add more detailed documentation for tree-sitter indentation * Improve code style in indent.rs * Use tree-sitter queries for indentation instead of TOML config. Migrate existing indent queries. * Add documentation for the new indent queries. Change xtask docgen to look for indents.scm instead of indents.toml * Improve code style in indent.rs. Fix an issue with the rust indent query. * Move indentation test sources to separate files. Add `#not-kind-eq?`, `#same-line?` and `#not-same-line` custom predicates. Improve the rust and c indent queries. * Fix indent test. Improve rust indent queries. * Move indentation tests to integration test folder. * Improve code style in indent.rs. Reuse tree-sitter cursors for indentation queries. * Migrate HCL indent query * Replace custom loading in indent tests with a designated languages.toml * Update indent query file name for --health command. * Fix single-space formatting in indent queries. * Add explanation for unwrapping. Co-authored-by: Triton171 <triton0171@gmail.com>
81 lines
1.7 KiB
Scheme
81 lines
1.7 KiB
Scheme
[
|
|
(use_list)
|
|
(block)
|
|
(match_block)
|
|
(arguments)
|
|
(parameters)
|
|
(declaration_list)
|
|
(field_declaration_list)
|
|
(field_initializer_list)
|
|
(struct_pattern)
|
|
(tuple_pattern)
|
|
(unit_expression)
|
|
(enum_variant_list)
|
|
(call_expression)
|
|
(binary_expression)
|
|
(field_expression)
|
|
(tuple_expression)
|
|
(array_expression)
|
|
(where_clause)
|
|
|
|
(token_tree)
|
|
(macro_definition)
|
|
(token_tree_pattern)
|
|
(token_repetition)
|
|
] @indent
|
|
|
|
[
|
|
"}"
|
|
"]"
|
|
")"
|
|
] @outdent
|
|
|
|
; Indent the right side of assignments.
|
|
; The #not-same-line? predicate is required to prevent an extra indent for e.g.
|
|
; an else-clause where the previous if-clause starts on the same line as the assignment.
|
|
(assignment_expression
|
|
.
|
|
(_) @expr-start
|
|
right: (_) @indent
|
|
(#not-same-line? @indent @expr-start)
|
|
(#set! "scope" "all")
|
|
)
|
|
(compound_assignment_expr
|
|
.
|
|
(_) @expr-start
|
|
right: (_) @indent
|
|
(#not-same-line? @indent @expr-start)
|
|
(#set! "scope" "all")
|
|
)
|
|
(let_declaration
|
|
.
|
|
(_) @expr-start
|
|
value: (_) @indent
|
|
(#not-same-line? @indent @expr-start)
|
|
(#set! "scope" "all")
|
|
)
|
|
(if_let_expression
|
|
.
|
|
(_) @expr-start
|
|
value: (_) @indent
|
|
(#not-same-line? @indent @expr-start)
|
|
(#set! "scope" "all")
|
|
)
|
|
(static_item
|
|
.
|
|
(_) @expr-start
|
|
value: (_) @indent
|
|
(#not-same-line? @indent @expr-start)
|
|
(#set! "scope" "all")
|
|
)
|
|
|
|
; Some field expressions where the left part is a multiline expression are not
|
|
; indented by cargo fmt.
|
|
; Because this multiline expression might be nested in an arbitrary number of
|
|
; field expressions, this can only be matched using a Regex.
|
|
(field_expression
|
|
value: (_) @val
|
|
"." @outdent
|
|
(#match? @val "(\\A[^\\n\\r]+\\([\\t ]*(\\n|\\r).*)|(\\A[^\\n\\r]*\\{[\\t ]*(\\n|\\r))")
|
|
)
|