From 4ab1f4a32f7e0fcafa8f542429f1f6c47dcd5d2c Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Fri, 16 Dec 2022 13:08:36 +0000 Subject: [PATCH] patch 9.0.1063: when using Kitty a shell command may mess up the key state Problem: When using Kitty a shell command may mess up the key protocol state. Solution: Output t_te before t_TE. If t_te switches between the main and the alternate screen then deactivating the key protocol by t_TE should happen after switching screen. (issue #11705) --- src/term.c | 5 ++++- src/version.c | 2 ++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/src/term.c b/src/term.c index 13e3709fb..777c510e8 100644 --- a/src/term.c +++ b/src/term.c @@ -3891,10 +3891,13 @@ stoptermcap(void) out_str(T_KE); // stop "keypad transmit" mode out_flush(); termcap_active = FALSE; + + // Output t_te first, it may switch between main and alternate screen, + // and following codes may work on the active screen only. + out_str(T_TE); // stop termcap mode cursor_on(); // just in case it is still off out_str_t_TE(); // stop "raw" mode, modifyOtherKeys and // Kitty keyboard protocol - out_str(T_TE); // stop termcap mode screen_start(); // don't know where cursor is now out_flush(); } diff --git a/src/version.c b/src/version.c index 097c0a6a2..316d21313 100644 --- a/src/version.c +++ b/src/version.c @@ -695,6 +695,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1063, /**/ 1062, /**/ -- 2.40.0