[PATCH v2] Cygwin: console: Fix behaviour of "ESC 8" after reset.
Corinna Vinschen
corinna-cygwin@cygwin.com
Mon Mar 9 08:59:27 GMT 2020
On Mar 9 10:38, Takashi Yano wrote:
> - This patch matches the behaviour of "ESC 8" (DECRC) to the real
> xterm after full reset (RIS), soft reset (DECSTR) and "CSI 3 J".
> ---
> winsup/cygwin/fhandler_console.cc | 7 +++++++
> 1 file changed, 7 insertions(+)
>
> diff --git a/winsup/cygwin/fhandler_console.cc b/winsup/cygwin/fhandler_console.cc
> index 1c376291f..2a239b866 100644
> --- a/winsup/cygwin/fhandler_console.cc
> +++ b/winsup/cygwin/fhandler_console.cc
> @@ -2124,6 +2124,11 @@ fhandler_console::char_command (char c)
> break;
> case 'J': /* ED */
> wpbuf.put (c);
> + if (con.args[0] == 3 && con.savey >= 0)
> + {
> + con.fillin (get_output_handle ());
> + con.savey -= con.b.srWindow.Top;
> + }
> if (con.args[0] == 3 && wincap.has_con_broken_csi3j ())
> { /* Workaround for broken CSI3J in Win10 1809 */
> CONSOLE_SCREEN_BUFFER_INFO sbi;
> @@ -2168,6 +2173,7 @@ fhandler_console::char_command (char c)
> {
> con.scroll_region.Top = 0;
> con.scroll_region.Bottom = -1;
> + con.savex = con.savey = -1;
> }
> wpbuf.put (c);
> /* Just send the sequence */
> @@ -3070,6 +3076,7 @@ fhandler_console::write (const void *vsrc, size_t len)
> {
> con.scroll_region.Top = 0;
> con.scroll_region.Bottom = -1;
> + con.savex = con.savey = -1;
> }
> /* ESC sequences below (e.g. OSC, etc) are left to xterm
> emulation in xterm compatible mode, therefore, are not
> --
> 2.21.0
Pushed.
Thanks,
Corinna
--
Corinna Vinschen
Cygwin Maintainer
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <http://cygwin.com/pipermail/cygwin-patches/attachments/20200309/82849a15/attachment-0001.sig>
More information about the Cygwin-patches
mailing list