/* Debug */
for (event_t *e = EVENTS; e; e = e->next)
- debug("event: %04d-%02d-%02d %02d:%02d: %s - %s\n",
+ debug("event: %04d-%02d-%02d %02d:%02d: %s - %s",
e->start.year, e->start.month, e->start.day,
e->start.hour, e->start.min, e->name, e->desc);
for (todo_t *e = TODOS; e; e = e->next)
- debug("todo: %04d-%02d-%02d %02d:%02d: %s - %s\n",
+ debug("todo: %04d-%02d-%02d %02d:%02d: %s - %s",
e->start.year, e->start.month, e->start.day,
e->start.hour, e->start.min, e->name, e->desc);
}
}
if (view_run(chr, btn.bstate, btn.y, btn.x))
continue;
- debug("main: Unhandled key - Dec %3d, Hex %02x, Oct %03o, Chr <%c>\n",
+ debug("main: Unhandled key - Dec %3d, Hex %02x, Oct %03o, Chr <%c>",
chr, chr, chr, chr);
}
- /* Cleanup, see also on_sigint */
+ /* Cleanup, see also on_sigint, error */
endwin();
return 0;
}
#include "date.h"
#include "cal.h"
#include "view.h"
+#include "util.h"
/* Static data */
static FILE *debug_fd = NULL;
+/* Helper functions */
+static void message(FILE *output_fd, const char *prefix, const char *fmt, va_list ap)
+{
+ va_list tmp;
+
+ /* Log to standard out */
+ if (output_fd) {
+ va_copy(tmp, ap);
+ fprintf(output_fd, "%s: ", prefix);
+ vfprintf(output_fd, fmt, tmp);
+ fprintf(output_fd, "\n");
+ }
+
+ /* Log to debug file */
+ if (debug_fd) {
+ va_copy(tmp, ap);
+ fprintf(debug_fd, "%s: ", prefix);
+ vfprintf(debug_fd, fmt, tmp);
+ fprintf(debug_fd, "\n");
+ }
+
+ /* Log to status bar */
+ if (stdscr) {
+ va_copy(tmp, ap);
+ mvhline(LINES-2, 0, ACS_HLINE, COLS);
+ move(LINES-1, 0);
+ attron(COLOR_PAIR(COLOR_ERROR));
+ vwprintw(stdscr, fmt, tmp);
+ attroff(COLOR_PAIR(COLOR_ERROR));
+ clrtoeol();
+ }
+}
+
/* Initialize */
void util_init(void)
{
}
/* Debugging functions */
-int debug(char *fmt, ...)
+void debug(char *fmt, ...)
{
- int rval;
va_list ap;
+ va_start(ap, fmt);
+ message(NULL, "debug", fmt, ap);
+ va_end(ap);
+}
- /* Log to debug file */
- if (debug_fd) {
- va_start(ap, fmt);
- vfprintf(debug_fd, "debug: ", ap);
- rval = vfprintf(debug_fd, fmt, ap);
- }
-
- /* Log to status bar */
+void error(char *fmt, ...)
+{
+ va_list ap;
+ va_start(ap, fmt);
+ fflush(stdout);
+ fflush(stderr);
+ message(stderr, "error", fmt, ap);
+ va_end(ap);
if (stdscr) {
- va_start(ap, fmt);
- mvhline(LINES-2, 0, ACS_HLINE, COLS);
- move(LINES-1, 0);
- attron(COLOR_PAIR(COLOR_ERROR));
- vwprintw(stdscr, fmt, ap);
- attroff(COLOR_PAIR(COLOR_ERROR));
- clrtoeol();
+ getch();
+ endwin();
}
-
- va_end(ap);
- return rval;
+ exit(-1);
}