summaryrefslogtreecommitdiff
path: root/Src/Zle/zle_move.c
diff options
context:
space:
mode:
authorAxel Beckert <abe@deuxchevaux.org>2015-08-22 01:55:58 +0200
committerAxel Beckert <abe@deuxchevaux.org>2015-08-22 01:55:58 +0200
commit02f6e25bfcd5feb9a093377dda0dd549cdf5c309 (patch)
tree9a25e61122b3fa0d0a1ff68b5ef05c775ff78b1e /Src/Zle/zle_move.c
parente04a19735ffc8523b93b33074f685ad4e2c92e0c (diff)
parent881474edcb223ac22a08d81a824809c33ca3a9c9 (diff)
downloadzsh-02f6e25bfcd5feb9a093377dda0dd549cdf5c309.tar.gz
zsh-02f6e25bfcd5feb9a093377dda0dd549cdf5c309.zip
Merge tag 'zsh-5.0.8-test-2' into debian
Diffstat (limited to 'Src/Zle/zle_move.c')
-rw-r--r--Src/Zle/zle_move.c43
1 files changed, 31 insertions, 12 deletions
diff --git a/Src/Zle/zle_move.c b/Src/Zle/zle_move.c
index d751c4333..f49df8647 100644
--- a/Src/Zle/zle_move.c
+++ b/Src/Zle/zle_move.c
@@ -555,6 +555,13 @@ visuallinemode(UNUSED(char **args))
return 0;
}
+/**/
+int
+deactivateregion(UNUSED(char **args))
+{
+ region_active = 0;
+ return 0;
+}
/**/
int
@@ -876,24 +883,36 @@ int
vigotomark(UNUSED(char **args))
{
ZLE_INT_T ch;
+ int *markcs, *markhist = 0;
int oldcs = zlecs;
int oldline = histline;
+ int tmpcs, tmphist;
ch = getfullchar(0);
- if (ch == ZWC('\'') || ch == ZWC('`'))
- ch = 26;
- else {
- if (ch < ZWC('a') || ch > ZWC('z'))
- return 1;
- ch -= ZWC('a');
- }
- if (!vimarkline[ch])
- return 1;
- if (curhist != vimarkline[ch] && !zle_goto_hist(vimarkline[ch], 0, 0)) {
- vimarkline[ch] = 0;
+ if (ch == ZWC('\'') || ch == ZWC('`')) {
+ markhist = vimarkline + 26;
+ markcs = vimarkcs + 26;
+ } else if (ch == ZWC('.') && curchange->prev) {
+ /* position cursor where it was after the last change. not exactly
+ * what vim does but close enough */
+ tmpcs = curchange->prev->new_cs;
+ tmphist = curchange->prev->hist;
+ markcs = &tmpcs;
+ markhist = &tmphist;
+ } else if (ch >= ZWC('a') && ch <= ZWC('z')) {
+ markhist = vimarkline + (ch - ZWC('a'));
+ markcs = vimarkcs + (ch - ZWC('a'));
+ } else
return 1;
+ if (markhist) {
+ if (!*markhist)
+ return 1;
+ if (histline != *markhist && !zle_goto_hist(*markhist, 0, 0)) {
+ *markhist = 0;
+ return 1;
+ }
}
- zlecs = vimarkcs[ch];
+ zlecs = *markcs;
vimarkcs[26] = oldcs;
vimarkline[26] = oldline;
if (zlecs > zlell)