X-Git-Url: https://git.xinqibao.xyz/dwm.git/blobdiff_plain/8a34fa50f75f4d6d8af234ac0c4f6d40b988d700..2de59d0f0927cec656fc4b9f6fc9ea178fb01c1e:/util.c?ds=inline diff --git a/util.c b/util.c index 3553f5d..99842e9 100644 --- a/util.c +++ b/util.c @@ -6,6 +6,7 @@ #include #include #include +#include void error(char *errstr, ...) { @@ -16,3 +17,61 @@ error(char *errstr, ...) { exit(1); } +static void +bad_malloc(unsigned int size) +{ + fprintf(stderr, "fatal: could not malloc() %d bytes\n", + (int) size); + exit(1); +} + +void * +emallocz(unsigned int size) +{ + void *res = calloc(1, size); + if(!res) + bad_malloc(size); + return res; +} + +void * +emalloc(unsigned int size) +{ + void *res = malloc(size); + if(!res) + bad_malloc(size); + return res; +} + +void * +erealloc(void *ptr, unsigned int size) +{ + void *res = realloc(ptr, size); + if(!res) + bad_malloc(size); + return res; +} + +char * +estrdup(const char *str) +{ + void *res = strdup(str); + if(!res) + bad_malloc(strlen(str)); + return res; +} + +void +failed_assert(char *a, char *file, int line) +{ + fprintf(stderr, "Assertion \"%s\" failed at %s:%d\n", a, file, line); + abort(); +} + +void +swap(void **p1, void **p2) +{ + void *tmp = *p1; + *p1 = *p2; + *p2 = tmp; +}