aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc André Tanner <mat@brain-dump.org>2014-09-25 11:31:38 +0200
committerMarc André Tanner <mat@brain-dump.org>2014-09-25 11:31:38 +0200
commit5d43998c54d35358d154ad99add19cd1130f9f3e (patch)
treed9069a1285cc179a99eb9d60d918f2b88b8667f4
parentd8bf6b83391edb8be69ce390e788785ddb0b806f (diff)
downloadvis-5d43998c54d35358d154ad99add19cd1130f9f3e.tar.gz
vis-5d43998c54d35358d154ad99add19cd1130f9f3e.tar.xz
Revert "Change semantics of text_line_end"
This reverts commit 3a24e6a5562e4b1ea456fbe36607bd8a9c92744d.
-rw-r--r--text-motions.c4
-rw-r--r--text-motions.h4
-rw-r--r--vis.c6
3 files changed, 7 insertions, 7 deletions
diff --git a/text-motions.c b/text-motions.c
index b215ffc..69afcc7 100644
--- a/text-motions.c
+++ b/text-motions.c
@@ -119,7 +119,9 @@ size_t text_line_start(Text *txt, size_t pos) {
size_t text_line_finish(Text *txt, size_t pos) {
char c;
Iterator it = text_iterator_get(txt, text_line_end(txt, pos));
+ do text_iterator_byte_prev(&it, NULL);
while (text_iterator_byte_get(&it, &c) && c != '\n' && isspace(c));
+ if (!ISUTF8(c))
text_iterator_char_prev(&it, NULL);
return it.pos;
}
@@ -129,8 +131,6 @@ size_t text_line_end(Text *txt, size_t pos) {
Iterator it = text_iterator_get(txt, pos);
while (text_iterator_byte_get(&it, &c) && c != '\r' && c != '\n')
text_iterator_byte_next(&it, NULL);
- if (text_iterator_char_prev(&it, &c) && c == '\n')
- text_iterator_byte_next(&it, NULL);
return it.pos;
}
diff --git a/text-motions.h b/text-motions.h
index 82450f6..18457a5 100644
--- a/text-motions.h
+++ b/text-motions.h
@@ -24,8 +24,8 @@ size_t text_find_char_prev(Text*, size_t pos, const char *s, size_t len);
/* begin finish next
* v v v
* [\r]\n I am a line! [\r]\n
- * ^ ^ ^
- * prev start end
+ * ^ ^ ^
+ * prev start end
*/
size_t text_line_prev(Text*, size_t pos);
size_t text_line_begin(Text*, size_t pos);
diff --git a/vis.c b/vis.c
index 17b7cf2..b2e9360 100644
--- a/vis.c
+++ b/vis.c
@@ -263,7 +263,7 @@ static Movement moves[] = {
[MOVE_LINE_BEGIN] = { .txt = text_line_begin, .type = LINEWISE },
[MOVE_LINE_START] = { .txt = text_line_start, .type = LINEWISE },
[MOVE_LINE_FINISH] = { .txt = text_line_finish, .type = LINEWISE },
- [MOVE_LINE_END] = { .txt = text_line_end, .type = LINEWISE|INCLUSIVE },
+ [MOVE_LINE_END] = { .txt = text_line_end, .type = LINEWISE },
[MOVE_LINE_NEXT] = { .txt = text_line_next, .type = LINEWISE },
[MOVE_LINE] = { .cmd = line, .type = LINEWISE|IDEMPOTENT},
[MOVE_COLUMN] = { .cmd = column, .type = CHARWISE|IDEMPOTENT},
@@ -936,7 +936,7 @@ static void joinline(const Arg *arg) {
Text *txt = vis->win->text;
size_t pos = window_cursor_get(vis->win->win), start, end;
if (arg->i == MOVE_LINE_NEXT) {
- start = text_line_prev(txt, text_line_next(txt, pos));
+ start = text_line_end(txt, pos);
end = text_line_next(txt, pos);
} else {
end = text_line_begin(txt, pos);
@@ -997,7 +997,7 @@ static void action_do(Action *a) {
Filerange sel = window_selection_get(win);
sel.end = text_char_prev(txt, sel.end);
size_t start = text_line_begin(txt, sel.start);
- size_t end = text_line_prev(txt, text_line_next(txt, sel.end));
+ size_t end = text_line_end(txt, sel.end);
if (sel.start == pos) { /* extend selection upwards */
sel.end = start;
sel.start = end;