#include "mainloop.h"
+#include "focus.h"
#include <stdio.h>
#include <stdlib.h>
ObMainLoop *loop;
gpointer data;
ObMainLoopXHandler func;
+ ObMainLoopXDoneHandler done_func;
GDestroyNotify destroy;
};
h->func(&e, h->data);
}
} while (XPending(loop->display));
+
+ for (it = loop->x_handlers; it; it = g_slist_next(it)) {
+ ObMainLoopXHandlerType *h = it->data;
+ if (h->done_func)
+ h->done_func(h->data);
+ }
} else {
/* this only runs if there were no x events received */
void ob_main_loop_x_add(ObMainLoop *loop,
ObMainLoopXHandler handler,
+ ObMainLoopXDoneHandler done_handler,
gpointer data,
GDestroyNotify notify)
{
h = g_new(ObMainLoopXHandlerType, 1);
h->loop = loop;
h->func = handler;
+ h->done_func = done_handler;
h->data = data;
h->destroy = notify;
loop->x_handlers = g_slist_prepend(loop->x_handlers, h);
static void timer_dispatch(ObMainLoop *loop, GTimeVal **wait)
{
+ GSList *it, *next;
+
+ gboolean fired = FALSE;
+
g_get_current_time(&loop->now);
- while (loop->timers != NULL) {
- ObMainLoopTimer *curr = loop->timers->data; /* get the top element */
+ for (it = loop->timers; it; it = next) {
+ ObMainLoopTimer *curr;
+
+ next = g_slist_next(it);
+
+ curr = it->data;
+
/* since timer_stop doesn't actually free the timer, we have to do our
real freeing in here.
*/
if (curr->del_me) {
/* delete the top */
- loop->timers = g_slist_delete_link(loop->timers, loop->timers);
+ loop->timers = g_slist_delete_link(loop->timers, it);
g_free(curr);
continue;
}
then re-insert. timers maintain their order and may trigger more
than once if they've waited more than one delay's worth of time.
*/
- loop->timers = g_slist_delete_link(loop->timers, loop->timers);
+ loop->timers = g_slist_delete_link(loop->timers, it);
g_time_val_add(&curr->last, curr->delay);
if (curr->func(curr->data)) {
g_time_val_add(&curr->timeout, curr->delay);
g_free(curr);
}
+ fired = TRUE;
+ }
+
+ if (fired) {
/* if at least one timer fires, then don't wait on X events, as there
may already be some in the queue from the timer callbacks.
*/
loop->ret_wait.tv_sec = loop->ret_wait.tv_usec = 0;
*wait = &loop->ret_wait;
- return;
- }
-
- if (nearest_timeout_wait(loop, &loop->ret_wait))
+ } else if (nearest_timeout_wait(loop, &loop->ret_wait))
*wait = &loop->ret_wait;
else
*wait = NULL;