Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
PATCH: minor fixes to vi mode changes
- X-seq: zsh-workers 33860
- From: Oliver Kiddle <okiddle@xxxxxxxxxxx>
- To: Zsh workers <zsh-workers@xxxxxxx>
- Subject: PATCH: minor fixes to vi mode changes
- Date: Fri, 05 Dec 2014 15:54:22 +0100
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yahoo.co.uk; s=s2048; t=1417791263; bh=jJzXEFxlNg9vT1EkJ2Ze60aL3wMk0Aaa47RmPH+1U84=; h=From:To:Subject:Date:From:Subject; b=YewBfy5WzVlJVIWIbb1eG5jadyYs1f7r1GgdLpQidRC00LpBY7epGNxpt1fp0otSRGWqweUTEyT5yz6+cKyNyyxjC0vFJyCMDdiswdWBub2PvxqW5W8VXGn9XyvJ7033G23aMOiyY7kWYpSb0u8VFyxKMml3p1xwcRT0v7pOUAj8MW69zUjMvNW78geZHaKdUhLBoNcf6bH1P/8E8h9lD/YOHxilj1sMTrUGBi28tByY1+AljisztErE+vOqyBr+wYdv5L9QDbGmGsm3mmkE+qrCgONNFuYfvcNol9DuSkseNpqi1ERkjdANB0ghq3Jz24ia/Di0nePJWXe7aWgnpA==
- Domainkey-signature: a=rsa-sha1; q=dns; c=nofws; s=s2048; d=yahoo.co.uk; b=ew1Il0dV7m0b7ryJmnlhIQ6xSPv9q0SWnm7z+AA/MjErMywxlAtiTKFxpuW/2mBuZ8rcdIGRmFkYIN9SpPD7dgtzYqt54zeQbby7wpXM1cd1lPkOMkyXnvp+Oo0Yyxpt2Z8AI50fCLkN2IUJbmqsMTLHRFJcd5wjyHi+yjw3MlHrF1lKiFKx2ScwP2LUirqTiNX5ulgEzBWNus074/VR0n3udbNjU+1/241YKludz8a2bPNU5P75VgUQd8C102PPVhHD4UlpTr2xWrORHLPgQBw0MYx7GVuZeyBIrWKZxEd3L85P4gX0TfXj3oHHLP7QTblTZEjQ7mT1c1qeW3EOQg==;
- List-help: <mailto:zsh-workers-help@zsh.org>
- List-id: Zsh Workers List <zsh-workers.zsh.org>
- List-post: <mailto:zsh-workers@zsh.org>
- Mailing-list: contact zsh-workers-help@xxxxxxx; run by ezmlm
This patch tidies up some loose ends with the vi-mode changes.
There's a couple of fixes for combining characters. I've changed
vi-match-bracket to use the general mechanisms that are now there for
text objects instead of getvirange needing to special case it. vi-join
had trouble with the final line of the buffer. And theres some fixes to
prevent attempts to yank an empty buffer.
Oliver
diff --git a/Src/Zle/textobjects.c b/Src/Zle/textobjects.c
index 85d014b..7f049c5 100644
--- a/Src/Zle/textobjects.c
+++ b/Src/Zle/textobjects.c
@@ -286,7 +286,6 @@ selectargument(UNUSED(char **args))
/* convert offsets for mark and zlecs back to ZLE internal format */
linein[wend] = '\0'; /* a bit of a hack to get two offsets */
free(stringaszleline(linein, wstarts[wcur], &zlecs, &tmpsz, &mark));
- free(linein);
if (bindk == t_selectinshellword) {
ZLE_CHAR_T *match = ZWS("`\'\"");
diff --git a/Src/Zle/zle_misc.c b/Src/Zle/zle_misc.c
index d432acf..a1dc3fa 100644
--- a/Src/Zle/zle_misc.c
+++ b/Src/Zle/zle_misc.c
@@ -476,11 +476,9 @@ killregion(UNUSED(char **args))
foredel(1, 0);
vifirstnonblank(zlenoargs);
}
- } else if (mark > zlecs) {
- if (invicmdmode())
- INCPOS(mark);
- forekill(mark - zlecs, CUT_RAW);
- } else {
+ } else if (mark > zlecs)
+ forekill(mark - zlecs + invicmdmode(), CUT_RAW);
+ else {
if (invicmdmode())
INCCS();
backkill(zlecs - mark, CUT_FRONT|CUT_RAW);
@@ -492,7 +490,6 @@ killregion(UNUSED(char **args))
int
copyregionaskill(char **args)
{
- int start, end;
if (*args) {
int len;
ZLE_STRING_T line = stringaszleline(*args, 0, &len, NULL, NULL);
@@ -501,16 +498,10 @@ copyregionaskill(char **args)
} else {
if (mark > zlell)
mark = zlell;
- if (mark > zlecs) {
- start = zlecs;
- end = mark;
- } else {
- start = mark;
- end = zlecs;
- }
- if (invicmdmode())
- INCPOS(end);
- cut(start, end - start, mark > zlecs ? 0 : CUT_FRONT);
+ if (mark > zlecs)
+ cut(zlecs, mark - zlecs + invicmdmode(), 0);
+ else
+ cut(mark, zlecs - mark + invicmdmode(), CUT_FRONT);
}
return 0;
}
@@ -1066,9 +1057,7 @@ quoteregion(UNUSED(char **args))
mark = zlecs;
zlecs = tmp;
}
- if (extra)
- INCPOS(mark);
- str = (ZLE_STRING_T)hcalloc((len = mark - zlecs) *
+ str = (ZLE_STRING_T)hcalloc((len = mark - zlecs + extra) *
ZLE_CHAR_SIZE);
ZS_memcpy(str, zleline + zlecs, len);
foredel(len, CUT_RAW);
diff --git a/Src/Zle/zle_move.c b/Src/Zle/zle_move.c
index 939cfb1..fad6b0a 100644
--- a/Src/Zle/zle_move.c
+++ b/Src/Zle/zle_move.c
@@ -575,8 +575,7 @@ vimatchbracket(UNUSED(char **args))
if ((zlecs == zlell || zleline[zlecs] == '\n') && zlecs > 0)
DECCS();
- if (virangeflag)
- mark = zlecs;
+
otog:
if (zlecs == zlell || zleline[zlecs] == '\n') {
zlecs = ocs;
@@ -588,6 +587,7 @@ vimatchbracket(UNUSED(char **args))
oth = '}';
break;
case /*{*/ '}':
+ virangeflag = -virangeflag;
dir = -1;
oth = '{'; /*}*/
break;
@@ -596,6 +596,7 @@ vimatchbracket(UNUSED(char **args))
oth = ')';
break;
case ')':
+ virangeflag = -virangeflag;
dir = -1;
oth = '(';
break;
@@ -604,6 +605,7 @@ vimatchbracket(UNUSED(char **args))
oth = ']';
break;
case ']':
+ virangeflag = -virangeflag;
dir = -1;
oth = '[';
break;
@@ -611,8 +613,6 @@ vimatchbracket(UNUSED(char **args))
INCCS();
goto otog;
}
- if (virangeflag && dir < 0)
- INCPOS(mark); /* include starting position when going backwards */
ct = 1;
while (zlecs >= 0 && zlecs < zlell && ct) {
if (dir < 0)
@@ -636,7 +636,7 @@ vimatchbracket(UNUSED(char **args))
int
viforwardchar(char **args)
{
- int lim = findeol();
+ int lim = findeol() - invicmdmode() + virangeflag;
int n = zmult;
if (n < 0) {
@@ -646,8 +646,6 @@ viforwardchar(char **args)
zmult = n;
return ret;
}
- if (invicmdmode() && !virangeflag)
- DECPOS(lim);
if (zlecs >= lim)
return 1;
while (n-- && zlecs < lim)
diff --git a/Src/Zle/zle_vi.c b/Src/Zle/zle_vi.c
index 249e38f..e9a3676 100644
--- a/Src/Zle/zle_vi.c
+++ b/Src/Zle/zle_vi.c
@@ -167,8 +167,6 @@ getvirange(int wf)
Thingy k2;
if (visual) {
- if (!zlell)
- return -1;
pos = mark;
vilinerange = (visual == 2);
region_active = 0;
@@ -181,15 +179,17 @@ getvirange(int wf)
if (km)
selectlocalmap(km);
/* Now we need to execute the movement command, to see where it *
- * actually goes. virangeflag here indicates to the movement *
- * function that it should place the cursor at the end of the *
- * range, rather than where the cursor would actually go if it *
- * were executed normally. This makes a difference to some *
- * commands, but not all. For example, if searching forward *
- * for a character, under normal circumstances the cursor lands *
- * on the character. For a range, the range must include the *
- * character, so the cursor gets placed after the character if *
- * virangeflag is set. */
+ * actually goes. virangeflag here indicates to the movement *
+ * function that it should place the cursor at the end of the *
+ * range, rather than where the cursor would actually go if it *
+ * were executed normally. This makes a difference to some *
+ * commands, but not all. For example, if searching forward *
+ * for a character, under normal circumstances the cursor lands *
+ * on the character. For a range, the range must include the *
+ * character, so the cursor gets placed after the character if *
+ * virangeflag is set. vi-match-bracket needs to change the *
+ * value of virangeflag under some circumstances, meaning that *
+ * we need to change the *starting* position. */
zmod.flags &= ~MOD_TMULT;
do {
vilinerange = 0;
@@ -202,10 +202,10 @@ getvirange(int wf)
return -1;
}
/*
- * With k2 == bindk, the command key is repeated:
- * a number of lines is used. If the function used
- * returns 1, we fail.
- */
+ * With k2 == bindk, the command key is repeated:
+ * a number of lines is used. If the function used
+ * returns 1, we fail.
+ */
if ((k2 == bindk) ? dovilinerange() : execzlefunc(k2, zlenoargs, 1))
ret = -1;
if(vichgrepeat)
@@ -217,8 +217,8 @@ getvirange(int wf)
selectlocalmap(NULL);
/* It is an error to use a non-movement command to delimit the *
- * range. We here reject the case where the command modified *
- * the line, or selected a different history line. */
+ * range. We here reject the case where the command modified *
+ * the line, or selected a different history line. */
if (histline != hist1 || zlell != lastll || memcmp(zleline, lastline, zlell)) {
histline = hist1;
ZS_memcpy(zleline, lastline, zlell = lastll);
@@ -228,16 +228,21 @@ getvirange(int wf)
}
/* Can't handle an empty file. Also, if the movement command *
- * failed, or didn't move, it is an error. */
- if (!zlell || (zlecs == pos && (mark == -1 || mark == zlecs) &&
- virangeflag != 2) || ret == -1) {
+ * failed, or didn't move, it is an error. */
+ if (!zlell || (zlecs == pos && mark == -1 && virangeflag != 2) || ret == -1) {
mark = mpos;
return -1;
}
+
+ /* vi-match-bracket changes the value of virangeflag when *
+ * moving to the opening bracket, meaning that we need to *
+ * change the *starting* position. */
+ if (virangeflag == -1)
+ INCPOS(pos);
virangeflag = 0;
/* if the mark has moved, ignore the original cursor position *
- * and use the mark. */
+ * and use the mark. */
if (mark != -1)
pos = mark;
}
@@ -878,7 +883,7 @@ vijoin(UNUSED(char **args))
} else if ((x = findeol()) == zlell || (visual && x >= mark))
return 1;
- do {
+ while (n) {
zlecs = x + 1;
pos = zlecs;
for (; zlecs != zlell && ZC_iblank(zleline[zlecs]); INCPOS(zlecs))
@@ -890,13 +895,14 @@ vijoin(UNUSED(char **args))
DECPOS(pos);
if (ZC_iblank(zleline[pos])) {
zlecs = pos;
- continue;
+ return 0;
}
}
spaceinline(1);
zleline[zlecs] = ZWC(' ');
- } while (!((!visual && --n < 2) || (x = findeol()) == zlell || (visual && x >= mark)));
-
+ if ((!visual && --n < 2) || (x = findeol()) == zlell || (visual && x >= mark))
+ return 0;
+ }
return 0;
}
diff --git a/Test/X02zlevi.ztst b/Test/X02zlevi.ztst
index 5204311..8f93902 100644
--- a/Test/X02zlevi.ztst
+++ b/Test/X02zlevi.ztst
@@ -317,16 +317,6 @@
>BUFFER: bhello
>CURSOR: 5
- zletest $'old\C-w\evyvP'
-0:yank empty selection
->BUFFER: old
->CURSOR: 2
-
- zletest $'old\C-w\evdvP'
-0:delete empty selection
->BUFFER: old
->CURSOR: 2
-
zletest $'one\eotwo\eyykVp'
0:yank linewise and put over linewise selection at start of buffer
>BUFFER: two
Messages sorted by:
Reverse Date,
Date,
Thread,
Author