]> granicus.if.org Git - vim/commitdiff
patch 8.2.0422: crash when passing popup window to win_splitmove() v8.2.0422
authorBram Moolenaar <Bram@vim.org>
Fri, 20 Mar 2020 20:15:51 +0000 (21:15 +0100)
committerBram Moolenaar <Bram@vim.org>
Fri, 20 Mar 2020 20:15:51 +0000 (21:15 +0100)
Problem:    Crash when passing popup window to win_splitmove(). (john Devin)
Solution:   Disallow moving a popup window. (closes #5816)

src/evalwindow.c
src/testdir/test_popupwin.vim
src/version.c

index c7a9f7960eeee1ef0d6d7f184f3be9853f8f239b..534a047e6998ec12f079491df6367ba0fdc30acd 100644 (file)
@@ -810,7 +810,8 @@ f_win_splitmove(typval_T *argvars, typval_T *rettv)
     targetwin = find_win_by_nr_or_id(&argvars[1]);
 
     if (wp == NULL || targetwin == NULL || wp == targetwin
-           || !win_valid(wp) || !win_valid(targetwin))
+           || !win_valid(wp) || !win_valid(targetwin)
+           || win_valid_popup(wp) || win_valid_popup(targetwin))
     {
         emsg(_(e_invalwindow));
        rettv->vval.v_number = -1;
index 9cd6e3229acdc4e2eab5369f85a6ad683e4ea079..478e9d49e95482005b60cfdef8e076f0ce8eea0b 100644 (file)
@@ -3307,4 +3307,16 @@ func Test_popupwin_atcursor_far_right()
   set signcolumn&
 endfunc
 
+func Test_popupwin_splitmove()
+  vsplit
+  let win2 = win_getid()
+  let popup_winid = popup_dialog('hello', {})
+  call assert_fails('call win_splitmove(popup_winid, win2)', 'E957:')
+  call assert_fails('call win_splitmove(win2, popup_winid)', 'E957:')
+
+  call popup_clear()
+  bwipe
+endfunc
+
+
 " vim: shiftwidth=2 sts=2
index 986a29feb02c373b886ae2a234677daa46b09056..a6112cee962f41d470e0de41c215bfe2b8dfce7b 100644 (file)
@@ -738,6 +738,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    422,
 /**/
     421,
 /**/