aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-shell.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/e-shell.c')
-rw-r--r--shell/e-shell.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/shell/e-shell.c b/shell/e-shell.c
index de4294bbec..382af66bb8 100644
--- a/shell/e-shell.c
+++ b/shell/e-shell.c
@@ -136,6 +136,10 @@ struct _EShellPrivate {
(Currently, it's interactive IIF there is at least one active
view.) */
unsigned int is_interactive : 1;
+
+ /* Whether quit has been requested, and the shell is now waiting for
+ permissions from all the components to quit. */
+ unsigned int preparing_to_quit : 1;
};
@@ -958,6 +962,9 @@ view_delete_event_cb (GtkWidget *widget,
return FALSE;
}
+ if (shell->priv->preparing_to_quit)
+ return TRUE;
+
/* If it's the last view, ask for confirm before actually destroying
this view. */
if (e_shell_prepare_for_quit (shell))
@@ -1196,6 +1203,7 @@ init (EShell *shell)
priv->db = CORBA_OBJECT_NIL;
priv->is_initialized = FALSE;
priv->is_interactive = FALSE;
+ priv->preparing_to_quit = FALSE;
shell->priv = priv;
}
@@ -2188,11 +2196,14 @@ e_shell_prepare_for_quit (EShell *shell)
g_return_val_if_fail (E_IS_SHELL (shell), FALSE);
priv = shell->priv;
+ priv->preparing_to_quit = TRUE;
/* Make all the views insensitive so we have some modal-like
behavior. */
- for (p = priv->views; p != NULL; p = p->next)
+ for (p = priv->views; p != NULL; p = p->next) {
+ g_print ("Insensitive %p\n", p->data);
gtk_widget_set_sensitive (GTK_WIDGET (p->data), FALSE);
+ }
component_ids = e_component_registry_get_id_list (priv->component_registry);
@@ -2223,6 +2234,7 @@ e_shell_prepare_for_quit (EShell *shell)
/* Restore all the views to be sensitive. */
for (p = priv->views; p != NULL; p = p->next)
gtk_widget_set_sensitive (GTK_WIDGET (p->data), TRUE);
+ priv->preparing_to_quit = FALSE;
e_free_string_list (component_ids);
return retval;