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;