summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-04-10 20:46:48 +0200
committerBram Moolenaar <Bram@vim.org>2021-04-10 20:46:48 +0200
commitc4297697761230489a025b3e39b992cca845b1b3 (patch)
tree38fc0043474ac06bb615ca6f6cb7a918f07cfd90
parentbb8a7ce0a1bcfafca715275dbadc2ead612f82dd (diff)
downloadvim-git-c4297697761230489a025b3e39b992cca845b1b3.tar.gz
patch 8.2.2748: Vim9: memory leak when calling :def function failsv8.2.2748
Problem: Vim9: memory leak when calling :def function fails. Solution: Jump to failed_early instead of returning.
-rw-r--r--src/version.c2
-rw-r--r--src/vim9execute.c2
2 files changed, 3 insertions, 1 deletions
diff --git a/src/version.c b/src/version.c
index 9fca01a86..fa3a9a8c6 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 */
/**/
+ 2748,
+/**/
2747,
/**/
2746,
diff --git a/src/vim9execute.c b/src/vim9execute.c
index e7885ad70..017d5774e 100644
--- a/src/vim9execute.c
+++ b/src/vim9execute.c
@@ -1343,7 +1343,7 @@ call_def_function(
emsg(_(e_one_argument_too_many));
else
semsg(_(e_nr_arguments_too_many), idx);
- return FAIL;
+ goto failed_early;
}
// Put arguments on the stack, but no more than what the function expects.