summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-03-04 22:52:34 +0100
committerBram Moolenaar <Bram@vim.org>2016-03-04 22:52:34 +0100
commit179f1b9a7ddf3624daf6380c3dad740e0a1ba361 (patch)
tree3629363a7337081e627d6838913207ab0281cfd4
parent328da0dcb7be34b594725eef6dc98d3ea6516d69 (diff)
downloadvim-git-179f1b9a7ddf3624daf6380c3dad740e0a1ba361.tar.gz
patch 7.4.1488v7.4.1488
Problem: Not using key when result from hangul_string_convert() is NULL. Solution: Fall back to not converted string.
-rw-r--r--src/ui.c22
-rw-r--r--src/version.c2
2 files changed, 13 insertions, 11 deletions
diff --git a/src/ui.c b/src/ui.c
index 3e8875851..875be1b30 100644
--- a/src/ui.c
+++ b/src/ui.c
@@ -1686,24 +1686,24 @@ add_to_input_buf_csi(char_u *str, int len)
push_raw_key(char_u *s, int len)
{
char_u *tmpbuf;
+ char_u *inp = s;
+ /* use the conversion result if possible */
tmpbuf = hangul_string_convert(s, &len);
if (tmpbuf != NULL)
- {
- s = tmpbuf;
+ inp = tmpbuf;
- for (; len--; s++)
+ for (; len--; inp++)
+ {
+ inbuf[inbufcount++] = *inp;
+ if (*inp == CSI)
{
- inbuf[inbufcount++] = *s;
- if (*s == CSI)
- {
- /* Turn CSI into K_CSI. */
- inbuf[inbufcount++] = KS_EXTRA;
- inbuf[inbufcount++] = (int)KE_CSI;
- }
+ /* Turn CSI into K_CSI. */
+ inbuf[inbufcount++] = KS_EXTRA;
+ inbuf[inbufcount++] = (int)KE_CSI;
}
- vim_free(tmpbuf);
}
+ vim_free(tmpbuf);
}
#endif
diff --git a/src/version.c b/src/version.c
index 3623a099f..17fd8883c 100644
--- a/src/version.c
+++ b/src/version.c
@@ -744,6 +744,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1488,
+/**/
1487,
/**/
1486,