Cygwin: pty: Fix a bug regarding ESC[?3h and ESC[?3l handling.
- Midnight commander (mc) does not work after the commit
1626569222
as reported in
https://www.cygwin.com/ml/cygwin/2019-12/msg00173.html.
This patch fixes the issue.
This commit is contained in:
parent
91f1eab9a9
commit
fe512b2b12
|
@ -1262,16 +1262,19 @@ fhandler_pty_slave::push_to_pcon_screenbuffer (const char *ptr, size_t len)
|
||||||
while ((p0 = (char *) memmem (p0, nlen - (p0 - buf), "\033[?", 3)))
|
while ((p0 = (char *) memmem (p0, nlen - (p0 - buf), "\033[?", 3)))
|
||||||
{
|
{
|
||||||
p0 += 3;
|
p0 += 3;
|
||||||
while (p0 < buf + nlen && *p0 != 'h' && *p0 != 'l')
|
bool exist_arg_3 = false;
|
||||||
|
while (p0 < buf + nlen && !isalpha (*p0))
|
||||||
{
|
{
|
||||||
int arg = 0;
|
int arg = 0;
|
||||||
while (p0 < buf + nlen && isdigit (*p0))
|
while (p0 < buf + nlen && isdigit (*p0))
|
||||||
arg = arg * 10 + (*p0 ++) - '0';
|
arg = arg * 10 + (*p0 ++) - '0';
|
||||||
if (arg == 3)
|
if (arg == 3)
|
||||||
get_ttyp ()->need_redraw_screen = true;
|
exist_arg_3 = true;
|
||||||
if (p0 < buf + nlen && *p0 == ';')
|
if (p0 < buf + nlen && *p0 == ';')
|
||||||
p0 ++;
|
p0 ++;
|
||||||
}
|
}
|
||||||
|
if (p0 < buf + nlen && exist_arg_3 && (*p0 == 'h' || *p0 == 'l'))
|
||||||
|
get_ttyp ()->need_redraw_screen = true;
|
||||||
p0 ++;
|
p0 ++;
|
||||||
if (p0 >= buf + nlen)
|
if (p0 >= buf + nlen)
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue