summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/term.c5
-rw-r--r--src/testdir/test_startup.vim9
-rw-r--r--src/version.c2
3 files changed, 14 insertions, 2 deletions
diff --git a/src/term.c b/src/term.c
index 8ce577ec1..ad52d1b31 100644
--- a/src/term.c
+++ b/src/term.c
@@ -3365,8 +3365,9 @@ win_new_shellsize(void)
ui_new_shellsize();
if (old_Rows != Rows)
{
- // if 'window' uses the whole screen, keep it using that
- if (p_window == old_Rows - 1 || old_Rows == 0)
+ // If 'window' uses the whole screen, keep it using that.
+ // Don't change it when set with "-w size" on the command line.
+ if (p_window == old_Rows - 1 || (old_Rows == 0 && p_window == 0))
p_window = Rows - 1;
old_Rows = Rows;
shell_new_rows(); // update window sizes
diff --git a/src/testdir/test_startup.vim b/src/testdir/test_startup.vim
index ae12f6187..0817c9e57 100644
--- a/src/testdir/test_startup.vim
+++ b/src/testdir/test_startup.vim
@@ -1045,6 +1045,7 @@ endfunc
func Test_w_arg()
" Can't catch the output of gvim.
CheckNotGui
+
call writefile(["iVim Editor\<Esc>:q!\<CR>"], 'Xscriptin', 'b')
if RunVim([], [], '-s Xscriptin -w Xscriptout')
call assert_equal(["iVim Editor\e:q!\r"], readfile('Xscriptout'))
@@ -1060,6 +1061,14 @@ func Test_w_arg()
call assert_equal("Cannot open for script output: \"Xdir\"\n", m)
call delete("Xdir", 'rf')
endif
+
+ " A number argument sets the 'window' option
+ call writefile(["iwindow \<C-R>=&window\<CR>\<Esc>:wq! Xresult\<CR>"], 'Xscriptin', 'b')
+ if RunVim([], [], '-s Xscriptin -w 17')
+ call assert_equal(["window 17"], readfile('Xresult'))
+ call delete('Xresult')
+ endif
+ call delete('Xscriptin')
endfunc
" Test for the "-s scriptin" argument
diff --git a/src/version.c b/src/version.c
index 5e177f09b..4cf2c0a88 100644
--- a/src/version.c
+++ b/src/version.c
@@ -751,6 +751,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 2655,
+/**/
2654,
/**/
2653,