mirror of
https://github.com/vim/vim
synced 2025-07-16 01:01:58 +00:00
patch 9.0.0813: Kitty terminal is not recognized
Problem: Kitty terminal is not recognized. Solution: Recognize Kitty by the termresponse and then do not set seenModifyOtherKeys, since Kitty doesn't support that. (issue #11413)
This commit is contained in:
@ -9670,6 +9670,7 @@ terminalprops() *terminalprops()*
|
||||
cursor_blink_mode whether sending |t_RC| works **
|
||||
underline_rgb whether |t_8u| works **
|
||||
mouse mouse type supported
|
||||
kitty whether Kitty terminal was detected
|
||||
|
||||
** value 'u' for unknown, 'y' for yes, 'n' for no
|
||||
|
||||
|
19
src/term.c
19
src/term.c
@ -1350,8 +1350,10 @@ typedef struct {
|
||||
#define TPR_UNDERLINE_RGB 2
|
||||
// mouse support - TPR_MOUSE_XTERM, TPR_MOUSE_XTERM2 or TPR_MOUSE_SGR
|
||||
#define TPR_MOUSE 3
|
||||
// term response indicates kitty
|
||||
#define TPR_KITTY 4
|
||||
// table size
|
||||
#define TPR_COUNT 4
|
||||
#define TPR_COUNT 5
|
||||
|
||||
static termprop_T term_props[TPR_COUNT];
|
||||
|
||||
@ -1373,6 +1375,8 @@ init_term_props(int all)
|
||||
term_props[TPR_UNDERLINE_RGB].tpr_set_by_termresponse = TRUE;
|
||||
term_props[TPR_MOUSE].tpr_name = "mouse";
|
||||
term_props[TPR_MOUSE].tpr_set_by_termresponse = TRUE;
|
||||
term_props[TPR_KITTY].tpr_name = "kitty";
|
||||
term_props[TPR_KITTY].tpr_set_by_termresponse = FALSE;
|
||||
|
||||
for (i = 0; i < TPR_COUNT; ++i)
|
||||
if (all || term_props[i].tpr_set_by_termresponse)
|
||||
@ -4715,6 +4719,13 @@ handle_version_response(int first, int *arg, int argc, char_u *tp)
|
||||
// else if (version == 115 && arg[0] == 0 && arg[2] == 0)
|
||||
// term_props[TPR_UNDERLINE_RGB].tpr_status = TPR_YES;
|
||||
|
||||
// Kitty sends 1;400{version};{secondary-version}
|
||||
if (arg[0] == 1 && arg[1] >= 4000 && arg[1] <= 4009)
|
||||
{
|
||||
term_props[TPR_KITTY].tpr_status = TPR_YES;
|
||||
term_props[TPR_KITTY].tpr_set_by_termresponse = TRUE;
|
||||
}
|
||||
|
||||
// GNU screen sends 83;30600;0, 83;40500;0, etc.
|
||||
// 30600/40500 is a version number of GNU screen. DA2 support is added
|
||||
// on 3.6. DCS string has a special meaning to GNU screen, but xterm
|
||||
@ -4848,7 +4859,11 @@ handle_key_with_modifier(
|
||||
int modifiers;
|
||||
char_u string[MAX_KEY_CODE_LEN + 1];
|
||||
|
||||
seenModifyOtherKeys = TRUE;
|
||||
// Do not set seenModifyOtherKeys for kitty, it does send some sequences
|
||||
// like this but does not have the modifyOtherKeys feature.
|
||||
if (term_props[TPR_KITTY].tpr_status != TPR_YES)
|
||||
seenModifyOtherKeys = TRUE;
|
||||
|
||||
if (trail == 'u')
|
||||
key = arg[0];
|
||||
else
|
||||
|
@ -1647,7 +1647,8 @@ func Test_xx01_term_style_response()
|
||||
\ cursor_style: 'u',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
set t_RV=
|
||||
@ -1681,7 +1682,8 @@ func Test_xx02_iTerm2_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
set t_RV=
|
||||
@ -1700,7 +1702,8 @@ func Run_libvterm_konsole_response(code)
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
endfunc
|
||||
|
||||
@ -1742,7 +1745,8 @@ func Test_xx04_Mac_Terminal_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'y',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
call assert_equal("\<Esc>[58;2;%lu;%lu;%lum", &t_8u)
|
||||
|
||||
@ -1772,7 +1776,8 @@ func Test_xx05_mintty_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'y',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
set t_RV=
|
||||
@ -1807,7 +1812,8 @@ func Test_xx06_screen_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'n',
|
||||
\ underline_rgb: 'y',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
set t_RV=
|
||||
@ -1831,7 +1837,8 @@ func Do_check_t_8u_set_reset(set_by_user)
|
||||
\ cursor_style: 'u',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
call assert_equal(a:set_by_user ? default_value : '', &t_8u)
|
||||
endfunc
|
||||
@ -1867,7 +1874,8 @@ func Test_xx07_xterm_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'y',
|
||||
\ mouse: 'u'
|
||||
\ mouse: 'u',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
" xterm >= 95 < 277 "xterm2"
|
||||
@ -1882,7 +1890,8 @@ func Test_xx07_xterm_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: '2'
|
||||
\ mouse: '2',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
" xterm >= 277: "sgr"
|
||||
@ -1897,7 +1906,8 @@ func Test_xx07_xterm_response()
|
||||
\ cursor_style: 'n',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'u',
|
||||
\ mouse: 's'
|
||||
\ mouse: 's',
|
||||
\ kitty: 'u',
|
||||
\ }, terminalprops())
|
||||
|
||||
" xterm >= 279: "sgr" and cursor_style not reset; also check t_8u reset,
|
||||
@ -1909,6 +1919,30 @@ func Test_xx07_xterm_response()
|
||||
call test_override('term_props', 0)
|
||||
endfunc
|
||||
|
||||
func Test_xx08_kitty_response()
|
||||
" Termresponse is only parsed when t_RV is not empty.
|
||||
set t_RV=x
|
||||
call test_override('term_props', 1)
|
||||
|
||||
set ttymouse=xterm
|
||||
call test_option_not_set('ttymouse')
|
||||
let seq = "\<Esc>[>1;4001;12c"
|
||||
call feedkeys(seq, 'Lx!')
|
||||
call assert_equal(seq, v:termresponse)
|
||||
call assert_equal('sgr', &ttymouse)
|
||||
|
||||
call assert_equal(#{
|
||||
\ cursor_style: 'u',
|
||||
\ cursor_blink_mode: 'u',
|
||||
\ underline_rgb: 'y',
|
||||
\ mouse: 's',
|
||||
\ kitty: 'y',
|
||||
\ }, terminalprops())
|
||||
|
||||
set t_RV=
|
||||
call test_override('term_props', 0)
|
||||
endfunc
|
||||
|
||||
func Test_focus_events()
|
||||
let save_term = &term
|
||||
let save_ttymouse = &ttymouse
|
||||
|
@ -695,6 +695,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
813,
|
||||
/**/
|
||||
812,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user