[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