From 7623d308f7569b91557fc350367df76fbd487409 Mon Sep 17 00:00:00 2001 From: Xavier Claessens Date: Mon, 13 Oct 2008 07:55:13 +0000 Subject: disconnect chatroom signals when they are removed from the mgr svn path=/trunk/; revision=1569 --- libempathy/empathy-chatroom-manager.c | 34 ++++++++++++++++++++++++---------- 1 file changed, 24 insertions(+), 10 deletions(-) (limited to 'libempathy') diff --git a/libempathy/empathy-chatroom-manager.c b/libempathy/empathy-chatroom-manager.c index 373ac8c29..be6eb79f2 100644 --- a/libempathy/empathy-chatroom-manager.c +++ b/libempathy/empathy-chatroom-manager.c @@ -56,6 +56,7 @@ static gboolean chatroom_manager_file_parse (EmpathyChatroomManager static void chatroom_manager_parse_chatroom (EmpathyChatroomManager *manager, xmlNodePtr node); static gboolean chatroom_manager_file_save (EmpathyChatroomManager *manager); +static void reset_save_timeout (EmpathyChatroomManager *self); enum { CHATROOM_ADDED, @@ -203,11 +204,20 @@ empathy_chatroom_manager_init (EmpathyChatroomManager *manager) manager->priv = priv; } +static void +chatroom_changed_cb (EmpathyChatroom *chatroom, + GParamSpec *spec, + EmpathyChatroomManager *self) +{ + reset_save_timeout (self); +} + static void chatroom_manager_finalize (GObject *object) { EmpathyChatroomManager *self = EMPATHY_CHATROOM_MANAGER (object); EmpathyChatroomManagerPriv *priv; + GList *l; priv = GET_PRIV (object); @@ -219,7 +229,16 @@ chatroom_manager_finalize (GObject *object) chatroom_manager_file_save (self); } - g_list_foreach (priv->chatrooms, (GFunc) g_object_unref, NULL); + for (l = priv->chatrooms; l != NULL; l = g_list_next (l)) + { + EmpathyChatroom *chatroom = l->data; + + g_signal_handlers_disconnect_by_func (chatroom, chatroom_changed_cb, + self); + + g_object_unref (chatroom); + } + g_list_free (priv->chatrooms); g_free (priv->file); @@ -269,14 +288,6 @@ reset_save_timeout (EmpathyChatroomManager *self) (GSourceFunc) save_timeout, self); } -static void -chatroom_changed_cb (EmpathyChatroom *chatroom, - GParamSpec *spec, - EmpathyChatroomManager *self) -{ - reset_save_timeout (self); -} - static void add_chatroom (EmpathyChatroomManager *self, EmpathyChatroom *chatroom) @@ -285,7 +296,6 @@ add_chatroom (EmpathyChatroomManager *self, priv->chatrooms = g_list_prepend (priv->chatrooms, g_object_ref (chatroom)); - /* FIXME: disconnect when removed */ g_signal_connect (chatroom, "notify::favorite", G_CALLBACK (chatroom_changed_cb), self); g_signal_connect (chatroom, "notify::name", @@ -361,6 +371,10 @@ empathy_chatroom_manager_remove (EmpathyChatroomManager *manager, } g_signal_emit (manager, signals[CHATROOM_REMOVED], 0, this_chatroom); + + g_signal_handlers_disconnect_by_func (chatroom, chatroom_changed_cb, + manager); + g_object_unref (this_chatroom); break; } -- cgit v1.2.3