X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=lib-lib%2Fmem.h;h=c95feac06936f140c1405a9671395868cbd7de83;hp=c1eb0b1cdb77237660157f01adc40fe2cbfa4623;hb=617e7d83d14e14e6a520a48e75437211b16c8834;hpb=8e037c67a88cb4680c4391134c578e3b55a80f8a diff --git a/lib-lib/mem.h b/lib-lib/mem.h index c1eb0b1..c95feac 100644 --- a/lib-lib/mem.h +++ b/lib-lib/mem.h @@ -23,49 +23,20 @@ #include #include -static inline void *xmalloc(ssize_t size) { - void *mem; - - if (size <= 0) - return NULL; - - mem = calloc(size, 1); - if (!mem) - abort(); - return mem; -} - -static inline void *xrealloc(void *mem, ssize_t newsize) { - mem = realloc(mem, newsize); - if (!mem) - abort(); - return mem; -} - -static inline void *xmemdup(const void *src, ssize_t size) { - return memcpy(xmalloc(size), src, size); -} - -static inline void *xmemdupstr(const void *src, ssize_t len) { - char *res = xmalloc(len + 1); - memcpy(res, src, len); - res[len] = '\0'; - return res; -} - #define p_new(type, count) ((type *)xmalloc(sizeof(type) * (count))) #define p_clear(p, count) ((void)memset((p), 0, sizeof(*(p)) * (count))) #define p_dup(p, count) xmemdup((p), sizeof(*(p)) * (count)) #define p_dupstr(p, len) xmemdupstr((p), (len)) +#define p_realloc(pp, count) xrealloc((void*)(pp), sizeof(**(pp)) * (count)) #ifdef __GNUC__ # define p_delete(mem_pp) \ - ({ \ + do { \ typeof(**(mem_pp)) **__ptr = (mem_pp); \ free(*__ptr); \ *__ptr = NULL; \ - }) + } while(0) #else @@ -78,8 +49,40 @@ static inline void *xmemdupstr(const void *src, ssize_t len) { #endif +static inline void *xmalloc(ssize_t size) { + void *mem; + + if (size <= 0) + return NULL; + + mem = calloc(size, 1); + if (!mem) + abort(); + return mem; +} + static inline void xmemfree(void **ptr) { p_delete(ptr); } +static inline void xrealloc(void **ptr, ssize_t newsize) { + if (newsize <= 0) { + p_delete(ptr); + } else { + *ptr = realloc(*ptr, newsize); + if (!*ptr) + abort(); + } +} + +static inline void *xmemdup(const void *src, ssize_t size) { + return memcpy(xmalloc(size), src, size); +} + +static inline void *xmemdupstr(const void *src, ssize_t len) { + char *res = memcpy(xmalloc(len + 1), src, len); + res[len] = '\0'; + return res; +} + #endif /* MUTT_LIB_LIB_MEM_H */