From 5b1d6e98c6610553fe3946086cdba77718bd69d5 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Fri, 11 Feb 2022 20:33:48 +0000 Subject: [PATCH] patch 8.2.4348: "legacy exe cmd" does not do what one would expect Problem: "legacy exe cmd" does not do what one would expect. Solution: Apply the "legacy" and "vim9script" command modifiers to the argument of ":execute". --- runtime/doc/vim9.txt | 10 +++++----- src/eval.c | 8 ++++++++ src/ex_docmd.c | 1 + src/globals.h | 1 + src/testdir/test_vim9_cmd.vim | 25 +++++++++++++++++++++++++ src/version.c | 2 ++ 6 files changed, 42 insertions(+), 5 deletions(-) diff --git a/runtime/doc/vim9.txt b/runtime/doc/vim9.txt index 5824ecb281..edd61d9689 100644 --- a/runtime/doc/vim9.txt +++ b/runtime/doc/vim9.txt @@ -57,13 +57,13 @@ rewrite old scripts, they keep working as before. You may want to use a few `:def` functions for code that needs to be fast. :vim9[cmd] {cmd} *:vim9* *:vim9cmd* *E1164* - Execute {cmd} using Vim9 script syntax and semantics. - Useful when typing a command and in a legacy script or - function. + Evaluate and execute {cmd} using Vim9 script syntax and + semantics. Useful when typing a command and in a legacy + script or function. :leg[acy] {cmd} *:leg* *:legacy* *E1189* *E1234* - Execute {cmd} using legacy script syntax and semantics. Only - useful in a Vim9 script or a :def function. + Evaluate and execute {cmd} using legacy script syntax and + semantics. Only useful in a Vim9 script or a :def function. Note that {cmd} cannot use local variables, since it is parsed with legacy expression syntax. diff --git a/src/eval.c b/src/eval.c index d775ee3f26..81a1dd0a97 100644 --- a/src/eval.c +++ b/src/eval.c @@ -6491,8 +6491,16 @@ ex_execute(exarg_T *eap) did_emsg = save_did_emsg; } else if (eap->cmdidx == CMD_execute) + { + int save_sticky_cmdmod_flags = sticky_cmdmod_flags; + + // "legacy exe cmd" and "vim9cmd exe cmd" applies to "cmd". + sticky_cmdmod_flags = cmdmod.cmod_flags + & (CMOD_LEGACY | CMOD_VIM9CMD); do_cmdline((char_u *)ga.ga_data, eap->getline, eap->cookie, DOCMD_NOWAIT|DOCMD_VERBOSE); + sticky_cmdmod_flags = save_sticky_cmdmod_flags; + } } ga_clear(&ga); diff --git a/src/ex_docmd.c b/src/ex_docmd.c index 4003605537..864f3d845d 100644 --- a/src/ex_docmd.c +++ b/src/ex_docmd.c @@ -2786,6 +2786,7 @@ parse_command_modifiers( int starts_with_colon = FALSE; CLEAR_POINTER(cmod); + cmod->cmod_flags = sticky_cmdmod_flags; // Repeat until no more command modifiers are found. for (;;) diff --git a/src/globals.h b/src/globals.h index 2f6a4b41ab..8bc537ed7e 100644 --- a/src/globals.h +++ b/src/globals.h @@ -1156,6 +1156,7 @@ EXTERN int mapped_ctrl_c INIT(= FALSE); // modes where CTRL-C is mapped EXTERN int ctrl_c_interrupts INIT(= TRUE); // CTRL-C sets got_int EXTERN cmdmod_T cmdmod; // Ex command modifiers +EXTERN int sticky_cmdmod_flags INIT(= 0); // used by :execute #ifdef FEAT_EVAL EXTERN int is_export INIT(= FALSE); // :export {cmd} diff --git a/src/testdir/test_vim9_cmd.vim b/src/testdir/test_vim9_cmd.vim index 0ac69e84fe..4398cbf4f6 100644 --- a/src/testdir/test_vim9_cmd.vim +++ b/src/testdir/test_vim9_cmd.vim @@ -83,6 +83,31 @@ def Test_vim9cmd() v9.CheckScriptSuccess(lines) enddef +def Test_cmdmod_execute() + # "legacy" applies not only to the "exe" argument but also to the commands + var lines =<< trim END + vim9script + + b:undo = 'let g:undone = 1 | let g:undtwo = 2' + legacy exe b:undo + assert_equal(1, g:undone) + assert_equal(2, g:undtwo) + END + v9.CheckScriptSuccess(lines) + + # same for "vim9cmd" modifier + lines =<< trim END + let b:undo = 'g:undone = 11 | g:undtwo = 22' + vim9cmd exe b:undo + call assert_equal(11, g:undone) + call assert_equal(22, g:undtwo) + END + v9.CheckScriptSuccess(lines) + unlet b:undo + unlet g:undone + unlet g:undtwo +enddef + def Test_edit_wildcards() var filename = 'Xtest' edit `=filename` diff --git a/src/version.c b/src/version.c index f7599c0d08..dfcec91717 100644 --- a/src/version.c +++ b/src/version.c @@ -746,6 +746,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 4348, /**/ 4347, /**/