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.c60
1 files changed, 49 insertions, 11 deletions
diff --git a/shell/e-shell.c b/shell/e-shell.c
index 8b1763f437..d16ff306b3 100644
--- a/shell/e-shell.c
+++ b/shell/e-shell.c
@@ -67,6 +67,7 @@
#include "e-splash.h"
#include "e-uri-schema-registry.h"
+#include "evolution-shell-component-utils.h"
#include "evolution-storage-set-view-factory.h"
#include "e-shell.h"
@@ -148,6 +149,25 @@ enum {
static guint signals[LAST_SIGNAL] = { 0 };
+/* Utility functions. */
+
+static void
+pop_up_activation_error_dialog (ESplash *splash,
+ const char *id,
+ CORBA_Environment *ev)
+{
+ char *error_message;
+
+ error_message = e_get_activation_failure_msg (ev);
+ e_notice (GTK_WINDOW (splash), GNOME_MESSAGE_BOX_ERROR,
+ _("Cannot activate component %s :\n"
+ "The error from the activation system is:\n"
+ "%s"),
+ id, error_message);
+ g_free (error_message);
+}
+
+
/* Interactivity handling. */
static void
@@ -738,11 +758,14 @@ setup_components (EShell *shell,
for (i = 0; i < info_list->_length; i++) {
const OAF_ServerInfo *info;
+ CORBA_Environment ev;
info = info_list->_buffer + i;
- if (! e_component_registry_register_component (priv->component_registry, info->iid)) {
- g_warning ("Cannot activate Evolution component -- %s", info->iid);
+ CORBA_exception_init (&ev);
+
+ if (! e_component_registry_register_component (priv->component_registry, info->iid, &ev)) {
+ pop_up_activation_error_dialog (splash, info->iid, &ev);
} else {
e_shell_user_creatable_items_handler_add_component
(priv->user_creatable_items_handler,
@@ -750,6 +773,8 @@ setup_components (EShell *shell,
e_component_registry_get_component_by_id (priv->component_registry, info->iid));
}
+ CORBA_exception_free (&ev);
+
if (splash != NULL)
e_splash_set_icon_highlight (splash, i, TRUE);
@@ -764,7 +789,8 @@ setup_components (EShell *shell,
/* FIXME what if anything fails here? */
static void
-set_owner_on_components (EShell *shell)
+set_owner_on_components (EShell *shell,
+ ESplash *splash)
{
GNOME_Evolution_Shell corba_shell;
EShellPrivate *priv;
@@ -792,14 +818,26 @@ set_owner_on_components (EShell *shell)
id, evolution_shell_component_result_to_string (result));
if (result == EVOLUTION_SHELL_COMPONENT_OLDOWNERHASDIED) {
- component_client = e_component_registry_restart_component (priv->component_registry, id);
- result = evolution_shell_component_client_set_owner (component_client, corba_shell,
- local_directory);
- if (result != EVOLUTION_SHELL_COMPONENT_OK) {
- g_warning ("Error re-setting owner on component %s -- %s",
- id, evolution_shell_component_result_to_string (result));
- /* (At this point, we give up.) */
+ CORBA_Environment ev;
+
+ CORBA_exception_init (&ev);
+
+ component_client = e_component_registry_restart_component (priv->component_registry,
+ id, &ev);
+
+ if (component_client == NULL) {
+ pop_up_activation_error_dialog (splash, id, &ev);
+ } else {
+ result = evolution_shell_component_client_set_owner (component_client, corba_shell,
+ local_directory);
+ if (result != EVOLUTION_SHELL_COMPONENT_OK) {
+ g_warning ("Error re-setting owner on component %s -- %s",
+ id, evolution_shell_component_result_to_string (result));
+ /* (At this point, we give up.) */
+ }
}
+
+ CORBA_exception_free (&ev);
}
}
}
@@ -1184,7 +1222,7 @@ e_shell_construct (EShell *shell,
/* Now that we have a local storage and all the interfaces set up, we
can tell the components we are here. */
- set_owner_on_components (shell);
+ set_owner_on_components (shell, E_SPLASH (splash));
if (show_splash) {
gtk_widget_destroy (splash);