From 9625d3d92d93be52f5d89a57b27ba2400e0fc6d2 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Sat, 30 Nov 2019 22:57:53 +0100 Subject: patch 8.1.2372: VMS: failing realloc leaks memory Problem: VMS: failing realloc leaks memory. (Chakshu Gupta) Solution: Free the memory. (partly fixes #5292) --- src/os_vms.c | 12 ++++++++++-- src/version.c | 2 ++ 2 files changed, 12 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/os_vms.c b/src/os_vms.c index 769377673..8845b28a9 100644 --- a/src/os_vms.c +++ b/src/os_vms.c @@ -404,12 +404,17 @@ vms_wproc(char *name, int val) return 1; } if (--vms_match_free == 0) { + char_u **old_vms_fmatch = vms_fmatch; + /* add more space to store matches */ vms_match_alloced += EXPL_ALLOC_INC; - vms_fmatch = vim_realloc(vms_fmatch, + vms_fmatch = vim_realloc(old_vms_fmatch, sizeof(char **) * vms_match_alloced); if (!vms_fmatch) + { + vim_free(old_vms_fmatch); return 0; + } vms_match_free = EXPL_ALLOC_INC; } vms_fmatch[vms_match_num] = vim_strsave((char_u *)name); @@ -489,10 +494,13 @@ mch_expand_wildcards(int num_pat, char_u **pat, int *num_file, char_u ***file, i /* allocate memory for pointers */ if (--files_free < 1) { + char_u **old_file = *file; + files_alloced += EXPL_ALLOC_INC; - *file = vim_realloc(*file, sizeof(char_u **) * files_alloced); + *file = vim_realloc(old_file, sizeof(char_u **) * files_alloced); if (*file == NULL) { + vim_free(old_file); *file = (char_u **)""; *num_file = 0; return(FAIL); diff --git a/src/version.c b/src/version.c index 281fafc7d..790607575 100644 --- a/src/version.c +++ b/src/version.c @@ -742,6 +742,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2372, /**/ 2371, /**/ -- cgit v1.2.1