]> granicus.if.org Git - vim/commitdiff
patch 7.4.1835 v7.4.1835
authorBram Moolenaar <Bram@vim.org>
Tue, 24 May 2016 09:31:32 +0000 (11:31 +0200)
committerBram Moolenaar <Bram@vim.org>
Tue, 24 May 2016 09:31:32 +0000 (11:31 +0200)
Problem:    When splitting and closing a window the status height changes.
Solution:   Compute the frame height correctly. (Hirohito Higashi)

src/testdir/test_alot.vim
src/testdir/test_window_cmd.vim [new file with mode: 0644]
src/version.c
src/window.c

index 6bfd81eaf9d0ac2d39f8ada78f07fca761b0d67c..d8d460aec45b00741d437db332b68fd8e474a953 100644 (file)
@@ -32,3 +32,4 @@ source test_tagjump.vim
 source test_timers.vim
 source test_undolevels.vim
 source test_unlet.vim
+source test_window_cmd.vim
diff --git a/src/testdir/test_window_cmd.vim b/src/testdir/test_window_cmd.vim
new file mode 100644 (file)
index 0000000..d2e4272
--- /dev/null
@@ -0,0 +1,37 @@
+" Tests for window cmd (:wincmd, :split, :vsplit, :resize and etc...)
+
+func Test_window_cmd_ls0_with_split()
+  set ls=0
+  set splitbelow
+  split
+  quit
+  call assert_equal(0, &lines - &cmdheight - winheight(0))
+  new | only!
+  "
+  set splitbelow&vim
+  botright split
+  quit
+  call assert_equal(0, &lines - &cmdheight - winheight(0))
+  new | only!
+  set ls&vim
+endfunc
+
+func Test_window_cmd_cmdwin_with_vsp()
+  let efmt='Expected 0 but got %d (in ls=%d, %s window)'
+  for v in range(0, 2)
+    exec "set ls=" . v
+    vsplit
+    call feedkeys("q:\<CR>")
+    let ac = &lines - (&cmdheight + winheight(0) + !!v)
+    let emsg = printf(efmt, ac, v, 'left')
+    call assert_equal(0, ac, emsg)
+    wincmd w
+    let ac = &lines - (&cmdheight + winheight(0) + !!v)
+    let emsg = printf(efmt, ac, v, 'right')
+    call assert_equal(0, ac, emsg)
+    new | only!
+  endfor
+  set ls&vim
+endfunc
+
+" vim: sw=2 et
index 417a3aa57e169e792a593362afb15226df865839..166a9de507b846b7a8514262bcde95375866c04c 100644 (file)
@@ -753,6 +753,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1835,
 /**/
     1834,
 /**/
index bbd0a527c017017c984ca9ddf98775fb61ebf9c8..01da765b46bb1e87cfe0f1056e575f3499b436c1 100644 (file)
@@ -1165,8 +1165,13 @@ win_split_ins(
         * one row for the status line */
        win_new_height(wp, new_size);
        if (flags & (WSP_TOP | WSP_BOT))
-           frame_new_height(curfrp, curfrp->fr_height
-                       - (new_size + STATUS_HEIGHT), flags & WSP_TOP, FALSE);
+       {
+           int new_fr_height = curfrp->fr_height - new_size;
+
+           if (!((flags & WSP_BOT) && p_ls == 0))
+               new_fr_height -= STATUS_HEIGHT;
+           frame_new_height(curfrp, new_fr_height, flags & WSP_TOP, FALSE);
+       }
        else
            win_new_height(oldwin, oldwin_height - (new_size + STATUS_HEIGHT));
        if (before)     /* new window above current one */
@@ -1179,18 +1184,13 @@ win_split_ins(
        {
            wp->w_winrow = oldwin->w_winrow + oldwin->w_height + STATUS_HEIGHT;
            wp->w_status_height = oldwin->w_status_height;
-           /* Don't set the status_height for oldwin yet, this might break
-            * frame_fix_height(oldwin), therefore will be set below. */
+           if (!(flags & WSP_BOT))
+               oldwin->w_status_height = STATUS_HEIGHT;
        }
        if (flags & WSP_BOT)
            frame_add_statusline(curfrp);
        frame_fix_height(wp);
        frame_fix_height(oldwin);
-
-       if (!before)
-           /* new window above current one, set the status_height after
-            * frame_fix_height(oldwin) */
-           oldwin->w_status_height = STATUS_HEIGHT;
     }
 
     if (flags & (WSP_TOP | WSP_BOT))