summaryrefslogtreecommitdiff
path: root/editors
diff options
context:
space:
mode:
authorRon Yorston2021-04-15 12:02:11 +0100
committerDenys Vlasenko2021-04-15 13:09:12 +0200
commit033fa3d5c65958a89fee155208ce8ac7f9049fcd (patch)
treedaa0c68e8cf9ac9a56271e81ac7b970f999eea12 /editors
parentd9d19896a9be5b5cf35d00cae61c9d5621044ccf (diff)
downloadbusybox-033fa3d5c65958a89fee155208ce8ac7f9049fcd.zip
busybox-033fa3d5c65958a89fee155208ce8ac7f9049fcd.tar.gz
vi: code shrink motion by paragraph
Use a hand-coded loop to search for paragraph boundaries instead of calling char_search(). We were using a loop anyway to skip consecutive newlines. function old new delta do_cmd 4792 4752 -40 ------------------------------------------------------------------------------ (add/remove: 0/0 grow/shrink: 0/1 up/down: 0/-40) Total: -40 bytes Signed-off-by: Ron Yorston <rmy@pobox.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'editors')
-rw-r--r--editors/vi.c27
1 files changed, 15 insertions, 12 deletions
diff --git a/editors/vi.c b/editors/vi.c
index f718972..d37357e 100644
--- a/editors/vi.c
+++ b/editors/vi.c
@@ -3636,21 +3636,24 @@ static void do_cmd(int c)
break;
case '{': // {- move backward paragraph
case '}': // }- move forward paragraph
+ dir = c == '}' ? FORWARD : BACK;
do {
- dir = c == '}' ? FORWARD : BACK;
- // skip over consecutive empty lines
- while ((dir == FORWARD ? dot < end - 1 : dot > text) &&
- *dot == '\n' && dot[dir] == '\n') {
+ int skip = TRUE; // initially skip consecutive empty lines
+ while (dir == FORWARD ? dot < end - 1 : dot > text) {
+ if (*dot == '\n' && dot[dir] == '\n') {
+ if (!skip) {
+ if (dir == FORWARD)
+ ++dot; // move to next blank line
+ goto dc2;
+ }
+ }
+ else {
+ skip = FALSE;
+ }
dot += dir;
}
- q = char_search(dot, "\n\n", ((unsigned)dir << 1) | FULL);
- if (q != NULL) { // found blank line
- dot = next_line(q); // move to next blank line
- }
- else { // blank line not found, move to end of file
- dot = dir == FORWARD ? end - 1 : text;
- break;
- }
+ goto dc6; // end of file
+ dc2: continue;
} while (--cmdcnt > 0);
break;
#endif /* FEATURE_VI_SEARCH */