win32: plug memory leak on realloc() failure in syslog()
If realloc() fails then the original buffer is still valid. Free it before exiting the function. Signed-off-by: Rene Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
7234152e66
commit
149d8cbb2e
@ -43,8 +43,10 @@ void syslog(int priority, const char *fmt, ...)
|
|||||||
va_end(ap);
|
va_end(ap);
|
||||||
|
|
||||||
while ((pos = strstr(str, "%1")) != NULL) {
|
while ((pos = strstr(str, "%1")) != NULL) {
|
||||||
|
char *oldstr = str;
|
||||||
str = realloc(str, st_add(++str_len, 1));
|
str = realloc(str, st_add(++str_len, 1));
|
||||||
if (!str) {
|
if (!str) {
|
||||||
|
free(oldstr);
|
||||||
warning_errno("realloc failed");
|
warning_errno("realloc failed");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user