From: zeertzjq Date: Fri, 28 Feb 2025 16:32:07 +0000 (+0100) Subject: patch 9.1.1158: :verbose set has wrong file name with :compiler! X-Git-Tag: v9.1.1158^0 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5e8b2268e180cbf5079ea6dbe9c8fd29c3e3133c;p=thirdparty%2Fvim.git patch 9.1.1158: :verbose set has wrong file name with :compiler! Problem: :verbose set has wrong file name with :compiler! Solution: Add -keepscript (zeertzjq) closes: #16752 Signed-off-by: zeertzjq Signed-off-by: Christian Brabandt --- diff --git a/src/ex_cmds2.c b/src/ex_cmds2.c index 0681153179..567522c22c 100644 --- a/src/ex_cmds2.c +++ b/src/ex_cmds2.c @@ -789,7 +789,7 @@ ex_compiler(exarg_T *eap) { // ":compiler! {name}" sets global options do_cmdline_cmd((char_u *) - "command -nargs=* CompilerSet set "); + "command -nargs=* -keepscript CompilerSet set "); } else { diff --git a/src/testdir/test_compiler.vim b/src/testdir/test_compiler.vim index 99f472401d..d86c55f1c7 100644 --- a/src/testdir/test_compiler.vim +++ b/src/testdir/test_compiler.vim @@ -17,12 +17,14 @@ func Test_compiler() e Xfoo.pl " Play nice with other tests. defer setqflist([]) + compiler perl call assert_equal('perl', b:current_compiler) call assert_fails('let g:current_compiler', 'E121:') - let verbose_efm = execute('verbose set efm') call assert_match('Last set from .*[/\\]compiler[/\\]perl.vim ', verbose_efm) + " Not using the global value + call assert_notequal('', &l:efm) call setline(1, ['#!/usr/bin/perl -w', 'use strict;', 'my $foo=1']) w! @@ -36,6 +38,29 @@ func Test_compiler() call assert_match('\n \d\+ Xfoo.pl:3: Global symbol "$foo" ' \ . 'requires explicit package name', a) + compiler make + call assert_fails('let b:current_compiler', 'E121:') + call assert_fails('let g:current_compiler', 'E121:') + let verbose_efm = execute('verbose set efm') + call assert_match('Last set from .*[/\\]compiler[/\\]make.vim ', verbose_efm) + + compiler! perl + call assert_equal('perl', b:current_compiler) + call assert_equal('perl', g:current_compiler) + let verbose_efm = execute('verbose set efm') + call assert_match('Last set from .*[/\\]compiler[/\\]perl.vim ', verbose_efm) + call assert_equal(verbose_efm, execute('verbose setglobal efm')) + " Using the global value + call assert_equal('', &l:efm) + + compiler! make + call assert_fails('let b:current_compiler', 'E121:') + call assert_fails('let g:current_compiler', 'E121:') + let verbose_efm = execute('verbose set efm') + call assert_match('Last set from .*[/\\]compiler[/\\]make.vim ', verbose_efm) + call assert_equal(verbose_efm, execute('verbose setglobal efm')) + " Using the global value + call assert_equal('', &l:efm) let &shellslash = save_shellslash call delete('Xfoo.pl') diff --git a/src/version.c b/src/version.c index 94db286ee6..3b61cdd8e6 100644 --- a/src/version.c +++ b/src/version.c @@ -704,6 +704,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1158, /**/ 1157, /**/