Skip to content

Commit

Permalink
patch 8.2.2663: Vim9: leaking memory when inline function has an error
Browse files Browse the repository at this point in the history
Problem:    Vim9: leaking memory when inline function has an error.
Solution:   Free the partially allocated function.
  • Loading branch information
brammool committed Mar 27, 2021
1 parent 7007e31 commit 79efa2e
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 4 deletions.
13 changes: 9 additions & 4 deletions src/userfunc.c
Expand Up @@ -35,6 +35,8 @@ static char *e_funcref = N_("E718: Funcref required");
static char *e_nofunc = N_("E130: Unknown function: %s");

static void funccal_unref(funccall_T *fc, ufunc_T *fp, int force);
static void func_clear(ufunc_T *fp, int force);
static int func_free(ufunc_T *fp, int force);

void
func_init()
Expand Down Expand Up @@ -946,7 +948,7 @@ lambda_function_body(
{
int evaluate = evalarg != NULL
&& (evalarg->eval_flags & EVAL_EVALUATE);
ufunc_T *ufunc;
ufunc_T *ufunc = NULL;
exarg_T eap;
garray_T newlines;
char_u *cmdline = NULL;
Expand Down Expand Up @@ -1000,10 +1002,7 @@ lambda_function_body(
goto erret;
set_ufunc_name(ufunc, name);
if (hash_add(&func_hashtab, UF2HIKEY(ufunc)) == FAIL)
{
vim_free(ufunc);
goto erret;
}
ufunc->uf_refcount = 1;
ufunc->uf_args = *newargs;
newargs->ga_data = NULL;
Expand Down Expand Up @@ -1045,6 +1044,7 @@ lambda_function_body(

rettv->vval.v_partial = pt;
rettv->v_type = VAR_PARTIAL;
ufunc = NULL;
ret = OK;

erret:
Expand All @@ -1054,6 +1054,11 @@ lambda_function_body(
ga_clear_strings(&newlines);
ga_clear_strings(newargs);
ga_clear_strings(default_args);
if (ufunc != NULL)
{
func_clear(ufunc, TRUE);
func_free(ufunc, TRUE);
}
return ret;
}

Expand Down
2 changes: 2 additions & 0 deletions src/version.c
Expand Up @@ -750,6 +750,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
2663,
/**/
2662,
/**/
Expand Down

0 comments on commit 79efa2e

Please sign in to comment.