From ca185d17f0ed45663616b86e4c3b5beaa8b8ff57 Mon Sep 17 00:00:00 2001 From: Xavier Claessens Date: Mon, 1 Oct 2007 11:59:31 +0000 Subject: Disconnect all signals in finalize. Fixes bug #462815. 2007-10-01 Xavier Claessens * libempathy/empathy-tp-chat.c: Disconnect all signals in finalize. Fixes bug #462815. svn path=/trunk/; revision=347 --- libempathy/empathy-tp-chat.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'libempathy/empathy-tp-chat.c') diff --git a/libempathy/empathy-tp-chat.c b/libempathy/empathy-tp-chat.c index fc943f0c6..feba273bd 100644 --- a/libempathy/empathy-tp-chat.c +++ b/libempathy/empathy-tp-chat.c @@ -346,10 +346,31 @@ tp_chat_finalize (GObject *object) chat = EMPATHY_TP_CHAT (object); priv = GET_PRIV (chat); + if (priv->text_iface) { + dbus_g_proxy_disconnect_signal (priv->text_iface, "Received", + G_CALLBACK (tp_chat_received_cb), + chat); + dbus_g_proxy_disconnect_signal (priv->text_iface, "Sent", + G_CALLBACK (tp_chat_sent_cb), + chat); + dbus_g_proxy_disconnect_signal (priv->text_iface, "SendError", + G_CALLBACK (tp_chat_send_error_cb), + chat); + } + + if (priv->chat_state_iface) { + dbus_g_proxy_disconnect_signal (priv->chat_state_iface, "ChatStateChanged", + G_CALLBACK (tp_chat_state_changed_cb), + chat); + } + if (priv->tp_chan) { g_signal_handlers_disconnect_by_func (priv->tp_chan, tp_chat_destroy_cb, object); + dbus_g_proxy_disconnect_signal (DBUS_G_PROXY (priv->tp_chan), "Closed", + G_CALLBACK (tp_chat_closed_cb), + chat); if (priv->acknowledge) { empathy_debug (DEBUG_DOMAIN, "Closing channel..."); if (!tp_chan_close (DBUS_G_PROXY (priv->tp_chan), &error)) { -- cgit v1.2.3