?alloc: do not return NULL when asked for zero bytes

Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Junio C Hamano 2005-12-29 01:31:26 -08:00
Родитель 82f9d58a39
Коммит 4e7a2eccc2
1 изменённых файлов: 6 добавлений и 0 удалений

Просмотреть файл

@ -63,6 +63,8 @@ extern char *gitstrcasestr(const char *haystack, const char *needle);
static inline void *xmalloc(size_t size) static inline void *xmalloc(size_t size)
{ {
void *ret = malloc(size); void *ret = malloc(size);
if (!ret && !size)
ret = malloc(1);
if (!ret) if (!ret)
die("Out of memory, malloc failed"); die("Out of memory, malloc failed");
return ret; return ret;
@ -71,6 +73,8 @@ static inline void *xmalloc(size_t size)
static inline void *xrealloc(void *ptr, size_t size) static inline void *xrealloc(void *ptr, size_t size)
{ {
void *ret = realloc(ptr, size); void *ret = realloc(ptr, size);
if (!ret && !size)
ret = realloc(ptr, 1);
if (!ret) if (!ret)
die("Out of memory, realloc failed"); die("Out of memory, realloc failed");
return ret; return ret;
@ -79,6 +83,8 @@ static inline void *xrealloc(void *ptr, size_t size)
static inline void *xcalloc(size_t nmemb, size_t size) static inline void *xcalloc(size_t nmemb, size_t size)
{ {
void *ret = calloc(nmemb, size); void *ret = calloc(nmemb, size);
if (!ret && (!nmemb || !size))
ret = calloc(1, 1);
if (!ret) if (!ret)
die("Out of memory, calloc failed"); die("Out of memory, calloc failed");
return ret; return ret;