X-Git-Url: https://jasonwoof.com/gitweb/?p=dwm.git;a=blobdiff_plain;f=util.c;h=99842e9c2032b16a095f34ca92fd06ebf02affe3;hp=3553f5d3f01ab8ad5cb3d5861a1d6811238c834f;hb=39677ec76616fe4165ef92afb14db2bef2488e30;hpb=8a34fa50f75f4d6d8af234ac0c4f6d40b988d700 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; +}