diff options
author | Daniel Lange <DLange@git.local> | 2016-04-11 13:01:07 +0200 |
---|---|---|
committer | Daniel Lange <DLange@git.local> | 2016-04-11 13:01:07 +0200 |
commit | ff9409b1737627857eb47f64f536a3f66b6a09a4 (patch) | |
tree | 61b631ba551e68a4f656b8b76ff7bd0d9955fc64 /XAlloc.c | |
parent | f75ab6d2c11e8a8e18191b087564aedebbeb96c5 (diff) | |
download | debian_htop-ff9409b1737627857eb47f64f536a3f66b6a09a4.tar.gz debian_htop-ff9409b1737627857eb47f64f536a3f66b6a09a4.tar.bz2 debian_htop-ff9409b1737627857eb47f64f536a3f66b6a09a4.zip |
Imported Upstream version 2.0.0upstream/2.0.0
Diffstat (limited to 'XAlloc.c')
-rw-r--r-- | XAlloc.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/XAlloc.c b/XAlloc.c new file mode 100644 index 0000000..cc29021 --- /dev/null +++ b/XAlloc.c @@ -0,0 +1,52 @@ + +#include "XAlloc.h" +#include "RichString.h" + +#ifndef _GNU_SOURCE +#define _GNU_SOURCE +#endif +#include <err.h> +#include <stdlib.h> +#include <string.h> + +/*{ +#include <stdlib.h> +}*/ + +static inline void fail() { + curs_set(1); + endwin(); + err(1, NULL); +} + +void* xMalloc(size_t size) { + void* data = malloc(size); + if (!data && size > 0) { + fail(); + } + return data; +} + +void* xCalloc(size_t nmemb, size_t size) { + void* data = calloc(nmemb, size); + if (!data) { + fail(); + } + return data; +} + +void* xRealloc(void* ptr, size_t size) { + void* data = realloc(ptr, size); + if (!data && size > 0) { + fail(); + } + return data; +} + +char* xStrdup(const char* str) { + char* data = strdup(str); + if (!data && str) { + fail(); + } + return data; +} |