[tracker/wip/carlosg/tracker-3.0-api-breaks: 78/79] libtracker-sparql: Always emit TrackerNotifier::events on an idle
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/tracker-3.0-api-breaks: 78/79] libtracker-sparql: Always emit TrackerNotifier::events on an idle
- Date: Mon, 27 Jan 2020 13:01:37 +0000 (UTC)
commit b447b49b69de001109e65d23332d98f486b17935
Author: Carlos Garnacho <carlosg gnome org>
Date: Mon Jan 27 13:51:05 2020 +0100
libtracker-sparql: Always emit TrackerNotifier::events on an idle
This ensures the callback will be dispatched outside of the updates
thread, and presumably into the main application thread/main context.
Also makes this function dependent on a main loop.
src/libtracker-sparql/tracker-notifier.c | 19 ++++++++++++++-----
1 file changed, 14 insertions(+), 5 deletions(-)
---
diff --git a/src/libtracker-sparql/tracker-notifier.c b/src/libtracker-sparql/tracker-notifier.c
index c1fe97fdb..0133ccb77 100644
--- a/src/libtracker-sparql/tracker-notifier.c
+++ b/src/libtracker-sparql/tracker-notifier.c
@@ -289,7 +289,7 @@ tracker_notifier_event_cache_take_events (TrackerNotifierEventCache *cache)
return events;
}
-static void
+static gboolean
tracker_notifier_emit_events (TrackerNotifierEventCache *cache)
{
GPtrArray *events;
@@ -300,6 +300,17 @@ tracker_notifier_emit_events (TrackerNotifierEventCache *cache)
g_signal_emit (cache->notifier, signals[EVENTS], 0, cache->service, cache->graph, events);
g_ptr_array_unref (events);
}
+
+ return G_SOURCE_REMOVE;
+}
+
+static void
+tracker_notifier_emit_events_in_idle (TrackerNotifierEventCache *cache)
+{
+ g_idle_add_full (G_PRIORITY_DEFAULT,
+ (GSourceFunc) tracker_notifier_emit_events,
+ cache,
+ (GDestroyNotify) _tracker_notifier_event_cache_free);
}
static gchar *
@@ -389,8 +400,7 @@ query_extra_info_cb (GObject *object,
g_object_unref (cursor);
- tracker_notifier_emit_events (cache);
- _tracker_notifier_event_cache_free (cache);
+ tracker_notifier_emit_events_in_idle (cache);
}
static void
@@ -424,8 +434,7 @@ _tracker_notifier_event_cache_flush_events (TrackerNotifierEventCache *cache)
if (priv->flags & TRACKER_NOTIFIER_FLAG_QUERY_URN) {
tracker_notifier_query_extra_info (notifier, cache);
} else {
- tracker_notifier_emit_events (cache);
- _tracker_notifier_event_cache_free (cache);
+ tracker_notifier_emit_events_in_idle (cache);
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]