From cf4448abf4112f6d2edb780fe6b1edf27ad7ea82 Mon Sep 17 00:00:00 2001 From: Not Zed Date: Mon, 13 Jan 2003 06:07:10 +0000 Subject: hook onto destroy to remove dialogue from active table. (error_response): 2003-01-13 Not Zed * mail-mt.c (mail_msg_check_error): hook onto destroy to remove dialogue from active table. (error_response): Just destroy on any response, dont unref either. svn path=/trunk/; revision=19423 --- mail/mail-mt.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'mail/mail-mt.c') diff --git a/mail/mail-mt.c b/mail/mail-mt.c index adbdbb0828..189576d8d3 100644 --- a/mail/mail-mt.c +++ b/mail/mail-mt.c @@ -215,12 +215,14 @@ void mail_msg_free(void *msg) /* hash table of ops->dialogue of active errors */ static GHashTable *active_errors = NULL; -static void error_response(GtkObject *o, int button, void *data) +static void error_destroy(GtkObject *o, void *data) { g_hash_table_remove(active_errors, data); +} +static void error_response(GtkObject *o, int button, void *data) +{ gtk_widget_destroy((GtkWidget *)o); - g_object_unref(o); } void mail_msg_check_error(void *msg) @@ -268,6 +270,7 @@ void mail_msg_check_error(void *msg) gd = (GtkDialog *)gtk_message_dialog_new(NULL, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, "%s", text); g_hash_table_insert(active_errors, m->ops, gd); g_signal_connect(gd, "response", G_CALLBACK(error_response), m->ops); + g_signal_connect(gd, "destroy", G_CALLBACK(error_destroy), m->ops); gtk_widget_show((GtkWidget *)gd); } -- cgit v1.2.3