diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-08-01 23:22:18 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-08-01 23:22:18 +0200 |
commit | ad486a0f0dd194826fdb733516bf0f35382c9dd7 (patch) | |
tree | 859e99f5181e93161caab1a2960db90c3a981ac3 /src | |
parent | bcbf41395f93aabd577a17dc4fbabe523d0a7ce8 (diff) | |
download | vim-git-ad486a0f0dd194826fdb733516bf0f35382c9dd7.tar.gz |
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)
Diffstat (limited to 'src')
-rw-r--r-- | src/testdir/test_vim9_func.vim | 14 | ||||
-rw-r--r-- | src/version.c | 2 | ||||
-rw-r--r-- | src/vim9compile.c | 8 |
3 files changed, 23 insertions, 1 deletions
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim index 1ccaeb308..f3fc4c7be 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 f032581c0..70d90c576 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 61be54d7b..3c7e1218e 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; } |