mirror of
https://github.com/vim/vim.git
synced 2025-10-02 05:04:20 -04:00
patch 8.0.1069: still get CTRL-X sometimes
Problem: Still get CTRL-X sometimes for t_RS request. Solution: Also skip 0x18 after a key code response.
This commit is contained in:
12
src/term.c
12
src/term.c
@@ -4741,9 +4741,10 @@ check_termcode(
|
||||
key_name[0] = (int)KS_EXTRA;
|
||||
key_name[1] = (int)KE_IGNORE;
|
||||
slen = i + 1 + (tp[i] == ESC);
|
||||
if (tp[i] == 0x07 && i + 1 < len && tp[i + 1] == 0x18)
|
||||
/* Sometimes the 0x07 is followed by 0x18, unclear
|
||||
* when this happens. */
|
||||
if (rcs_status == STATUS_SENT
|
||||
&& slen < len && tp[slen] == 0x18)
|
||||
/* Some older xterm send 0x18 for the T_RS request,
|
||||
* skip it here. */
|
||||
++slen;
|
||||
# ifdef FEAT_EVAL
|
||||
set_vim_var_string(VV_TERMRGBRESP, tp, slen);
|
||||
@@ -4793,6 +4794,11 @@ check_termcode(
|
||||
key_name[0] = (int)KS_EXTRA;
|
||||
key_name[1] = (int)KE_IGNORE;
|
||||
slen = i + 1 + (tp[i] == ESC);
|
||||
if (rcs_status == STATUS_SENT
|
||||
&& slen < len && tp[slen] == 0x18)
|
||||
/* Some older xterm send 0x18 for the T_RS request,
|
||||
* skip it here. */
|
||||
++slen;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@@ -769,6 +769,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1069,
|
||||
/**/
|
||||
1068,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user