From 78cde6934008f79fe498e4adc64d187b0ed47417 Mon Sep 17 00:00:00 2001 From: Vladimir Nadvornik Date: Sun, 2 Oct 2011 11:12:44 +0200 Subject: [PATCH] call notify functions in in an idle call --- src/filedata.c | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/src/filedata.c b/src/filedata.c index d90f75c1..a0bb4e99 100644 --- a/src/filedata.c +++ b/src/filedata.c @@ -2524,6 +2524,12 @@ GList *file_data_process_groups_in_selection(GList *list, gboolean ungroup, GLis implementation in view_file_list.c */ +typedef struct _NotifyIdleData NotifyIdleData; + +struct _NotifyIdleData { + FileData *fd; + NotifyType type; +}; typedef struct _NotifyData NotifyData; @@ -2597,17 +2603,29 @@ gboolean file_data_unregister_notify_func(FileDataNotifyFunc func, gpointer data } -void file_data_send_notification(FileData *fd, NotifyType type) +gboolean file_data_send_notification_idle_cb(gpointer data) { + NotifyIdleData *nid = (NotifyIdleData *)data; GList *work = notify_func_list; while (work) { NotifyData *nd = (NotifyData *)work->data; - nd->func(fd, type, nd->data); + nd->func(nid->fd, nid->type, nd->data); work = work->next; } + file_data_unref(nid->fd); + g_free(nid); + return FALSE; +} + +void file_data_send_notification(FileData *fd, NotifyType type) +{ + NotifyIdleData *nid = g_new0(NotifyIdleData, 1); + nid->fd = file_data_ref(fd); + nid->type = type; + g_idle_add_full(G_PRIORITY_HIGH, file_data_send_notification_idle_cb, nid, NULL); } static GHashTable *file_data_monitor_pool = NULL; -- 2.20.1