summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-08-01 22:35:13 +0200
committerBram Moolenaar <Bram@vim.org>2020-08-01 22:35:13 +0200
commitbcbf41395f93aabd577a17dc4fbabe523d0a7ce8 (patch)
tree9cc9270de87f65cb8ad127fb663ba937fcff9cf8
parentb9a2cac3ef293bfdfe80dea6c6d16d02b7af5435 (diff)
downloadvim-git-bcbf41395f93aabd577a17dc4fbabe523d0a7ce8.tar.gz
patch 8.2.1351: Vim9: no proper error if using namespace for nested functionv8.2.1351
Problem: Vim9: no proper error if using namespace for nested function. Solution: Specifically check for a namespace. (closes #6582)
-rw-r--r--src/testdir/test_vim9_func.vim2
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c8
3 files changed, 11 insertions, 1 deletions
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim
index 85fd8ff4e..1ccaeb308 100644
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -131,6 +131,8 @@ def Test_nested_function()
CheckDefFailure(['def Nested(arg: string)', 'enddef', 'Nested()'], 'E119:')
CheckDefFailure(['func Nested()', 'endfunc'], 'E1086:')
+ CheckDefFailure(['def s:Nested()', 'enddef'], 'E1075:')
+ CheckDefFailure(['def b:Nested()', 'enddef'], 'E1075:')
enddef
func Test_call_default_args_from_func()
diff --git a/src/version.c b/src/version.c
index 00d8c2dab..f032581c0 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 */
/**/
+ 1351,
+/**/
1350,
/**/
1349,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 6581708bc..61be54d7b 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -4899,12 +4899,18 @@ compile_nested_function(exarg_T *eap, cctx_T *cctx)
{
int is_global = *eap->arg == 'g' && eap->arg[1] == ':';
char_u *name_start = eap->arg;
- char_u *name_end = to_name_end(eap->arg, is_global);
+ char_u *name_end = to_name_end(eap->arg, TRUE);
char_u *lambda_name;
lvar_T *lvar;
ufunc_T *ufunc;
int r;
+ // Only g:Func() can use a namespace.
+ if (name_start[1] == ':' && !is_global)
+ {
+ semsg(_(e_namespace), name_start);
+ return NULL;
+ }
if (check_defined(name_start, name_end - name_start, cctx) == FAIL)
return NULL;