summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-08-01 23:22:18 +0200
committerBram Moolenaar <Bram@vim.org>2020-08-01 23:22:18 +0200
commitad486a0f0dd194826fdb733516bf0f35382c9dd7 (patch)
tree859e99f5181e93161caab1a2960db90c3a981ac3
parentbcbf41395f93aabd577a17dc4fbabe523d0a7ce8 (diff)
patch 8.2.1352: Vim9: no error for shadowing a script-local functionv8.2.1352
Problem: Vim9: no error for shadowing a script-local function by a nested function. Solution: Check for script-local function. (closes #6586)
-rw-r--r--src/testdir/test_vim9_func.vim14
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c8
3 files changed, 23 insertions, 1 deletions
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim
index 1ccaeb308a..f3fc4c7bee 100644
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -174,6 +174,20 @@ def Test_nested_global_function()
Outer()
END
CheckScriptFailure(lines, "E122:")
+
+ lines =<< trim END
+ vim9script
+ def Func()
+ echo 'script'
+ enddef
+ def Outer()
+ def Func()
+ echo 'inner'
+ enddef
+ enddef
+ defcompile
+ END
+ CheckScriptFailure(lines, "E1073:")
enddef
def Test_global_local_function()
diff --git a/src/version.c b/src/version.c
index f032581c0c..70d90c5764 100644
--- a/src/version.c
+++ b/src/version.c
@@ -755,6 +755,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1352,
+/**/
1351,
/**/
1350,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 61be54d7b7..3c7e1218ed 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -291,15 +291,21 @@ lookup_script(char_u *name, size_t len)
int
check_defined(char_u *p, size_t len, cctx_T *cctx)
{
+ int c = p[len];
+
+ p[len] = NUL;
if (lookup_script(p, len) == OK
|| (cctx != NULL
&& (lookup_local(p, len, cctx) != NULL
|| lookup_arg(p, len, NULL, NULL, NULL, cctx) == OK))
- || find_imported(p, len, cctx) != NULL)
+ || find_imported(p, len, cctx) != NULL
+ || find_func_even_dead(p, FALSE, cctx) != NULL)
{
+ p[len] = c;
semsg(_(e_already_defined), p);
return FAIL;
}
+ p[len] = c;
return OK;
}