2006-08-09 [colin] 2.4.0cvs36
authorColin Leroy <colin@colino.net>
Wed, 9 Aug 2006 18:46:14 +0000 (18:46 +0000)
committerColin Leroy <colin@colino.net>
Wed, 9 Aug 2006 18:46:14 +0000 (18:46 +0000)
* src/main.c
* src/main.h
Add a function to know whether we're exiting
* src/plugins/trayicon/trayicon.c
If exiting, don't do anything. Faster, and
avoids gtk_main_iteration reentracy causing
segfaults at exit

ChangeLog
PATCHSETS
configure.ac
src/main.c
src/main.h
src/plugins/trayicon/trayicon.c

index 359c78de6ee7e8f9a9d8708d9f069ad67ed8d700..921aa010d0316d23fae38d079e16f72c49599490 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,13 @@
+2006-08-09 [colin]     2.4.0cvs36
+
+       * src/main.c
+       * src/main.h
+               Add a function to know whether we're exiting
+       * src/plugins/trayicon/trayicon.c
+               If exiting, don't do anything. Faster, and
+               avoids gtk_main_iteration reentracy causing
+               segfaults at exit
+
 2006-08-09 [colin]     2.4.0cvs35
 
        * src/messageview.c
index e5a96797ba016b4b4ed0a3d6a8e4169abac33c79..4680bcbcf34a954bb6c0ec607bd5ff4cbe7accd1 100644 (file)
--- a/PATCHSETS
+++ b/PATCHSETS
 ( cvs diff -u -r 1.83.2.76 -r 1.83.2.77 src/mimeview.c;  cvs diff -u -r 1.20.2.11 -r 1.20.2.12 src/mimeview.h;  cvs diff -u -r 1.49.2.78 -r 1.49.2.79 src/procmime.c;  cvs diff -u -r 1.5.2.3 -r 1.5.2.4 src/gtk/gtkvscrollbutton.c;  cvs diff -u -r 1.3 -r 1.4 src/gtk/gtkvscrollbutton.h;  ) > 2.4.0cvs33.patchset
 ( cvs diff -u -r 1.382.2.298 -r 1.382.2.299 src/compose.c;  ) > 2.4.0cvs34.patchset
 ( cvs diff -u -r 1.94.2.95 -r 1.94.2.96 src/messageview.c;  cvs diff -u -r 1.83.2.77 -r 1.83.2.78 src/mimeview.c;  cvs diff -u -r 1.20.2.12 -r 1.20.2.13 src/mimeview.h;  cvs diff -u -r 1.16.2.33 -r 1.16.2.34 src/msgcache.c;  ) > 2.4.0cvs35.patchset
+( cvs diff -u -r 1.115.2.99 -r 1.115.2.100 src/main.c;  cvs diff -u -r 1.7.2.3 -r 1.7.2.4 src/main.h;  cvs diff -u -r 1.14.2.34 -r 1.14.2.35 src/plugins/trayicon/trayicon.c;  ) > 2.4.0cvs36.patchset
index 16972b25bd2a5792ba8ca20bc5e3f8793992a35e..68865f6135199c0d3a163766469906a8e4ac7ac6 100644 (file)
@@ -11,7 +11,7 @@ MINOR_VERSION=4
 MICRO_VERSION=0
 INTERFACE_AGE=0
 BINARY_AGE=0
-EXTRA_VERSION=35
+EXTRA_VERSION=36
 EXTRA_RELEASE=
 EXTRA_GTK2_VERSION=
 
index 7670f825cef676d1d21c9f848350eb73149ebc16..c8b07d656ec80e29ff275d5168d1c0fc6ad4a893 100644 (file)
@@ -638,10 +638,14 @@ static void save_all_caches(FolderItem *item, gpointer data)
                folder_item_write_cache(item);
 }
 
+static gboolean sc_exiting = FALSE;
+
 static void exit_sylpheed(MainWindow *mainwin)
 {
        gchar *filename;
 
+       sc_exiting = TRUE;
+
        debug_print("shutting down\n");
        inc_autocheck_timer_remove();
 
@@ -948,13 +952,12 @@ gboolean clean_quit(gpointer data)
 void app_will_exit(GtkWidget *widget, gpointer data)
 {
        MainWindow *mainwin = data;
-       static gboolean exiting = FALSE;
        
-       if (exiting == TRUE) {
+       if (sc_exiting == TRUE) {
                debug_print("exit pending\n");
                return;
        }
-       exiting = TRUE;
+       sc_exiting = TRUE;
        debug_print("exiting\n");
        if (compose_get_compose_list()) {
                gint val = alertpanel(_("Really quit?"),
@@ -988,6 +991,11 @@ void app_will_exit(GtkWidget *widget, gpointer data)
        gtk_main_quit();
 }
 
+gboolean sylpheed_is_exiting(void)
+{
+       return sc_exiting;
+}
+
 /*
  * CLAWS: want this public so crash dialog can delete the
  * lock file too
index 34446d185c376d9df55512bca57865d7dd6ae0ef..e4fe57d434a000254b60d64eb6de91965d27ede5 100644 (file)
@@ -28,5 +28,6 @@ extern gboolean debug_mode;
 
 void app_will_exit     (GtkWidget *widget, gpointer data);
 gboolean clean_quit    (gpointer data);
+gboolean sylpheed_is_exiting(void);
 
 #endif /* __MAIN_H__ */
index 2777ccb42829b4072f0419b3d6d275425fd5ad46..1e6f13af83c9bfe0fec12321df28cebfab05b9b9 100644 (file)
@@ -295,8 +295,11 @@ int plugin_init(gchar **error)
 
 void plugin_done(void)
 {
-       g_signal_handler_disconnect(G_OBJECT(trayicon), destroy_signal_id);
+       if (sylpheed_is_exiting())
+               return;
 
+       g_signal_handler_disconnect(G_OBJECT(trayicon), destroy_signal_id);
+       
        gtk_widget_destroy(GTK_WIDGET(trayicon));
        hooks_unregister_hook(FOLDER_ITEM_UPDATE_HOOKLIST, hook_id);