From 5181d90b017715bab95b991f258a4df2b42263fc Mon Sep 17 00:00:00 2001 From: Frederic Culot Date: Wed, 29 Jul 2009 19:11:57 +0000 Subject: Avoid multiple notifications of the same appointment when running in background. --- src/dmon.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) (limited to 'src/dmon.c') diff --git a/src/dmon.c b/src/dmon.c index 4a93bcb..72f4887 100644 --- a/src/dmon.c +++ b/src/dmon.c @@ -1,4 +1,4 @@ -/* $calcurse: dmon.c,v 1.7 2009/07/27 21:02:55 culot Exp $ */ +/* $calcurse: dmon.c,v 1.8 2009/07/29 19:11:58 culot Exp $ */ /* * Calcurse - text-based organizer @@ -161,6 +161,7 @@ daemonize (int status) void dmon_start (int parent_exit_status) { + struct notify_app_s next; conf_t conf; if (!daemonize (parent_exit_status)) @@ -182,11 +183,12 @@ dmon_start (int parent_exit_status) io_load_app (); data_loaded = 1; + next.got_app = 0; for (;;) { - struct notify_app_s next; - - (void)notify_get_next (&next); + if (!next.got_app) + (void)notify_get_next (&next); + if (next.got_app) { int left; @@ -195,7 +197,10 @@ dmon_start (int parent_exit_status) left = notify_time_left (); if (left < nbar.cntdwn) - notify_launch_cmd (); + { + notify_launch_cmd (); + next.got_app = 0; + } } if (next.txt) -- cgit v1.2.3-54-g00ecf