From e3ab855984902fdc48f3e8703e2f30c005a214b2 Mon Sep 17 00:00:00 2001 From: Dan Winship Date: Sat, 13 Oct 2001 17:28:42 +0000 Subject: New function to try to activate a component when you know it's going to * evolution-shell-component-utils.c (e_activation_failure_dialog): New function to try to activate a component when you know it's going to fail, and then pop up a dialog explaining why it failed. svn path=/trunk/; revision=13657 --- shell/evolution-shell-component-utils.c | 51 +++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) (limited to 'shell/evolution-shell-component-utils.c') diff --git a/shell/evolution-shell-component-utils.c b/shell/evolution-shell-component-utils.c index e056fc54b3..38b307a4e5 100644 --- a/shell/evolution-shell-component-utils.c +++ b/shell/evolution-shell-component-utils.c @@ -27,8 +27,13 @@ #include "evolution-shell-component-utils.h" #include +#include #include #include +#include +#include +#include +#include static void free_pixmaps (void); static GSList *inited_arrays = NULL; @@ -90,3 +95,49 @@ free_pixmaps (void) g_slist_free (inited_arrays); } + +/** + * e_activation_failure_dialog: + * @parent: parent window of the dialog, or %NULL + * @msg: the context-specific part of the error message + * @oafiid: the OAFIID of the component that failed to start + * @repo_id: the repo_id of the component that failed to start + * + * This puts up an error dialog about a failed component activation + * containing as much information as we can manage to gather about + * why it failed. + **/ +void +e_activation_failure_dialog (GtkWindow *parent, const char *msg, + const char *oafiid, const char *repo_id) +{ + Bonobo_Unknown object; + CORBA_Environment ev; + char *errmsg; + + CORBA_exception_init (&ev); + object = bonobo_get_object (oafiid, repo_id, &ev); + if (ev._major == CORBA_NO_EXCEPTION) { + if (object) { + Bonobo_Unknown_unref (object, &ev); + CORBA_Object_release (object, &ev); + } + errmsg = g_strdup_printf (_("%s\n\nUnknown error."), msg); + } else if (strcmp (CORBA_exception_id (&ev), ex_OAF_GeneralError) != 0) { + char *bonobo_err = bonobo_exception_get_text (&ev); + errmsg = g_strdup_printf (_("%s\n\nThe error from the " + "component system is:\n%s"), + msg, bonobo_err); + g_free (bonobo_err); + } else { + OAF_GeneralError *errval = CORBA_exception_value (&ev); + + errmsg = g_strdup_printf (_("%s\n\nThe error from the " + "activation system is:\n%s"), + msg, errval->description); + } + CORBA_exception_free (&ev); + + e_notice (parent, GNOME_MESSAGE_BOX_ERROR, errmsg); + g_free (errmsg); +} -- cgit v1.2.3