/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ /* evolution-shell-component-utils.c * * Copyright (C) 2000, 2001 Ximian, Inc. * * This program is free software; you can redistribute it and/or * modify it under the terms of version 2 of the GNU General Public * License as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. * */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include "evolution-shell-component-utils.h" #include "e-util/e-dialog-utils.h" #include <string.h> #include <libgnome/gnome-i18n.h> #include <libgnome/gnome-util.h> #include <bonobo/bonobo-ui-util.h> #include <bonobo/bonobo-moniker-util.h> #include <bonobo/bonobo-exception.h> #include <bonobo-activation/bonobo-activation.h> static void free_pixmaps (void); static GSList *inited_arrays = NULL; void e_pixmaps_update (BonoboUIComponent *uic, EPixmap *pixcache) { static int done_init = 0; int i; if (!done_init) { g_atexit (free_pixmaps); done_init = 1; } if (g_slist_find (inited_arrays, pixcache) == NULL) inited_arrays = g_slist_prepend (inited_arrays, pixcache); for (i = 0; pixcache [i].path; i++) { if (!pixcache [i].pixbuf) { char *path; GdkPixbuf *pixbuf; path = g_build_filename (EVOLUTION_IMAGES, pixcache [i].fname, NULL); pixbuf = gdk_pixbuf_new_from_file (path, NULL); if (pixbuf == NULL) { g_warning ("Cannot load image -- %s", path); } else { pixcache [i].pixbuf = bonobo_ui_util_pixbuf_to_xml (pixbuf); g_object_unref (pixbuf); bonobo_ui_component_set_prop (uic, pixcache [i].path, "pixname", pixcache [i].pixbuf, NULL); } g_free (path); } else { bonobo_ui_component_set_prop (uic, pixcache [i].path, "pixname", pixcache [i].pixbuf, NULL); } } } static void free_pixmaps (void) { int i; GSList *li; for (li = inited_arrays; li != NULL; li = li->next) { EPixmap *pixcache = li->data; for (i = 0; pixcache [i].path; i++) g_free (pixcache [i].pixbuf); } 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_Bonobo_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 { Bonobo_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, GTK_MESSAGE_ERROR, errmsg); g_free (errmsg); } /** * e_get_activation_failure_msg: * @ev: An exception returned by an oaf_activate call. * * Get a descriptive error message from @ev. * * Return value: A newly allocated string with the printable error message. **/ char * e_get_activation_failure_msg (CORBA_Environment *ev) { g_return_val_if_fail (ev != NULL, NULL); if (CORBA_exception_id (ev) == NULL) return NULL; if (strcmp (CORBA_exception_id (ev), ex_Bonobo_GeneralError) != 0) { return bonobo_exception_get_text (ev); } else { const Bonobo_GeneralError *oaf_general_error; oaf_general_error = CORBA_exception_value (ev); return g_strdup (oaf_general_error->description); } }