From db816940865c8c5e13cad68e249905f3aa5ccac0 Mon Sep 17 00:00:00 2001 From: Xavier Claessens Date: Tue, 6 Jan 2009 16:48:00 +0000 Subject: Don't own a reference to the EmpathyTpChat, otherwise it won't be finalized. svn path=/trunk/; revision=2063 --- libempathy/empathy-contact-monitor.c | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) (limited to 'libempathy/empathy-contact-monitor.c') diff --git a/libempathy/empathy-contact-monitor.c b/libempathy/empathy-contact-monitor.c index 04a384bbf..8cd55d932 100644 --- a/libempathy/empathy-contact-monitor.c +++ b/libempathy/empathy-contact-monitor.c @@ -55,6 +55,13 @@ enum { static void contact_remove_foreach (EmpathyContact *contact, EmpathyContactMonitor *monitor); +static void cl_members_changed_cb (EmpathyContactList *cl, + EmpathyContact *contact, + EmpathyContact *actor, + guint reason, + gchar *message, + gboolean is_member, + EmpathyContactMonitor *monitor); static guint signals[LAST_SIGNAL]; @@ -102,7 +109,7 @@ do_finalize (GObject *obj) EmpathyContactMonitorPriv *priv; priv = GET_PRIV (obj); - + if (priv->contacts) { g_ptr_array_foreach (priv->contacts, (GFunc) contact_remove_foreach, obj); @@ -110,6 +117,11 @@ do_finalize (GObject *obj) priv->contacts = NULL; } + if (priv->proxy) { + g_signal_handlers_disconnect_by_func (priv->proxy, + cl_members_changed_cb, obj); + } + G_OBJECT_CLASS (empathy_contact_monitor_parent_class)->finalize (obj); } @@ -370,12 +382,7 @@ empathy_contact_monitor_set_proxy (EmpathyContactMonitor *self, priv->contacts = NULL; } - if (priv->proxy != NULL) { - g_object_unref (priv->proxy); - priv->proxy = NULL; - } - - priv->proxy = g_object_ref (proxy); + priv->proxy = proxy; priv->contacts = g_ptr_array_new (); g_signal_connect (proxy, "members-changed", -- cgit v1.2.3