MINOR: new function my_realloc2 = realloc + free upon failure

When realloc fails to allocate memory, the original pointer is not
freed. Sometime people override the original pointer with the pointer
returned by realloc which is NULL in case of failure. This results
in a memory leak because the memory pointed by the original pointer
cannot be freed.
This commit is contained in:
Hubert Verstraete 2016-06-28 22:41:00 +02:00 committed by Willy Tarreau
parent a9300a3d5a
commit 2eae3a0497

View File

@ -1093,4 +1093,15 @@ static inline unsigned long long rdtsc()
struct list; struct list;
int list_append_word(struct list *li, const char *str, char **err); int list_append_word(struct list *li, const char *str, char **err);
/* same as realloc() except that ptr is also freed upon failure */
static inline void *my_realloc2(void *ptr, size_t size)
{
void *ret;
ret = realloc(ptr, size);
if (!ret && size)
free(ptr);
return ret;
}
#endif /* _COMMON_STANDARD_H */ #endif /* _COMMON_STANDARD_H */