patch 9.1.1745: tabpanel: not properly redraw after wildmenu

Problem:  tabpanel: not properly redraw after wildmenu
          (ddad431)
Solution: Mark tabpanel to be redrawn (Hirohito Higashi).

fixes: #18209
closes: #18252

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Hirohito Higashi
2025-09-09 15:11:13 -04:00
committed by Christian Brabandt
parent 77cfc49060
commit 95593facd7
5 changed files with 49 additions and 0 deletions

View File

@ -4501,6 +4501,9 @@ wildmenu_cleanup(cmdline_info_T *cclp UNUSED)
p_ls = save_p_ls; p_ls = save_p_ls;
p_wmh = save_p_wmh; p_wmh = save_p_wmh;
last_status(FALSE); last_status(FALSE);
#if defined(FEAT_TABPANEL)
redraw_tabpanel = TRUE;
#endif
update_screen(UPD_VALID); // redraw the screen NOW update_screen(UPD_VALID); // redraw the screen NOW
redrawcmd(); redrawcmd();
save_p_ls = -1; save_p_ls = -1;

View File

@ -0,0 +1,10 @@
|[+8#0000001#e0e0e08|N|o| |N|a|m|e|]| @11|[|N|o| |N|a|m|e|]| | +2#0000000#ffffff0|a@2| | +1&&@7|X+8#0000001#e0e0e08
|a+2#0000000#ffffff0@2| @16> +0&&@24
| +1&&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +0#0000000&@44

View File

@ -0,0 +1,10 @@
|[+8#0000001#e0e0e08|N|o| |N|a|m|e|]| @11|[|N|o| |N|a|m|e|]| | +2#0000000#ffffff0|a@2| | +1&&@7|X+8#0000001#e0e0e08
|a+2#0000000#ffffff0@2| @16| +0&&@24
| +1&&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
| +1#0000000&@19|~+0#4040ff13&| @23
|t+0#0000001#ffff4012|a|b|n|e|w| +3#0000000#ffffff0@1|t|a|b|n|e|x|t| @29
|:+0&&|t|a|b|n|e|w> @37

View File

@ -147,6 +147,7 @@ function Test_tabpanel_mouse()
call feedkeys("\<LeftRelease>", 'xt') call feedkeys("\<LeftRelease>", 'xt')
call assert_equal(3, tabpagenr()) call assert_equal(3, tabpagenr())
" Test getmousepos()
call feedkeys("\<LeftMouse>", 'xt') call feedkeys("\<LeftMouse>", 'xt')
call test_setmouse(2, 3) call test_setmouse(2, 3)
let pos = getmousepos() let pos = getmousepos()
@ -770,4 +771,27 @@ function Test_tabpanel_with_cmdline_pum()
call StopVimInTerminal(buf) call StopVimInTerminal(buf)
endfunc endfunc
function Test_tabpanel_with_cmdline_no_pum()
CheckScreendump
let lines =<< trim END
set showtabpanel=2
set noruler
tabnew aaa
set wildoptions-=pum
END
call writefile(lines, 'XTest_tabpanel_with_cmdline_pum', 'D')
let buf = RunVimInTerminal('-S XTest_tabpanel_with_cmdline_pum', {'rows': 10, 'cols': 45})
call term_sendkeys(buf, "\<C-L>")
call VerifyScreenDump(buf, 'Test_tabpanel_with_cmdline_no_pum_0', {})
call term_sendkeys(buf, ":tabne\<Tab>")
call VerifyScreenDump(buf, 'Test_tabpanel_with_cmdline_no_pum_1', {})
call term_sendkeys(buf, "\<Esc>\<C-L>")
call VerifyScreenDump(buf, 'Test_tabpanel_with_cmdline_no_pum_0', {})
call StopVimInTerminal(buf)
endfunc
" vim: shiftwidth=2 sts=2 expandtab " vim: shiftwidth=2 sts=2 expandtab

View File

@ -724,6 +724,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1745,
/**/ /**/
1744, 1744,
/**/ /**/