summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/getchar.c14
-rw-r--r--src/normal.c5
-rw-r--r--src/version.c2
3 files changed, 12 insertions, 9 deletions
diff --git a/src/getchar.c b/src/getchar.c
index e623ce666..670520278 100644
--- a/src/getchar.c
+++ b/src/getchar.c
@@ -76,7 +76,7 @@ static int maphash_valid = FALSE;
*/
static mapblock_T *first_abbr = NULL; /* first entry in abbrlist */
-static int KeyNoremap = FALSE; /* remapping disabled */
+static int KeyNoremap = 0; /* remapping flags */
/*
* variables used by vgetorpeek() and flush_buffers()
@@ -1035,6 +1035,8 @@ ins_typebuf(str, noremap, offset, nottyped, silent)
/*
* Put character "c" back into the typeahead buffer.
* Can be used for a character obtained by vgetc() that needs to be put back.
+ * Uses cmd_silent, KeyTyped and KeyNoremap to restore the flags belonging to
+ * the char.
*/
void
ins_char_typebuf(c)
@@ -1061,7 +1063,7 @@ ins_char_typebuf(c)
buf[1] = NUL;
#endif
}
- (void)ins_typebuf(buf, REMAP_YES, 0, !KeyTyped, FALSE);
+ (void)ins_typebuf(buf, KeyNoremap, 0, !KeyTyped, cmd_silent);
}
/*
@@ -2270,9 +2272,8 @@ vgetorpeek(advance)
gotchars(typebuf.tb_buf
+ typebuf.tb_off, 1);
}
- KeyNoremap = (typebuf.tb_noremap[
- typebuf.tb_off]
- & (RM_NONE|RM_SCRIPT));
+ KeyNoremap = typebuf.tb_noremap[
+ typebuf.tb_off];
del_typebuf(1, 0);
}
break; /* got character, break for loop */
@@ -4196,7 +4197,8 @@ check_abbr(c, ptr, col, mincol)
if (typebuf.tb_no_abbr_cnt) /* abbrev. are not recursive */
return FALSE;
- if (KeyNoremap) /* no remapping implies no abbreviation */
+ if ((KeyNoremap & (RM_NONE|RM_SCRIPT)) != 0)
+ /* no remapping implies no abbreviation */
return FALSE;
/*
diff --git a/src/normal.c b/src/normal.c
index 94d98996b..bd4b1779d 100644
--- a/src/normal.c
+++ b/src/normal.c
@@ -651,9 +651,8 @@ normal_cmd(oap, toplevel)
/* Fake a "c"hange command. When "restart_edit" is set (e.g., because
* 'insertmode' is set) fake a "d"elete command, Insert mode will
* restart automatically.
- * Insert the typed character in the typeahead buffer, so that it will
- * be mapped in Insert mode. Required for ":lmap" to work. May cause
- * mapping a character from ":vnoremap"... */
+ * Insert the typed character in the typeahead buffer, so that it can
+ * be mapped in Insert mode. Required for ":lmap" to work. */
ins_char_typebuf(c);
if (restart_edit != 0)
c = 'd';
diff --git a/src/version.c b/src/version.c
index 531c12672..e20349dc9 100644
--- a/src/version.c
+++ b/src/version.c
@@ -667,6 +667,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 177,
+/**/
176,
/**/
175,