summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2013-05-15 14:22:41 +0200
committerBram Moolenaar <Bram@vim.org>2013-05-15 14:22:41 +0200
commit46a7561f3a151fefc469225d41822dd0be292f98 (patch)
treeac16453264c802547562c7a6d99bd1b2d301c59c
parentdfa38d4e45a4a64c6b2a84c1d4c91b153f43a86d (diff)
downloadvim-46a7561f3a151fefc469225d41822dd0be292f98.zip
updated for version 7.3.946
Problem: Sometimes get stuck in waiting for cursor position report, resulting in keys starting with <Esc>[ not working. Solution: Only wait for more characters after <Esc>[ if followed by '?', '>' or a digit.
-rw-r--r--src/term.c10
-rw-r--r--src/version.c2
2 files changed, 10 insertions, 2 deletions
diff --git a/src/term.c b/src/term.c
index 97bf62ac4..003dd8b1a 100644
--- a/src/term.c
+++ b/src/term.c
@@ -4126,9 +4126,11 @@ check_termcode(max_offset, buf, bufsize, buflen)
* The final byte is 'R'. now it is only used for checking for
* ambiguous-width character state.
*/
+ p = tp[0] == CSI ? tp + 1 : tp + 2;
if ((*T_CRV != NUL || *T_U7 != NUL)
&& ((tp[0] == ESC && tp[1] == '[' && len >= 3)
- || (tp[0] == CSI && len >= 2)))
+ || (tp[0] == CSI && len >= 2))
+ && (VIM_ISDIGIT(*p) || *p == '>' || *p == '?'))
{
j = 0;
extra = 0;
@@ -4136,7 +4138,7 @@ check_termcode(max_offset, buf, bufsize, buflen)
&& !(tp[i] >= '{' && tp[i] <= '~')
&& !ASCII_ISALPHA(tp[i]); ++i)
if (tp[i] == ';' && ++j == 1)
- extra = atoi((char *)tp + i + 1);
+ extra = i + 1;
if (i == len)
return -1; /* not enough characters */
@@ -4150,6 +4152,8 @@ check_termcode(max_offset, buf, bufsize, buflen)
# ifdef FEAT_AUTOCMD
did_cursorhold = TRUE;
# endif
+ if (extra > 0)
+ extra = atoi((char *)tp + extra);
if (extra == 2)
aw = "single";
else if (extra == 3)
@@ -4178,6 +4182,8 @@ check_termcode(max_offset, buf, bufsize, buflen)
/* rxvt sends its version number: "20703" is 2.7.3.
* Ignore it for when the user has set 'term' to xterm,
* even though it's an rxvt. */
+ if (extra > 0)
+ extra = atoi((char *)tp + extra);
if (extra > 20000)
extra = 0;
diff --git a/src/version.c b/src/version.c
index 76d652079..5e5dbc4b6 100644
--- a/src/version.c
+++ b/src/version.c
@@ -729,6 +729,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 946,
+/**/
945,
/**/
944,