X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=src%2Fmain.c;h=bec3b1c09616555ff72d6308a51735f92e056b69;hb=035bf3a6553362883c2451c36afc7766002941a3;hp=6daa8f8cfcfcdf9770065c6948758d397ce1ffb5;hpb=c222556b46998f2eb2466ded089c1b01091c88a6;p=lackey diff --git a/src/main.c b/src/main.c index 6daa8f8..bec3b1c 100644 --- a/src/main.c +++ b/src/main.c @@ -1,39 +1,29 @@ /* * Copyright (C) 2012 Andy Spencer - * + * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. - * + * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. - * + * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ -#include #include #include -#include #include #include -#include "main.h" -#include "screen.h" - -/* Debugging */ -year_t YEAR = 2012; -month_t MONTH = 8; -day_t DAY = 29; - -event_t *EVENTS = NULL; - -/* Static data */ -static FILE *debug_fd = NULL; +#include "util.h" +#include "date.h" +#include "cal.h" +#include "view.h" /* Control-C handler, so we don't hose the therminal */ static void on_sigint(int signum) @@ -42,47 +32,13 @@ static void on_sigint(int signum) exit(0); } -/* Debugging functions */ -int debug(char *fmt, ...) -{ - int rval; - va_list ap; - - /* Log to debug file */ - va_start(ap, fmt); - vfprintf(debug_fd, "debug: ", ap); - rval = vfprintf(debug_fd, fmt, ap); - - /* Log to status bar */ - 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(); - - va_end(ap); - return rval; -} - /* Main */ int main(int argc, char **argv) { /* Misc setup */ signal(SIGINT, on_sigint); - debug_fd = fopen("/tmp/lackey.log", "w+"); - - /* Time setup */ - time_t sec = time(NULL); - struct tm *tm = localtime(&sec); - YEAR = tm->tm_year+1900; - MONTH = tm->tm_mon; - DAY = tm->tm_mday-1; - EVENTS = event_get(2012, JAN, 0, 366); - - /* Curses setup */ + /* Setup Curses */ setlocale(LC_ALL, ""); initscr(); cbreak(); @@ -90,17 +46,29 @@ int main(int argc, char **argv) keypad(stdscr, TRUE); start_color(); curs_set(false); + use_default_colors(); mousemask(ALL_MOUSE_EVENTS, NULL); - init_pair(COLOR_TITLE, COLOR_GREEN, COLOR_BLACK); - init_pair(COLOR_ERROR, COLOR_RED, COLOR_BLACK); - screen_init(); - screen_draw(); - /* Debug */ - for (event_t *e = EVENTS; e; e = e->next) - debug("event: %04d-%02d-%02d %02d:%02d: %s - %s\n", - e->start.year, e->start.month, e->start.day, - e->start.hour, e->start.min, e->name, e->desc); + init_pair(COLOR_TITLE, COLOR_GREEN, -1); + init_pair(COLOR_ERROR, COLOR_RED, -1); + + init_pair(COLOR_NEW, COLOR_RED, -1); + init_pair(COLOR_WIP, COLOR_YELLOW, -1); + init_pair(COLOR_DONE, COLOR_GREEN, -1); + + init_pair(COLOR_CLASS, COLOR_BLUE, -1); + init_pair(COLOR_EC, COLOR_GREEN, -1); + init_pair(COLOR_WORK, COLOR_MAGENTA, -1); + init_pair(COLOR_OTHER, COLOR_RED, -1); + + /* Initialize */ + util_init(); + date_init(); + cal_init(); + view_init(); + + /* Draw initial view */ + view_draw(); /* Run */ while (1) { @@ -117,22 +85,22 @@ int main(int argc, char **argv) case KEY_RESIZE: endwin(); refresh(); - screen_resize(); - screen_draw(); + view_resize(); + view_draw(); continue; case '\14': clear(); case '\7': - screen_draw(); + view_draw(); continue; } - if (screen_run(chr, btn.bstate, btn.y, btn.x)) + if (view_run(chr, btn.bstate, btn.y, btn.x)) continue; - //debug("Unhandled key: Dec %3d, Hex %02x, Oct %03o, Chr <%c>\n", - // chr, chr, chr, chr); + 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; }