Hi Bram and Vimmers,
I have received reports of problems related to :split and laststatus=0.
I was confirmed by CUI Vim 7.4.1832 on fedora 23 via PuTTY (80x24)
Issue 1:
- Start pure Vim with some options.
$ vim -Nu NONE -c "set ls=0 splitbelow"
- Check window height.
:echo winheight(0)
23
- split and quit window.
:sp | q
- Recheck window height.
:echo winheight(0)
Expected value: 23
Actual value: 22 and command-line line has moved up by one line.
Issue 2:
- Start pure Vim with some options.
$ vim -Nu NONE -c "set ls=0"
- Split window.
:botright sp
- Type `:`.
Expected behavior:
- Cursor move to last line. Because 'cmdheight' is 1 (default).
Actual behavior:
- Cursor has moved to the second from the bottom. It's wrong.
Issue 3:
- Start pure Vim with some options.
$ vim -Nu NONE -c "set ls=0"
- Vertical split window.
:vsp
- Open command-line window.
q:
Expected behavior:
- Command line window is opened.
Actual behavior:
- Likewise opened, but obviously the second line from the bottom strange.
REMARKS:
The issue 3 is related to the following patch and thread.
patch 7.4.706
https://github.com/vim/vim/commit/5b14f89164fa2f40f52283226c98005887568317
Re: [bug] cmdline-window given laststatus=0 and vertical split
https://groups.google.com/forum/#!searchin/vim_dev/Yclept$20Nemo/vim_dev/fNq8tHTcKfA/7yg4GZ1h8agJ
I think patch 7.4.706 is no good solution.
This patch is updating the window information after updating the frame
information.
It generates a Inconsistencies between the frame information and the window
information, and It cause abnormal window drawing.
I wrote a patch to fix above all issues. Of course, the test was also added.
Please check an attached patch.
--
Best regards,
Hirohito Higashi (a.k.a. h_east)
--
--
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php
---
You received this message because you are subscribed to the Google Groups
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to vim_dev+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.
diff --git a/src/Makefile b/src/Makefile
index b3b8daf..2e8665a 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -2057,6 +2057,7 @@ test_arglist \
test_viminfo \
test_viml \
test_visual \
+ test_window_cmd \
test_window_id \
test_alot_latin \
test_alot_utf8 \
diff --git a/src/testdir/test_alot.vim b/src/testdir/test_alot.vim
index 6bfd81e..d8d460a 100644
--- a/src/testdir/test_alot.vim
+++ b/src/testdir/test_alot.vim
@@ -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
index 000..d7e432d
--- /dev/null
+++ b/src/testdir/test_window_cmd.vim
@@ -0,0 +1,36 @@
+" 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, - - winheight(0))
+ new | only!
+ "
+ set splitbelow
+ botright split
+ quit
+ call assert_equal(0, - - winheight(0))
+ new | only!
+ set ls
+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:\")
+let ac = - ( + winheight(0) + !!v)
+let emsg = printf(efmt, ac, v, 'left')
+call assert_equal(0, ac, emsg)
+wincmd w
+let ac = - ( + winheight(0) + !!v)
+let emsg = printf(efmt, ac, v, 'right')
+call assert_equal(0, ac, emsg)
+new | only!
+ endfor
+ set ls
+endfunc
+" vim: sw=2 et
diff --git a/src/window.c b/src/window.c
index bbd0a52..01da765 100644
--- a/src/window.c
+++ b/src/window.c
@@ -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 &