diff options
author | Matthew Loper <mloper@src.gnome.org> | 2000-03-23 00:35:58 +0800 |
---|---|---|
committer | Matthew Loper <mloper@src.gnome.org> | 2000-03-23 00:35:58 +0800 |
commit | f286676ead838f371de0096b6bfd3c46748d84ec (patch) | |
tree | 895901d9c2203404c6e14c15d866eccc408d6212 /shell/e-shell-view.c | |
parent | 44e1a62c0ca5aede11bb1a5c7551186d7618dadb (diff) | |
download | gsoc2013-evolution-f286676ead838f371de0096b6bfd3c46748d84ec.tar.gz gsoc2013-evolution-f286676ead838f371de0096b6bfd3c46748d84ec.tar.zst gsoc2013-evolution-f286676ead838f371de0096b6bfd3c46748d84ec.zip |
+ * shell/main.c (evolution_boot): gtk_signal_connect'ed "destroy"
+ to gtk_main_quit, so that the shell dies when you want it to.
+
+ * shell/e-shell-view.c (get_view): Reorganized, and added
+ assertions.
+ (e_shell_view_set_view): Added assertions.
+
+ * camel/camel-formatter.c (debug): Disabled some useless debug
+ messaging.
svn path=/trunk/; revision=2141
Diffstat (limited to 'shell/e-shell-view.c')
-rw-r--r-- | shell/e-shell-view.c | 119 |
1 files changed, 59 insertions, 60 deletions
diff --git a/shell/e-shell-view.c b/shell/e-shell-view.c index 9f41b4ec3b..398c67f377 100644 --- a/shell/e-shell-view.c +++ b/shell/e-shell-view.c @@ -85,24 +85,25 @@ static GtkWidget * get_view (EShellView *eshell_view, EFolder *efolder, Bonobo_UIHandler uih) { GtkWidget *w = NULL; - EFolderType e_folder_type; - BonoboControlFrame *control_frame = NULL; - BonoboObjectClient *server; - EShell *shell_model; Evolution_Shell corba_shell = CORBA_OBJECT_NIL; CORBA_Environment ev; + EShell *shell_model = eshell_view->eshell; + + /* This type could be E_FOLDER_MAIL, E_FOLDER_CONTACTS, etc */ + EFolderType e_folder_type; + g_assert (efolder); + g_assert (eshell_view); + + e_folder_type = e_folder_get_folder_type (efolder); - shell_model = eshell_view->eshell; if (shell_model) - corba_shell = bonobo_object_corba_objref (BONOBO_OBJECT (shell_model)); + corba_shell = bonobo_object_corba_objref ( + BONOBO_OBJECT (shell_model)); else - g_warning ("The shell Bonobo object does not have an associated CORBA object\n"); + g_warning ("The shell Bonobo object does not have " + "an associated CORBA object\n"); - - /* get the folder type */ - e_folder_type = e_folder_get_folder_type (efolder); - /* initialize the corba environment */ CORBA_exception_init (&ev); @@ -111,65 +112,57 @@ get_view (EShellView *eshell_view, EFolder *efolder, Bonobo_UIHandler uih) switch (e_folder_type) { case E_FOLDER_MAIL : - { - Evolution_ServiceRepository corba_sr; - - w = bonobo_widget_new_control ("control:evolution-mail", - uih); - server = bonobo_widget_get_server (BONOBO_WIDGET (w)); - - corba_sr = (Evolution_ServiceRepository) - bonobo_object_client_query_interface (server, - "IDL:Evolution/ServiceRepository:1.0", - NULL); - if (corba_sr != CORBA_OBJECT_NIL) { - Evolution_ServiceRepository_set_shell (corba_sr, corba_shell, &ev); - } else { - g_warning ("The bonobo component for the mail doesn't seem to implement the " - "Evolution::ServiceRepository interface\n"); - } - } + w = bonobo_widget_new_control ("control:evolution-mail", uih); break; case E_FOLDER_CONTACTS : - { -#if 0 - Evolution_ServiceRepository corba_sr; -#endif - - w = bonobo_widget_new_control ("control:addressbook", - uih); -#if 0 - server = bonobo_widget_get_server (BONOBO_WIDGET (w)); - - corba_sr = (Evolution_ServiceRepository) - bonobo_object_client_query_interface (server, - "IDL:Evolution/ServiceRepository:1.0", - NULL); - if (corba_sr != CORBA_OBJECT_NIL) { - Evolution_ServiceRepository_set_shell (corba_sr, corba_shell, &ev); - } else { - g_warning ("The bonobo component for the mail doesn't seem to implement the " - "Evolution::ServiceRepository interface\n"); - } -#endif - } + w = bonobo_widget_new_control ("control:addressbook", uih); break; - + + case E_FOLDER_CALENDAR : + case E_FOLDER_TASKS : + case E_FOLDER_OTHER : default : - printf ("No bonobo component associated to %s\n", + printf ("%s: %s: No bonobo component associated with %s\n", + __FILE__, + __FUNCTION__, e_folder_get_description (efolder)); + return NULL; } - - if (!control_frame) - control_frame = bonobo_widget_get_control_frame (BONOBO_WIDGET (w)); - bonobo_control_frame_set_autoactivate (control_frame, FALSE); - bonobo_control_frame_control_activate (control_frame); - if (w) gtk_widget_show (w); + if (w) + { + Evolution_ServiceRepository corba_sr; + BonoboObjectClient *server = + bonobo_widget_get_server (BONOBO_WIDGET (w)); + BonoboControlFrame *control_frame = + bonobo_widget_get_control_frame (BONOBO_WIDGET (w)); + + bonobo_control_frame_set_autoactivate (control_frame, FALSE); + bonobo_control_frame_control_activate (control_frame); + + /* Does this control have the "ServiceRepository" interface? */ + corba_sr = (Evolution_ServiceRepository) + bonobo_object_client_query_interface ( + server, + "IDL:Evolution/ServiceRepository:1.0", + NULL); + + /* If it does, pass our shell interface to it */ + if (corba_sr != CORBA_OBJECT_NIL) { + Evolution_ServiceRepository_set_shell (corba_sr, + corba_shell, + &ev); + } else { + g_warning ("The bonobo component for the mail doesn't " + "seem to implement the " + "Evolution::ServiceRepository interface\n"); + } + + gtk_widget_show (w); + } return w; - } @@ -181,6 +174,9 @@ e_shell_view_set_view (EShellView *eshell_view, EFolder *efolder) GtkWidget *folder_view = g_hash_table_lookup ( eshell_view->priv->folder_views, efolder); + g_assert (eshell_view); + g_assert (efolder); + /* if we found a notebook page in our hash, that represents this efolder, switch to it */ if (folder_view) { @@ -221,6 +217,9 @@ e_shell_view_new (EShell *eshell, EFolder *efolder, gboolean show_shortcut_bar) { EShellView *eshell_view; + g_return_val_if_fail (eshell != NULL, NULL); + g_return_val_if_fail (efolder != NULL, NULL); + eshell_view = gtk_type_new (e_shell_view_get_type ()); eshell_view->priv = g_new (EShellViewPrivate, 1); |