aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--text-objects.c13
-rw-r--r--text-objects.h2
2 files changed, 15 insertions, 0 deletions
diff --git a/text-objects.c b/text-objects.c
index a5d5d1c..b5dec88 100644
--- a/text-objects.c
+++ b/text-objects.c
@@ -287,6 +287,19 @@ Filerange text_object_backtick(Text *txt, size_t pos) {
return text_object_bracket(txt, pos, '`');
}
+Filerange text_object_range(Text *txt, size_t pos, int (*isboundary)(int)) {
+ char c;
+ size_t start;
+ Iterator it = text_iterator_get(txt, pos);
+ if (!text_iterator_byte_get(&it, &c) || boundary(c))
+ return text_range_empty();
+ do start = it.pos; while (text_iterator_char_prev(&it, &c) && !boundary(c));
+ it = text_iterator_get(txt, pos);
+ text_iterator_byte_get(&it, &c);
+ while (!boundary(c) && text_iterator_byte_next(&it, &c));
+ return text_range_new(start, it.pos);
+}
+
Filerange text_range_linewise(Text *txt, Filerange *rin) {
Filerange rout = *rin;
rout.start = text_line_begin(txt, rin->start);
diff --git a/text-objects.h b/text-objects.h
index 5781b51..127b127 100644
--- a/text-objects.h
+++ b/text-objects.h
@@ -43,6 +43,8 @@ Filerange text_object_paranthese(Text*, size_t pos);
Filerange text_object_quote(Text*, size_t pos);
Filerange text_object_single_quote(Text*, size_t pos);
Filerange text_object_backtick(Text*, size_t pos);
+/* text object delimited by arbitrary chars for which isboundary returns non-zero */
+Filerange text_object_range(Text*, size_t pos, int (*isboundary)(int));
/* extend a range to cover whole lines */
Filerange text_range_linewise(Text*, Filerange*);