# HG changeset patch # User Bram Moolenaar # Date 1671196503 -3600 # Node ID 79701601ba55fb992a17dacdbfc3d48c6d5c8ef7 # Parent 0a5992bd6a1e637aa371b34c68e8b7f29cbeee77 patch 9.0.1063: when using Kitty a shell command may mess up the key state Commit: https://github.com/vim/vim/commit/4ab1f4a32f7e0fcafa8f542429f1f6c47dcd5d2c Author: Bram Moolenaar Date: Fri Dec 16 13:08:36 2022 +0000 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) diff --git a/src/term.c b/src/term.c --- 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 --- a/src/version.c +++ b/src/version.c @@ -696,6 +696,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1063, +/**/ 1062, /**/ 1061,