diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-03-04 20:10:38 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-03-04 20:10:38 +0000 |
commit | f07751457c39a645009c17cd837131f6bcdd7d55 (patch) | |
tree | 119f5f4f97b44fa75496ec1d690c855bc16af8c3 /src/autocmd.c | |
parent | 196c3850dbe95247f7aa1b0000a5cae625a99ef2 (diff) |
patch 8.2.4505: Vim9: outdated "autocmd nested" still worksv8.2.4505
Problem: Vim9: outdated "autocmd nested" still works.
Solution: Do not accept the :autocmd argument "nested" without "++" in Vim9
script.
Diffstat (limited to 'src/autocmd.c')
-rw-r--r-- | src/autocmd.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/autocmd.c b/src/autocmd.c index 341cf83729..7eb08c85b9 100644 --- a/src/autocmd.c +++ b/src/autocmd.c @@ -921,16 +921,30 @@ do_autocmd(exarg_T *eap, char_u *arg_in, int forceit) if ((STRNCMP(cmd, "++nested", 8) == 0 && VIM_ISWHITE(cmd[8]))) { if (nested) + { semsg(_(e_duplicate_argument_str), "++nested"); + return; + } nested = TRUE; cmd = skipwhite(cmd + 8); } - // Check for the old "nested" flag. + // Check for the old "nested" flag in legacy script. if (STRNCMP(cmd, "nested", 6) == 0 && VIM_ISWHITE(cmd[6])) { + if (in_vim9script()) + { + // If there ever is a :nested command this error should + // be removed and "nested" accepted as the start of the + // command. + emsg(_(e_invalid_command_nested_did_you_mean_plusplus_nested)); + return; + } if (nested) + { semsg(_(e_duplicate_argument_str), "nested"); + return; + } nested = TRUE; cmd = skipwhite(cmd + 6); } |