Xinqi Bao's Git
projects
/
dmenu.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
add support for more keypad keys
[dmenu.git]
/
util.c
diff --git
a/util.c
b/util.c
index
b4b163a
..
fe044fc
100644
(file)
--- a/
util.c
+++ b/
util.c
@@
-1,47
+1,35
@@
-/* (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 <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
-#include <sys/wait.h>
-#include <unistd.h>
-/* static */
-
-static void
-badmalloc(unsigned int size) {
- eprint("fatal: could not malloc() %u bytes\n", size);
-}
-
-/* extern */
+#include "util.h"
void *
void *
-emalloc(unsigned int size) {
- void *res = malloc(size);
+ecalloc(size_t nmemb, size_t size)
+{
+ void *p;
- if
(!res
)
-
badmalloc(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)
- badmalloc(strlen(str));
- return res;
+ exit(1);
}
}