From 0a1a6a1aa4004d0e4d64cc375540156b8bd92a87 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Fri, 26 Mar 2021 14:14:18 +0100 Subject: [PATCH] patch 8.2.2655: The -w command line argument doesn't work Problem: The -w command line argument doesn't work. Solution: Don't set 'window' when set with the -w argument. (closes #8011) --- src/term.c | 5 +++-- src/testdir/test_startup.vim | 9 +++++++++ src/version.c | 2 ++ 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/src/term.c b/src/term.c index 8ce577ec13..ad52d1b315 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 ae12f61873..0817c9e576 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\:q!\"], '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 \=&window\\:wq! Xresult\"], '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 5e177f09b3..4cf2c0a886 100644 --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2655, /**/ 2654, /**/