diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-10-04 13:42:34 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-10-04 13:42:34 +0200 |
commit | 7b5d5442696d86daab062592d5c86c829757c352 (patch) | |
tree | 9820f883da5e85b119c51bb04fbccc48fd9d10e8 | |
parent | 2bb2658bef9fb25b320f87147261b7154494a86f (diff) | |
download | vim-git-7b5d5442696d86daab062592d5c86c829757c352.tar.gz |
patch 8.2.1796: Vim9: invalid memory access with weird function namev8.2.1796
Problem: Vim9: invalid memory access with weird function name. (Dhiraj
Mishra)
Solution: Check the name is valid. Add a test.
-rw-r--r-- | src/testdir/test_vim9_func.vim | 26 | ||||
-rw-r--r-- | src/userfunc.c | 9 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 36 insertions, 1 deletions
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim index 509c7fa7e..4f741bb45 100644 --- a/src/testdir/test_vim9_func.vim +++ b/src/testdir/test_vim9_func.vim @@ -1906,6 +1906,32 @@ def Test_closure_in_map() delete('XclosureDir', 'rf') enddef +def Test_invalid_function_name() + var lines =<< trim END + vim9script + def s: list<string> + END + CheckScriptFailure(lines, 'E129:') + + lines =<< trim END + vim9script + def g: list<string> + END + CheckScriptFailure(lines, 'E129:') + + lines =<< trim END + vim9script + def <SID>: list<string> + END + CheckScriptFailure(lines, 'E884:') + + lines =<< trim END + vim9script + def F list<string> + END + CheckScriptFailure(lines, 'E488:') +enddef + def Test_partial_call() var Xsetlist = function('setloclist', [0]) Xsetlist([], ' ', {'title': 'test'}) diff --git a/src/userfunc.c b/src/userfunc.c index 1d96a358a..39d8fb25b 100644 --- a/src/userfunc.c +++ b/src/userfunc.c @@ -2374,6 +2374,7 @@ trans_function_name( int extra = 0; lval_T lv; int vim9script; + static char *e_function_name = N_("E129: Function name required"); if (fdp != NULL) CLEAR_POINTER(fdp); @@ -2401,7 +2402,7 @@ trans_function_name( if (end == start) { if (!skip) - emsg(_("E129: Function name required")); + emsg(_(e_function_name)); goto theend; } if (end == NULL || (lv.ll_tv != NULL && (lead > 2 || lv.ll_range))) @@ -2517,6 +2518,12 @@ trans_function_name( } len = (int)(end - lv.ll_name); } + if (len <= 0) + { + if (!skip) + emsg(_(e_function_name)); + goto theend; + } // In Vim9 script a user function is script-local by default. vim9script = ASCII_ISUPPER(*start) && in_vim9script(); diff --git a/src/version.c b/src/version.c index 984da5f24..09109b045 100644 --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1796, +/**/ 1795, /**/ 1794, |