[tracker/wip/carlosg/tracker-3.0-api-breaks] libtracker-direct: Unref data manager after we free all notifiers
- From: Sam Thursfield <sthursfield src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/tracker-3.0-api-breaks] libtracker-direct: Unref data manager after we free all notifiers
- Date: Wed, 22 Jan 2020 00:24:03 +0000 (UTC)
commit 0dfed9f6ac33f71a0b7ad9bd027d637c53348779
Author: Sam Thursfield <sam afuera me uk>
Date: Wed Jan 22 01:18:50 2020 +0100
libtracker-direct: Unref data manager after we free all notifiers
The detach_notifier() function accesses the priv->data_manager object.
We can't free priv->data_manager in tracker_direct_connetion_dispose()
because we later call detach_notifier().
There doesn't seem to be a ref cycle being broken here, so I moved the
priv->data_manager free later on.
src/libtracker-direct/tracker-direct.c | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
---
diff --git a/src/libtracker-direct/tracker-direct.c b/src/libtracker-direct/tracker-direct.c
index 9270f74e8..61ca72fe2 100644
--- a/src/libtracker-direct/tracker-direct.c
+++ b/src/libtracker-direct/tracker-direct.c
@@ -525,11 +525,6 @@ tracker_direct_connection_dispose (GObject *object)
priv->select_pool = NULL;
}
- if (priv->data_manager) {
- tracker_data_manager_shutdown (priv->data_manager);
- g_clear_object (&priv->data_manager);
- }
-
G_OBJECT_CLASS (tracker_direct_connection_parent_class)->dispose (object);
}
@@ -551,6 +546,11 @@ tracker_direct_connection_finalize (GObject *object)
detach_notifier (conn, notifier);
}
+ if (priv->data_manager) {
+ tracker_data_manager_shutdown (priv->data_manager);
+ g_clear_object (&priv->data_manager);
+ }
+
g_clear_object (&priv->store);
g_clear_object (&priv->ontology);
g_clear_object (&priv->namespace_manager);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]