From 2d0e2bf2558698db242fbc382675ee00044c0d76 Mon Sep 17 00:00:00 2001 From: Rikard Falkeborn Date: Mon, 20 Jul 2015 21:34:10 +0200 Subject: pacman/util.c: Fix memory leak if realloc fails Signed-off-by: Allan McRae --- src/pacman/util.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/pacman/util.c b/src/pacman/util.c index dd6e218a..3d71d8b0 100644 --- a/src/pacman/util.c +++ b/src/pacman/util.c @@ -1449,11 +1449,14 @@ int multiselect_question(char *array, int count) size_t len; /* handle buffer not being large enough to read full line case */ while(*lastchar == '\0' && lastchar[-1] != '\n') { + char *new_response; response_len += response_incr; - response = realloc(response, response_len); - if(!response) { + new_response = realloc(response, response_len); + if(!new_response) { + free(response); return -1; } + response = new_response; lastchar = response + response_len - 1; /* sentinel byte */ *lastchar = 1; -- cgit v1.2.3-70-g09d2