summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-02-12 22:10:21 +0100
committerBram Moolenaar <Bram@vim.org>2021-02-12 22:10:21 +0100
commit31842cd0772b557eb9584a13740430db29de8a51 (patch)
tree14e2d6a59a117e2d2b951e6e21022e573ba2bca3
parent44ec21c467ddf481b422c787324ea08f375f6942 (diff)
downloadvim-git-31842cd0772b557eb9584a13740430db29de8a51.tar.gz
patch 8.2.2505: Vim9: crash after defining function with invalid return typev8.2.2505
Problem: Vim9: crash after defining function with invalid return type. Solution: Clear function growarrays. Fix memory leak.
-rw-r--r--src/testdir/test_vim9_func.vim15
-rw-r--r--src/userfunc.c7
-rw-r--r--src/version.c2
3 files changed, 24 insertions, 0 deletions
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim
index cea25a431..4bcd974e5 100644
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -254,6 +254,21 @@ def Test_return_invalid()
defcompile
END
CheckScriptFailure(lines, 'E1010:', 2)
+
+ lines =<< trim END
+ vim9script
+ def Test(Fun: func(number): number): list<number>
+ return map([1, 2, 3], (_, i) => Fun(i))
+ enddef
+ defcompile
+ def Inc(nr: number): nr
+ return nr + 2
+ enddef
+ echo Test(Inc)
+ END
+ # doing this twice was leaking memory
+ CheckScriptFailure(lines, 'E1010:')
+ CheckScriptFailure(lines, 'E1010:')
enddef
func Increment()
diff --git a/src/userfunc.c b/src/userfunc.c
index c9b15fd63..3e1762189 100644
--- a/src/userfunc.c
+++ b/src/userfunc.c
@@ -3955,8 +3955,15 @@ define_function(exarg_T *eap, char_u *name_arg)
erret:
ga_clear_strings(&newargs);
ga_clear_strings(&default_args);
+ if (fp != NULL)
+ {
+ ga_init(&fp->uf_args);
+ ga_init(&fp->uf_def_args);
+ }
errret_2:
ga_clear_strings(&newlines);
+ if (fp != NULL)
+ VIM_CLEAR(fp->uf_arg_types);
ret_free:
ga_clear_strings(&argtypes);
vim_free(skip_until);
diff --git a/src/version.c b/src/version.c
index 465b5b04a..6ec23a95a 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 */
/**/
+ 2505,
+/**/
2504,
/**/
2503,