aboutsummaryrefslogtreecommitdiff
path: root/util.c
diff options
context:
space:
mode:
authorMarkus Teich <markus.teich@stusta.mhn.de>2016-06-12 00:55:09 +0200
committerMarkus Teich <markus.teich@stusta.mhn.de>2016-06-12 00:55:09 +0200
commitec1ce068edb4cc0b222008b295b22c565e5339df (patch)
treea480043736f76e22106063779d2ab046f6e47700 /util.c
parent6416f0fbfe16593e019e1aae491b2dda53e20b8d (diff)
update util: logging and assertions
Diffstat (limited to 'util.c')
-rw-r--r--util.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/util.c b/util.c
new file mode 100644
index 0000000..99d4c9b
--- /dev/null
+++ b/util.c
@@ -0,0 +1,47 @@
+
+#include <stdarg.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "util.h"
+
+static void xvprintf(const char *, va_list);
+
+void
+eprintf(const char *fmt, ...)
+{
+ va_list ap;
+
+ va_start(ap, fmt);
+ xvprintf(fmt, ap);
+ va_end(ap);
+
+ abort();
+}
+
+void
+weprintf(const char *fmt, ...)
+{
+ va_list ap;
+
+ va_start(ap, fmt);
+ xvprintf(fmt, ap);
+ va_end(ap);
+}
+
+void
+xvprintf(const char *fmt, va_list ap)
+{
+ /**TODO: provide other logging target than stderr */
+ fputs("libbrandt: ", stderr);
+
+ vfprintf(stderr, fmt, ap);
+
+ if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
+ fputc(' ', stderr);
+ perror(NULL);
+ } else {
+ fputc('\n', stderr);
+ }
+}