X-Git-Url: https://git.xinqibao.xyz/dmenu.git/blobdiff_plain/3d25a327aad95e38ecd1642af58a49fc555a9d01..bf3deb6357f1c864ba6b9771a33dc31e18a68e16:/util.c

diff --git a/util.c b/util.c
index b7798d2..6b703e9 100644
--- a/util.c
+++ b/util.c
@@ -1,38 +1,33 @@
-/* (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
- * See LICENSE file for license details.
- */
-#include "dmenu.h"
+/* See LICENSE file for copyright and license details. */
 #include <stdarg.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
-#include <sys/wait.h>
-#include <unistd.h>
 
-void *
-emalloc(unsigned int size) {
-	void *res = malloc(size);
-
-	if(!res)
-		eprint("fatal: could not malloc() %u bytes\n", size);
-	return res;
-}
+#include "util.h"
 
-char *
-estrdup(const char *str) {
-	void *res = strdup(str);
+void *
+ecalloc(size_t nmemb, size_t size)
+{
+	void *p;
 
-	if(!res)
-		eprint("fatal: could not malloc() %u bytes\n", strlen(str));
-	return res;
+	if (!(p = calloc(nmemb, size)))
+		perror(NULL);
+	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);
+
+	if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
+		fputc(' ', stderr);
+		perror(NULL);
+	}
+
+	exit(1);
 }