diff options
Diffstat (limited to 'shell')
-rw-r--r-- | shell/ChangeLog | 23 | ||||
-rw-r--r-- | shell/e-shell-view-menu.c | 2 | ||||
-rw-r--r-- | shell/e-shell-view.c | 1 | ||||
-rw-r--r-- | shell/e-shell.c | 98 | ||||
-rw-r--r-- | shell/e-shell.h | 11 |
5 files changed, 99 insertions, 36 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog index 6a6fbde975..2e65cd6b7c 100644 --- a/shell/ChangeLog +++ b/shell/ChangeLog @@ -1,5 +1,28 @@ 2001-10-22 Ettore Perazzoli <ettore@ximian.com> + * e-shell-view-menu.c (command_open_folder_in_new_window): No need + to gtk_widget_show() the view anymore. + + * e-shell-view.c (activate_shortcut_cb): No need to + gtk_widget_show() the view anymore. + + * e-shell.c (impl_Shell_createNewView): Don't explicitly show the + new view. + (e_shell_create_view): gtk_widget_show() the new view and flush + the GTK+ event loop before sending the ::interactive notification. + (create_view): New helper function. + (e_shell_create_view): Use it. + (e_shell_create_view_from_settings): New. + (e_shell_restore_from_settings): Use + `e_shell_create_view_from_settings()'. + +2001-10-22 Ettore Perazzoli <ettore@ximian.com> + + * e-shell-view-menu.c (command_open_folder_in_new_window): Don't + explicitly show the new view. + +2001-10-22 Ettore Perazzoli <ettore@ximian.com> + * evolution-shell-component.c (impl_unsetOwner): Remove the ping timeout. diff --git a/shell/e-shell-view-menu.c b/shell/e-shell-view-menu.c index e32a1a9d92..3b3844d7b3 100644 --- a/shell/e-shell-view-menu.c +++ b/shell/e-shell-view-menu.c @@ -298,8 +298,6 @@ command_open_folder_in_new_window (BonoboUIComponent *uih, uri = g_strconcat (E_SHELL_URI_PREFIX, get_path_for_folder_op (shell_view), NULL); new_view = e_shell_create_view (shell, uri, shell_view); g_free (uri); - - gtk_widget_show (GTK_WIDGET (new_view)); } diff --git a/shell/e-shell-view.c b/shell/e-shell-view.c index 7d0f67c338..5e501d55a5 100644 --- a/shell/e-shell-view.c +++ b/shell/e-shell-view.c @@ -669,7 +669,6 @@ activate_shortcut_cb (EShortcutsView *shortcut_view, EShellView *new_view; new_view = e_shell_create_view (e_shell_view_get_shell (shell_view), uri, shell_view); - gtk_widget_show (GTK_WIDGET (new_view)); } else { e_shell_view_display_uri (shell_view, uri); } diff --git a/shell/e-shell.c b/shell/e-shell.c index 6de1b38912..0b746c8589 100644 --- a/shell/e-shell.c +++ b/shell/e-shell.c @@ -349,8 +349,6 @@ impl_Shell_createNewView (PortableServer_Servant servant, return CORBA_OBJECT_NIL; } - gtk_widget_show (GTK_WIDGET (shell_view)); - shell_view_interface = e_shell_view_get_corba_interface (shell_view); if (shell_view_interface == CORBA_OBJECT_NIL) { CORBA_exception_set (ev, CORBA_USER_EXCEPTION, @@ -806,7 +804,7 @@ set_owner_on_components (EShell *shell) } -/* EShellView destruction callback. */ +/* EShellView handling and bookkeeping. */ static int view_delete_event_cb (GtkWidget *widget, @@ -854,6 +852,45 @@ view_destroy_cb (GtkObject *object, } } +static EShellView * +create_view (EShell *shell, + const char *uri, + EShellView *template_view) +{ + EShellPrivate *priv; + EShellView *view; + ETaskBar *task_bar; + + priv = shell->priv; + + view = e_shell_view_new (shell); + + gtk_signal_connect (GTK_OBJECT (view), "delete_event", + GTK_SIGNAL_FUNC (view_delete_event_cb), shell); + gtk_signal_connect (GTK_OBJECT (view), "destroy", + GTK_SIGNAL_FUNC (view_destroy_cb), shell); + + if (uri != NULL) { + if (!e_shell_view_display_uri (E_SHELL_VIEW (view), uri)) { + /* FIXME: Consider popping a dialog box up about how the provided URI does not + exist/could not be displayed. */ + e_shell_view_display_uri (E_SHELL_VIEW (view), E_SHELL_VIEW_DEFAULT_URI); + } + } + + shell->priv->views = g_list_prepend (shell->priv->views, view); + + task_bar = e_shell_view_get_task_bar (view); + e_activity_handler_attach_task_bar (priv->activity_handler, task_bar); + + if (template_view != NULL) { + e_shell_view_show_folder_bar (view, e_shell_view_folder_bar_shown (template_view)); + e_shell_view_show_shortcut_bar (view, e_shell_view_shortcut_bar_shown (template_view)); + } + + return view; +} + /* GtkObject methods. */ @@ -1204,37 +1241,42 @@ e_shell_create_view (EShell *shell, { EShellView *view; EShellPrivate *priv; - ETaskBar *task_bar; g_return_val_if_fail (shell != NULL, NULL); g_return_val_if_fail (E_IS_SHELL (shell), NULL); priv = shell->priv; - view = e_shell_view_new (shell); + view = create_view (shell, uri, template_view); - gtk_signal_connect (GTK_OBJECT (view), "delete_event", - GTK_SIGNAL_FUNC (view_delete_event_cb), shell); - gtk_signal_connect (GTK_OBJECT (view), "destroy", - GTK_SIGNAL_FUNC (view_destroy_cb), shell); + gtk_widget_show (GTK_WIDGET (view)); + while (gtk_events_pending ()) + gtk_main_iteration (); - if (uri != NULL) { - if (!e_shell_view_display_uri (E_SHELL_VIEW (view), uri)) { - /* FIXME: Consider popping a dialog box up about how the provided URI does not - exist/could not be displayed. */ - e_shell_view_display_uri (E_SHELL_VIEW (view), E_SHELL_VIEW_DEFAULT_URI); - } - } + set_interactive (shell, TRUE); - shell->priv->views = g_list_prepend (shell->priv->views, view); + return view; +} - task_bar = e_shell_view_get_task_bar (view); - e_activity_handler_attach_task_bar (priv->activity_handler, task_bar); +EShellView * +e_shell_create_view_from_settings (EShell *shell, + const char *uri, + EShellView *template_view, + int view_num, + gboolean *settings_found) +{ + EShellView *view; - if (template_view != NULL) { - e_shell_view_show_folder_bar (view, e_shell_view_folder_bar_shown (template_view)); - e_shell_view_show_shortcut_bar (view, e_shell_view_shortcut_bar_shown (template_view)); - } + g_return_val_if_fail (shell != NULL, NULL); + g_return_val_if_fail (E_IS_SHELL (shell), NULL); + + view = create_view (shell, uri, template_view); + + *settings_found = e_shell_view_load_settings (view, view_num); + + gtk_widget_show (GTK_WIDGET (view)); + while (gtk_events_pending ()) + gtk_main_iteration (); set_interactive (shell, TRUE); @@ -1504,15 +1546,11 @@ e_shell_restore_from_settings (EShell *shell) for (i = 0; i < num_views; i++) { EShellView *view; + gboolean settings_found; - view = e_shell_create_view (shell, NULL, NULL); - - if (! e_shell_view_load_settings (view, i)) + view = e_shell_create_view_from_settings (shell, NULL, NULL, i, &settings_found); + if (! settings_found) retval = FALSE; - - /* This needs to be done after loading the settings as the - default size is in the settings as well. */ - gtk_widget_show (GTK_WIDGET (view)); } return retval; diff --git a/shell/e-shell.h b/shell/e-shell.h index 8f413902bf..e3e9c929ba 100644 --- a/shell/e-shell.h +++ b/shell/e-shell.h @@ -100,9 +100,14 @@ EShell *e_shell_new (const char *local_director gboolean show_splash, EShellConstructResult *construct_result_return); -EShellView *e_shell_create_view (EShell *shell, - const char *uri, - EShellView *template_view); +EShellView *e_shell_create_view (EShell *shell, + const char *uri, + EShellView *template_view); +EShellView *e_shell_create_view_from_settings (EShell *shell, + const char *uri, + EShellView *template_view, + int view_num, + gboolean *settings_found); const char *e_shell_get_local_directory (EShell *shell); EShortcuts *e_shell_get_shortcuts (EShell *shell); |