Cygwin: console: Fix OSC sequence handling.
- Currently, some OSC escape sequences, such as 'OSC 110 BEL', are not handled correctly. This patch fixes the issue.
This commit is contained in:
parent
8fa73a9f84
commit
e1026837dd
|
@ -3308,13 +3308,30 @@ fhandler_console::write (const void *vsrc, size_t len)
|
||||||
case gotrsquare:
|
case gotrsquare:
|
||||||
if (isdigit (*src))
|
if (isdigit (*src))
|
||||||
con.rarg = con.rarg * 10 + (*src - '0');
|
con.rarg = con.rarg * 10 + (*src - '0');
|
||||||
else if (*src == ';' && (con.rarg == 2 || con.rarg == 0))
|
else if (*src == ';')
|
||||||
con.state = gettitle;
|
{
|
||||||
else if (*src == ';' && (con.rarg == 4 || con.rarg == 104
|
if (con.rarg == 0 || con.rarg == 2)
|
||||||
|| (con.rarg >= 10 && con.rarg <= 19)))
|
con.state = gettitle;
|
||||||
con.state = eatpalette;
|
else if ((con.rarg >= 4 && con.rarg <= 6)
|
||||||
else
|
|| (con.rarg >=10 && con.rarg <= 19)
|
||||||
con.state = eattitle;
|
|| (con.rarg >=104 && con.rarg <= 106)
|
||||||
|
|| (con.rarg >=110 && con.rarg <= 119))
|
||||||
|
con.state = eatpalette;
|
||||||
|
else
|
||||||
|
con.state = eattitle;
|
||||||
|
}
|
||||||
|
else if (*src == '\033')
|
||||||
|
con.state = endpalette;
|
||||||
|
else if (*src == '\007')
|
||||||
|
{
|
||||||
|
wpbuf.put (*src);
|
||||||
|
if (wincap.has_con_24bit_colors () && !con_is_legacy)
|
||||||
|
wpbuf.send (get_output_handle ());
|
||||||
|
wpbuf.empty ();
|
||||||
|
con.state = normal;
|
||||||
|
src++;
|
||||||
|
break;
|
||||||
|
}
|
||||||
wpbuf.put (*src);
|
wpbuf.put (*src);
|
||||||
src++;
|
src++;
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue