Add comment textobject for surround selection and navigation (#1605)

This commit is contained in:
Daniel S Poulin 2022-03-06 00:24:24 -05:00 committed by GitHub
parent 7633c5acd3
commit 9bfb0caf1b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
17 changed files with 95 additions and 0 deletions

View File

@ -21,6 +21,8 @@ # Adding Textobject Queries
| `class.inside` | | `class.inside` |
| `class.around` | | `class.around` |
| `parameter.inside` | | `parameter.inside` |
| `comment.inside` |
| `comment.around` |
[Example query files][textobject-examples] can be found in the helix GitHub repository. [Example query files][textobject-examples] can be found in the helix GitHub repository.

View File

@ -270,6 +270,8 @@ #### Unimpaired
| `[c` | Go to previous class (**TS**) | `goto_prev_class` | | `[c` | Go to previous class (**TS**) | `goto_prev_class` |
| `]p` | Go to next parameter (**TS**) | `goto_next_parameter` | | `]p` | Go to next parameter (**TS**) | `goto_next_parameter` |
| `[p` | Go to previous parameter (**TS**) | `goto_prev_parameter` | | `[p` | Go to previous parameter (**TS**) | `goto_prev_parameter` |
| `]o` | Go to next comment (**TS**) | `goto_next_comment` |
| `[o` | Go to previous comment (**TS**) | `goto_prev_comment` |
| `[space` | Add newline above | `add_newline_above` | | `[space` | Add newline above | `add_newline_above` |
| `]space` | Add newline below | `add_newline_below` | | `]space` | Add newline below | `add_newline_below` |

View File

@ -69,6 +69,7 @@ ## Textobjects
| `f` | Function | | `f` | Function |
| `c` | Class | | `c` | Class |
| `p` | Parameter | | `p` | Parameter |
| `o` | Comment |
> NOTE: `f`, `c`, etc need a tree-sitter grammar active for the current > NOTE: `f`, `c`, etc need a tree-sitter grammar active for the current
document and a special tree-sitter query file to work properly. [Only document and a special tree-sitter query file to work properly. [Only

View File

@ -401,6 +401,8 @@ pub fn doc(&self) -> &str {
goto_prev_class, "Goto previous class", goto_prev_class, "Goto previous class",
goto_next_parameter, "Goto next parameter", goto_next_parameter, "Goto next parameter",
goto_prev_parameter, "Goto previous parameter", goto_prev_parameter, "Goto previous parameter",
goto_next_comment, "Goto next comment",
goto_prev_comment, "Goto previous comment",
dap_launch, "Launch debug target", dap_launch, "Launch debug target",
dap_toggle_breakpoint, "Toggle breakpoint", dap_toggle_breakpoint, "Toggle breakpoint",
dap_continue, "Continue program execution", dap_continue, "Continue program execution",
@ -5381,6 +5383,14 @@ fn goto_prev_parameter(cx: &mut Context) {
goto_ts_object_impl(cx, "parameter", Direction::Backward) goto_ts_object_impl(cx, "parameter", Direction::Backward)
} }
fn goto_next_comment(cx: &mut Context) {
goto_ts_object_impl(cx, "comment", Direction::Forward)
}
fn goto_prev_comment(cx: &mut Context) {
goto_ts_object_impl(cx, "comment", Direction::Backward)
}
fn select_textobject_around(cx: &mut Context) { fn select_textobject_around(cx: &mut Context) {
select_textobject(cx, textobject::TextObject::Around); select_textobject(cx, textobject::TextObject::Around);
} }
@ -5423,6 +5433,7 @@ fn select_textobject(cx: &mut Context, objtype: textobject::TextObject) {
'c' => textobject_treesitter("class", range), 'c' => textobject_treesitter("class", range),
'f' => textobject_treesitter("function", range), 'f' => textobject_treesitter("function", range),
'p' => textobject_treesitter("parameter", range), 'p' => textobject_treesitter("parameter", range),
'o' => textobject_treesitter("comment", range),
'm' => { 'm' => {
let ch = text.char(range.cursor(text)); let ch = text.char(range.cursor(text));
if !ch.is_ascii_alphanumeric() { if !ch.is_ascii_alphanumeric() {
@ -5456,6 +5467,7 @@ fn select_textobject(cx: &mut Context, objtype: textobject::TextObject) {
("c", "Class (tree-sitter)"), ("c", "Class (tree-sitter)"),
("f", "Function (tree-sitter)"), ("f", "Function (tree-sitter)"),
("p", "Parameter (tree-sitter)"), ("p", "Parameter (tree-sitter)"),
("o", "Comment (tree-sitter)"),
("m", "Matching delimiter under cursor"), ("m", "Matching delimiter under cursor"),
(" ", "... or any character acting as a pair"), (" ", "... or any character acting as a pair"),
]; ];

View File

@ -608,6 +608,7 @@ fn default() -> Self {
"f" => goto_prev_function, "f" => goto_prev_function,
"c" => goto_prev_class, "c" => goto_prev_class,
"p" => goto_prev_parameter, "p" => goto_prev_parameter,
"o" => goto_prev_comment,
"space" => add_newline_above, "space" => add_newline_above,
}, },
"]" => { "Right bracket" "]" => { "Right bracket"
@ -616,6 +617,7 @@ fn default() -> Self {
"f" => goto_next_function, "f" => goto_next_function,
"c" => goto_next_class, "c" => goto_next_class,
"p" => goto_next_parameter, "p" => goto_next_parameter,
"o" => goto_next_comment,
"space" => add_newline_below, "space" => add_newline_below,
}, },

View File

@ -11,3 +11,7 @@
body: (_) @class.inside) @class.around body: (_) @class.inside) @class.around
(parameter_declaration) @parameter.inside (parameter_declaration) @parameter.inside
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -1,3 +1,12 @@
(macro_def) @function.around (macro_def) @function.around
(argument) @parameter.inside (argument) @parameter.inside
[
(bracket_comment)
(line_comment)
] @comment.inside
(line_comment)+ @comment.around
(bracket_comment) @comment.around

View File

@ -1 +1,5 @@
(function_definition) @function.around (function_definition) @function.around
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -19,3 +19,7 @@
(argument_list (argument_list
(_) @parameter.inside) (_) @parameter.inside)
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -1,3 +1,12 @@
(basic_block) @function.around (basic_block) @function.around
(argument) @parameter.inside (argument) @parameter.inside
[
(comment)
(multiline_comment)
] @comment.inside
(comment)+ @comment.around
(multiline_comment) @comment.around

View File

@ -14,3 +14,7 @@
(array_vector_body) @class.inside) @class.around (array_vector_body) @class.inside) @class.around
(argument) @parameter.inside (argument) @parameter.inside
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -6,3 +6,12 @@
(argument (argument
(_) @parameter.inside) (_) @parameter.inside)
[
(comments)
(pod_statement)
] @comment.inside
(comments)+ @comment.around
(pod_statement) @comment.around

View File

@ -28,3 +28,7 @@
(variadic_parameter) (variadic_parameter)
(property_promotion_parameter) (property_promotion_parameter)
] @parameter.inside) ] @parameter.inside)
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -12,3 +12,7 @@
(argument_list (argument_list
(_) @parameter.inside) (_) @parameter.inside)
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -7,3 +7,10 @@
;---------- ;----------
(function body: (_) @function.inside) @function.around (function body: (_) @function.inside) @function.around
; Comments
;---------
(comment) @comment.inside
(comment)+ @comment.around

View File

@ -24,3 +24,12 @@
(arguments (arguments
(_) @parameter.inside) (_) @parameter.inside)
[
(line_comment)
(block_comment)
] @comment.inside
(line_comment)+ @comment.around
(block_comment) @comment.around

View File

@ -5,3 +5,12 @@
body: (_) @class.inside) @class.around body: (_) @class.inside) @class.around
(_ argument: _ @parameter.inside) (_ argument: _ @parameter.inside)
[
(comment)
(multiline_comment)
] @comment.inside
(comment)+ @comment.around
(multiline_comment) @comment.around