Problem: possible memory leak in vim9generics.c
Solution: Free ret_free if ga_grow() fails and before returning
(Lidong Yan).
In parse_generic_func_type_args() at vim9generics.c, we allocate memory
in ret_name and should free it by calling vim_free(ret_free). If
ga_grow on gfatab->gfat_args failed, we forget to call vim_free(ret_free)
thus would cause a leak. Add vim_free(ret_free) before return NULL.
closes: #17821
Signed-off-by: Lidong Yan <yldhome2d2@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 1581,
/**/
1580,
/**/
char *ret_name = type_name(type_arg, &ret_free);
// create space for the name and the new type
- if (ga_grow(&gfatab->gfat_args, 1) == FAIL)
+ if (ga_grow(&gfatab->gfat_args, 1) == FAIL) {
+ vim_free(ret_free);
return NULL;
+ }
generic_arg = (generic_T *)gfatab->gfat_args.ga_data +
gfatab->gfat_args.ga_len;
gfatab->gfat_args.ga_len++;