patch 8.2.4814: possible to leave a popup window with win_gotoid()

Problem:    Possible to leave a popup window with win_gotoid().
Solution:   Give an error when trying to leave a popup window with
            win_gotoid(). (closes #10253)
This commit is contained in:
LemonBoy
2022-04-23 14:07:56 +01:00
committed by Bram Moolenaar
parent 2c40707baa
commit 4a392d2440
3 changed files with 21 additions and 0 deletions

View File

@ -816,6 +816,13 @@ f_win_gotoid(typval_T *argvars, typval_T *rettv)
emsg(_(e_invalid_in_cmdline_window));
return;
}
#endif
#if defined(FEAT_PROP_POPUP) && defined(FEAT_TERMINAL)
if (popup_is_popup(curwin) && curbuf->b_term != NULL)
{
emsg(_(e_not_allowed_for_terminal_in_popup_window));
return;
}
#endif
FOR_ALL_TAB_WINDOWS(tp, wp)
if (wp->w_id == id)

View File

@ -528,6 +528,18 @@ func Test_double_popup_terminal()
exe buf2 .. 'bwipe!'
endfunc
func Test_escape_popup_terminal()
set hidden
" Cannot escape a terminal popup window using win_gotoid
let prev_win = win_getid()
eval term_start('sh', #{hidden: 1, term_finish: 'close'})->popup_create({})
call assert_fails("call win_gotoid(" .. prev_win .. ")", 'E863:')
call popup_clear(1)
set hidden&
endfunc
func Test_issue_5607()
let wincount = winnr('$')
exe 'terminal' &shell &shellcmdflag 'exit'

View File

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