Xinqi Bao's Git
projects
/
dmenu.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
drw_text: improve both performance and correctness
[dmenu.git]
/
util.c
diff --git
a/util.c
b/util.c
index
0a8aada
..
fe044fc
100644
(file)
--- a/
util.c
+++ b/
util.c
@@
-1,36
+1,35
@@
-/* © 2006-2007 Anselm R. Garbe <garbeam at gmail dot com>
- * © 2006-2007 Sander van Dijk <a dot h dot vandijk 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 <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include "util.h"
+
void *
void *
-emalloc(unsigned int size) {
- void *res = malloc(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
}
void
-
eprint(const char *errstr
, ...) {
+
die(const char *fmt
, ...) {
va_list ap;
va_list ap;
- va_start(ap,
errstr
);
- vfprintf(stderr,
errstr
, ap);
+ va_start(ap,
fmt
);
+ vfprintf(stderr,
fmt
, ap);
va_end(ap);
va_end(ap);
- exit(EXIT_FAILURE);
-}
-char *
-estrdup(const char *str) {
- void *res = strdup(str);
+ if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
+ fputc(' ', stderr);
+ perror(NULL);
+ } else {
+ fputc('\n', stderr);
+ }
- if(!res)
- eprint("fatal: could not malloc() %u bytes\n", strlen(str));
- return res;
+ exit(1);
}
}