diff options
author | Lars Henriksen <LarsHenriksen@get2net.dk> | 2018-09-14 21:32:52 +0200 |
---|---|---|
committer | Lukas Fleischer <lfleischer@calcurse.org> | 2018-10-21 20:02:57 +0200 |
commit | 2112b1ca2e821e08bbfe6c197856860b6d49b69f (patch) | |
tree | f3098f89779bd05fad8096defca9c11e01d83bce /src/queue.c | |
parent | 2339d78cbd562319473a34a36390378df64ade00 (diff) | |
download | calcurse-2112b1ca2e821e08bbfe6c197856860b6d49b69f.tar.gz calcurse-2112b1ca2e821e08bbfe6c197856860b6d49b69f.zip |
System message queue
The screen and user interaction is managed by the main thread. Other parts of
calcurse (threads) wishing to use the screen or communicate with the user, must
do it via the main thread.
For this purpose the main input loop is extended with a message queue. A thread
may insert a message in the queue. The main thread tests for messages before
listening for user commands. If a message is present, it is displayed (in a popup
window) for the user to acknowledge. Depending on the message other actions may
be performed, e.g. the message could be turned into a "system appointment/event"
and inserted among the usual appointments.
Signed-off-by: Lukas Fleischer <lfleischer@calcurse.org>
Diffstat (limited to 'src/queue.c')
-rw-r--r-- | src/queue.c | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/src/queue.c b/src/queue.c new file mode 100644 index 0000000..939b502 --- /dev/null +++ b/src/queue.c @@ -0,0 +1,90 @@ +#include "calcurse.h" + +/* + * A queue for calcurse system messages. + */ +llist_t sysqueue; + +void que_init(void) +{ + LLIST_INIT(&sysqueue); +} + +/* + * Test for queued system events. + */ +int que_ued(void) +{ + return sysqueue.head ? 1 : 0; +} + +/* + * Insert a system event at the tail of the queue. + */ +struct event *que_ins(char *mesg, time_t time, int id) +{ + struct event *ev; + + ev = mem_malloc(sizeof(struct event)); + ev->mesg = mem_strdup(mesg); + ev->day = time; + ev->id = id; + ev->note = NULL; + LLIST_ADD(&sysqueue, ev); + + return ev; +} + +/* + * Get the system event at the head of the queue. + */ +struct event *que_get(void) +{ + return sysqueue.head ? sysqueue.head->data : NULL; +} + +/* + * Remove the system event at the head of the queue. + */ +void que_rem(void) +{ + struct event *ev; + + if (!sysqueue.head) + return; + else + ev = sysqueue.head->data; + mem_free(ev->mesg); + mem_free(ev); + LLIST_REMOVE(&sysqueue, sysqueue.head); +} + +/* + * Display the system event at the head of the queue in a popup window. + */ +void que_show(void) +{ + struct event *ev; + char *date; + + if (!que_ued()) + return; + ev = que_get(); + date = date_sec2date_str(ev->day, "%F %T"); + item_in_popup(date, "", ev->mesg, _("System event")); + mem_free(date); +} + +/* + * Save the system event at the head of the queue as an appointment. + */ +void que_save(void) +{ + struct event *ev; + + if (!que_ued()) + return; + ev = que_get(); + apoint_new(ev->mesg, NULL, ev->day, 0, APOINT_NULL); + io_set_modified(); +} |