forked from aniani/vim
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:
@@ -816,6 +816,13 @@ f_win_gotoid(typval_T *argvars, typval_T *rettv)
|
|||||||
emsg(_(e_invalid_in_cmdline_window));
|
emsg(_(e_invalid_in_cmdline_window));
|
||||||
return;
|
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
|
#endif
|
||||||
FOR_ALL_TAB_WINDOWS(tp, wp)
|
FOR_ALL_TAB_WINDOWS(tp, wp)
|
||||||
if (wp->w_id == id)
|
if (wp->w_id == id)
|
||||||
|
@@ -528,6 +528,18 @@ func Test_double_popup_terminal()
|
|||||||
exe buf2 .. 'bwipe!'
|
exe buf2 .. 'bwipe!'
|
||||||
endfunc
|
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()
|
func Test_issue_5607()
|
||||||
let wincount = winnr('$')
|
let wincount = winnr('$')
|
||||||
exe 'terminal' &shell &shellcmdflag 'exit'
|
exe 'terminal' &shell &shellcmdflag 'exit'
|
||||||
|
@@ -746,6 +746,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 */
|
||||||
|
/**/
|
||||||
|
4814,
|
||||||
/**/
|
/**/
|
||||||
4813,
|
4813,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user