From 25107cd4d712e05a366ccf772ed0ca40aaaecaa9 Mon Sep 17 00:00:00 2001 From: Not Zed Date: Fri, 17 Nov 2000 06:18:01 +0000 Subject: Before we destroy ourselves, unhook ourselves from the folder update 2000-11-17 Not Zed * message-list.c (message_list_destroy): Before we destroy ourselves, unhook ourselves from the folder update events. Should fix a common crash on exit case. svn path=/trunk/; revision=6598 --- mail/ChangeLog | 6 ++++++ mail/message-list.c | 10 +++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/mail/ChangeLog b/mail/ChangeLog index a39cc0bfd2..b73815fd03 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,9 @@ +2000-11-17 Not Zed + + * message-list.c (message_list_destroy): Before we destroy + ourselves, unhook ourselves from the folder update events. Should + fix a common crash on exit case. + 2000-11-16 Jeffrey Stedfast * folder-browser-factory.c: Added the MessageViewSource bonobo diff --git a/mail/message-list.c b/mail/message-list.c index 685bfa6be0..6fc97de969 100644 --- a/mail/message-list.c +++ b/mail/message-list.c @@ -91,6 +91,9 @@ static void free_tree_ids (ETreeModel *etm); static void save_tree_state(MessageList *ml); +static void folder_changed (CamelObject *o, gpointer event_data, gpointer user_data); +static void message_changed (CamelObject *o, gpointer event_data, gpointer user_data); + /* note: @changes is owned/freed by the caller */ static void mail_do_regenerate_messagelist (MessageList *list, const gchar *search, CamelFolderChangeInfo *changes); @@ -1050,8 +1053,13 @@ message_list_destroy (GtkObject *object) if (message_list->seen_id) gtk_timeout_remove (message_list->seen_id); - if (message_list->folder) + if (message_list->folder) { + camel_object_unhook_event((CamelObject *)message_list->folder, "folder_changed", + folder_changed, message_list); + camel_object_unhook_event((CamelObject *)message_list->folder, "message_changed", + message_changed, message_list); camel_object_unref (CAMEL_OBJECT (message_list->folder)); + } GTK_OBJECT_CLASS (message_list_parent_class)->destroy (object); } -- cgit v1.2.3