patch 8.2.3951: Vim9: memory leak when text after a nested function
Problem: Vim9: memory leak when text after a nested function.
Solution: Free the function if text is found after "enddef".
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim
index 7a5f0f1..7b2f501 100644
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -1493,9 +1493,20 @@
enddef
def Test_using_var_as_arg()
- writefile(['def Func(x: number)', 'var x = 234', 'enddef', 'defcompile'], 'Xdef')
- assert_fails('so Xdef', 'E1006:', '', 1, 'Func')
- delete('Xdef')
+ var lines =<< trim END
+ def Func(x: number)
+ var x = 234
+ enddef
+ END
+ CheckDefFailure(lines, 'E1006:')
+
+ lines =<< trim END
+ def Func(Ref: number)
+ def Ref()
+ enddef
+ enddef
+ END
+ CheckDefFailure(lines, 'E1073:')
enddef
def DictArg(arg: dict<string>)
diff --git a/src/version.c b/src/version.c
index 56d900d..649d2fc 100644
--- a/src/version.c
+++ b/src/version.c
@@ -750,6 +750,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 3951,
+/**/
3950,
/**/
3949,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index 8882bfe..272368e 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -889,6 +889,7 @@
semsg(_(e_text_found_after_str_str),
eap->cmdidx == CMD_def ? "enddef" : "endfunction", eap->nextcmd);
r = FAIL;
+ func_ptr_unref(ufunc);
goto theend;
}