aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-05-26 09:57:26 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-05-26 09:57:26 +0100
commitd1ecdb5f4761f56093301b06e70022c28e0958cb (patch)
treee2c6d7e49b5340ec3bd222383f7db0fc41358240 /src/libserver
parent93a26608132961f13f868ee80a71fbb2b1ed1cbc (diff)
downloadrspamd-d1ecdb5f4761f56093301b06e70022c28e0958cb.tar.gz
rspamd-d1ecdb5f4761f56093301b06e70022c28e0958cb.zip
Call watchers on event group completion.
Diffstat (limited to 'src/libserver')
-rw-r--r--src/libserver/events.c19
-rw-r--r--src/libserver/events.h2
2 files changed, 19 insertions, 2 deletions
diff --git a/src/libserver/events.c b/src/libserver/events.c
index a1bc698f7..05d11e2d3 100644
--- a/src/libserver/events.c
+++ b/src/libserver/events.c
@@ -27,8 +27,10 @@
#include "events.h"
#define RSPAMD_SESSION_FLAG_WATCHING (1 << 0)
+#define RSPAMD_SESSION_FLAG_DESTROYING (1 << 1)
#define RSPAMD_SESSION_IS_WATCHING(s) ((s)->flags & RSPAMD_SESSION_FLAG_WATCHING)
+#define RSPAMD_SESSION_IS_DESTROYING(s) ((s)->flags & RSPAMD_SESSION_FLAG_DESTROYING)
struct rspamd_async_watcher {
event_watcher_t cb;
@@ -153,12 +155,23 @@ remove_normal_event (struct rspamd_async_session *session,
search_ev.user_data = ud;
if ((found_ev =
g_hash_table_lookup (session->events, &search_ev)) != NULL) {
- g_hash_table_remove (session->events, found_ev);
+
msg_debug ("removed event: %p, subsystem: %s, pending %d events", ud,
g_quark_to_string (found_ev->subsystem),
g_hash_table_size (session->events));
/* Remove event */
fin (ud);
+
+ /* Call watcher if needed */
+ if (found_ev->w) {
+ if (found_ev->w->remain > 0) {
+ if (--found_ev->w->remain == 0) {
+ found_ev->w->cb (found_ev->w->ud);
+ }
+ }
+ }
+
+ g_hash_table_remove (session->events, found_ev);
}
check_session_pending (session);
@@ -177,6 +190,8 @@ rspamd_session_destroy (gpointer k, gpointer v, gpointer unused)
ev->fin (ev->user_data);
}
+ /* We ignore watchers on session destroying */
+
return TRUE;
}
@@ -188,6 +203,7 @@ destroy_session (struct rspamd_async_session *session)
return FALSE;
}
+ session->flags |= RSPAMD_SESSION_FLAG_DESTROYING;
g_hash_table_foreach_remove (session->events,
rspamd_session_destroy,
session);
@@ -195,6 +211,7 @@ destroy_session (struct rspamd_async_session *session)
if (session->cleanup != NULL) {
session->cleanup (session->user_data);
}
+
return TRUE;
}
diff --git a/src/libserver/events.h b/src/libserver/events.h
index 5f5d509ef..d78c79792 100644
--- a/src/libserver/events.h
+++ b/src/libserver/events.h
@@ -32,7 +32,7 @@ struct rspamd_async_event;
struct rspamd_async_session;
typedef void (*event_finalizer_t)(gpointer ud);
-typedef void (*event_watcher_t)(guint remain, gboolean terminated, gpointer ud);
+typedef void (*event_watcher_t)(gpointer ud);
typedef gboolean (*session_finalizer_t)(gpointer user_data);
/**