summaryrefslogtreecommitdiffstats
path: root/src/autocmd.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-03-04 20:10:38 +0000
committerBram Moolenaar <Bram@vim.org>2022-03-04 20:10:38 +0000
commitf07751457c39a645009c17cd837131f6bcdd7d55 (patch)
tree119f5f4f97b44fa75496ec1d690c855bc16af8c3 /src/autocmd.c
parent196c3850dbe95247f7aa1b0000a5cae625a99ef2 (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.c16
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);
}