}
session->flags |= RSPAMD_SESSION_FLAG_CLEANUP;
+ khash_t(rspamd_events_hash) *uncancellable_events = kh_init(rspamd_events_hash);
kh_foreach_key (session->events, ev, {
/* Call event's finalizer */
- msg_debug_session ("removed event on destroy: %p, subsystem: %s",
- ev->user_data,
- ev->subsystem);
+ int ret;
if (ev->fin != NULL) {
+ msg_debug_session ("removed event on destroy: %p, subsystem: %s",
+ ev->user_data,
+ ev->subsystem);
ev->fin (ev->user_data);
}
+ else {
+ msg_debug_session ("NOT removed event on destroy - uncancellable: %p, subsystem: %s",
+ ev->user_data,
+ ev->subsystem);
+ /* Assume an event is uncancellable, move it to a new hash table */
+ kh_put (rspamd_events_hash, uncancellable_events, ev, &ret);
+ }
});
- kh_clear (rspamd_events_hash, session->events);
-
+ kh_destroy (rspamd_events_hash, session->events);
+ session->events = uncancellable_events;
+ msg_debug_session ("pending %d uncancellable events", kh_size (uncancellable_events));
session->flags &= ~RSPAMD_SESSION_FLAG_CLEANUP;
}