X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=src%2Fmain.c;h=3071fbff370d560711bbbda3a88759c4d645f118;hb=ff73132b49900fddd76e82c75372b60f49d44889;hp=af019b36d17f41953b0a05b1dd111fdab4dcba3b;hpb=95a4a1492b982e64458a2b0ed0260cf853c728a4;p=lackey diff --git a/src/main.c b/src/main.c index af019b3..3071fbf 100644 --- a/src/main.c +++ b/src/main.c @@ -15,16 +15,26 @@ * along with this program. If not, see . */ +#define _XOPEN_SOURCE + #include #include #include #include #include "util.h" +#include "conf.h" #include "date.h" #include "cal.h" #include "view.h" +/* Config parser */ +static void on_config(const char *group, const char *name, const char *key, const char *value) +{ + view_config(group, name, key, value); + cal_config(group, name, key, value); +} + /* Control-C handler, so we don't hose the therminal */ static void on_sigint(int signum) { @@ -38,6 +48,10 @@ int main(int argc, char **argv) /* Misc setup */ signal(SIGINT, on_sigint); + /* Set default escape timeout */ + if (!getenv("ESCDELAY")) + putenv("ESCDELAY=25"); + /* Setup Curses */ setlocale(LC_ALL, ""); initscr(); @@ -61,8 +75,12 @@ int main(int argc, char **argv) init_pair(COLOR_WORK, COLOR_MAGENTA, -1); init_pair(COLOR_OTHER, COLOR_RED, -1); + /* Configuration */ + conf_setup(argc, argv, ".lackeyrc", on_config); + /* Initialize */ util_init(); + conf_init(); date_init(); cal_init(); view_init(); @@ -73,6 +91,7 @@ int main(int argc, char **argv) /* Run */ while (1) { MEVENT btn; + conf_sync(); int chr = getch(); if (chr == 'q') break;