diff options
| author | Marc André Tanner <mat@brain-dump.org> | 2015-08-01 19:50:56 +0200 |
|---|---|---|
| committer | Marc André Tanner <mat@brain-dump.org> | 2015-08-02 00:13:51 +0200 |
| commit | dec8bc0015c9fc0e6f4283557cb088718348ec80 (patch) | |
| tree | 2ea272cd29595a2810d4801244899bd34067729e | |
| parent | dd3a6e2d9487c970fd007989833fc68a3261183a (diff) | |
| download | vis-dec8bc0015c9fc0e6f4283557cb088718348ec80.tar.gz vis-dec8bc0015c9fc0e6f4283557cb088718348ec80.tar.xz | |
vis: add text objects `af` and `if`
They try to match C-like function definitions. The inner variant
only contains the function body.
| -rw-r--r-- | config.def.h | 2 | ||||
| -rw-r--r-- | text-objects.c | 19 | ||||
| -rw-r--r-- | text-objects.h | 4 | ||||
| -rw-r--r-- | vis.c | 4 |
4 files changed, 29 insertions, 0 deletions
diff --git a/config.def.h b/config.def.h index 910e1e7..a2eabee 100644 --- a/config.def.h +++ b/config.def.h @@ -170,6 +170,7 @@ static KeyBinding vis_textobjs[] = { { { NONE('a'), NONE('\'') }, textobj, { .i = TEXT_OBJ_OUTER_SINGLE_QUOTE } }, { { NONE('a'), NONE('`') }, textobj, { .i = TEXT_OBJ_OUTER_BACKTICK } }, { { NONE('a'), NONE('e') }, textobj, { .i = TEXT_OBJ_OUTER_ENTIRE } }, + { { NONE('a'), NONE('f') }, textobj, { .i = TEXT_OBJ_OUTER_FUNCTION } }, { /* empty last element, array terminator */ }, }; @@ -192,6 +193,7 @@ static KeyBinding vis_inner_textobjs[] = { { { NONE('i'), NONE('\'') }, textobj, { .i = TEXT_OBJ_INNER_SINGLE_QUOTE } }, { { NONE('i'), NONE('`') }, textobj, { .i = TEXT_OBJ_INNER_BACKTICK } }, { { NONE('i'), NONE('e') }, textobj, { .i = TEXT_OBJ_INNER_ENTIRE } }, + { { NONE('i'), NONE('f') }, textobj, { .i = TEXT_OBJ_INNER_FUNCTION } }, { /* empty last element, array terminator */ }, }; diff --git a/text-objects.c b/text-objects.c index 0308e8c..9f646dc 100644 --- a/text-objects.c +++ b/text-objects.c @@ -235,6 +235,25 @@ Filerange text_object_paragraph(Text *txt, size_t pos) { return r; } +Filerange text_object_function(Text *txt, size_t pos) { + size_t a = text_function_start_prev(txt, pos); + size_t b = text_function_end_next(txt, pos); + if (text_function_end_next(txt, a) == b) { + Filerange r = text_range_new(a, b+1); + return text_range_linewise(txt, &r); + } + return text_range_empty(); +} + +Filerange text_object_function_inner(Text *txt, size_t pos) { + Filerange r = text_object_function(txt, pos); + if (!text_range_valid(&r)) + return r; + size_t b = text_function_end_next(txt, pos); + size_t a = text_bracket_match(txt, b); + return text_range_new(a+1, b-1); +} + static Filerange text_object_bracket(Text *txt, size_t pos, char type) { char c, open, close; int opened = 1, closed = 1; diff --git a/text-objects.h b/text-objects.h index fb35d13..1ff728a 100644 --- a/text-objects.h +++ b/text-objects.h @@ -29,6 +29,10 @@ Filerange text_object_line(Text*, size_t pos); Filerange text_object_sentence(Text*, size_t pos); Filerange text_object_paragraph(Text*, size_t pos); +/* C like function definition */ +Filerange text_object_function(Text*, size_t pos); +/* inner variant only contains the function body */ +Filerange text_object_function_inner(Text*, size_t pos); /* these are inner text objects i.e. the delimiters themself are not * included in the range */ Filerange text_object_square_bracket(Text*, size_t pos); @@ -257,6 +257,8 @@ enum { TEXT_OBJ_INNER_BACKTICK, TEXT_OBJ_OUTER_ENTIRE, TEXT_OBJ_INNER_ENTIRE, + TEXT_OBJ_OUTER_FUNCTION, + TEXT_OBJ_INNER_FUNCTION, }; static TextObject textobjs[] = { @@ -282,6 +284,8 @@ static TextObject textobjs[] = { [TEXT_OBJ_INNER_BACKTICK] = { text_object_backtick, INNER }, [TEXT_OBJ_OUTER_ENTIRE] = { text_object_entire, }, [TEXT_OBJ_INNER_ENTIRE] = { text_object_entire_inner, }, + [TEXT_OBJ_OUTER_FUNCTION] = { text_object_function, }, + [TEXT_OBJ_INNER_FUNCTION] = { text_object_function_inner, }, }; /** functions to be called from keybindings */ |
