X-Git-Url: https://git.danieliu.xyz/?p=dwm.git;a=blobdiff_plain;f=util.c;h=fe044fc7b7978d1f3c23768e315aae415d90b11a;hp=8b36a3f21d34d49e658c847baa727fb0972f255c;hb=HEAD;hpb=9715ba82aa4d256a43b3a166c88f3409b873eb32 diff --git a/util.c b/util.c index 8b36a3f..fe044fc 100644 --- a/util.c +++ b/util.c @@ -1,54 +1,35 @@ -/* (C)opyright MMVI-MMVII Anselm R. Garbe - * See LICENSE file for license details. - */ -#include "dwm.h" +/* See LICENSE file for copyright and license details. */ #include #include #include -#include -#include +#include -/* extern */ +#include "util.h" void * -emallocz(unsigned int size) { - void *res = calloc(1, size); +ecalloc(size_t nmemb, size_t size) +{ + void *p; - if(!res) - eprint("fatal: could not malloc() %u bytes\n", size); - return res; + if (!(p = calloc(nmemb, size))) + die("calloc:"); + return p; } void -eprint(const char *errstr, ...) { +die(const char *fmt, ...) { va_list ap; - va_start(ap, errstr); - vfprintf(stderr, errstr, ap); + va_start(ap, fmt); + vfprintf(stderr, fmt, ap); va_end(ap); - exit(EXIT_FAILURE); -} - -void -spawn(Arg *arg) { - static char *shell = NULL; - if(!shell && !(shell = getenv("SHELL"))) - shell = "/bin/sh"; - if(!arg->cmd) - return; - /* The double-fork construct avoids zombie processes and keeps the code - * clean from stupid signal handlers. */ - if(fork() == 0) { - if(fork() == 0) { - if(dpy) - close(ConnectionNumber(dpy)); - setsid(); - execl(shell, shell, "-c", arg->cmd, (char *)NULL); - fprintf(stderr, "dwm: execl '%s -c %s'", shell, arg->cmd); - perror(" failed"); - } - exit(0); + if (fmt[0] && fmt[strlen(fmt)-1] == ':') { + fputc(' ', stderr); + perror(NULL); + } else { + fputc('\n', stderr); } - wait(0); + + exit(1); }