* GNOME_Evolution_Shell.server.in: Renamed from
GNOME_Evolution_Shell.oaf.in.
* Makefile.am: Port from OAF to bonobo-activation.
(INCLUDES): Define SYSCONFDIR, DATADIR, LIBDIR.
* main.c (main): Use gnome_program_init().
* e-corba-storage-registry.c (e_corba_storage_registry_new):
g_object_new(), not gtk_type_new().
(impl_finalize): New, ported over from destroy.
(destroy): Removed.
(class_init): Install finalize handler, not destroy handler, since
we are not a GtkObject anymore.
* e-corba-storage.c (e_corba_storage_new): g_object_new(), not
gtk_type_new().
* e-shell.c (class_init): Override finalize, not destroy.
(impl_finalize): Finalize implementation, basically the old
destroy renamed.
(e_shell_new): g_object_new(), not gtk_type_new().
(class_init): Use e_shell_marshal_NONE__INT for
line_status_changed instead of using an ENUM.
(e_shell_construct): Use g_signal_connect_object() instead of
gtk_signal_connect_while_alive().
* e-setup.c (e_setup): Do not unref local_folder if NULL.
* e-folder.c (init): Make not floating.
(e_folder_construct): No need to make it floating here anymore.
* e-shell.c (impl_Shell_selectUserFolder): For now don't set
dialog parent from xid.
* main.c (no_views_left_cb): Add missing GTK_SIGNAL_FUNC() cast.
(new_view_created_callback): Likewise.
(warning_dialog_clicked_callback): Update to use the
EConfigListener from the shell instead of bonobo-conf.
(show_development_warning): Likewise.
(upgrade_from_1_0_if_needed): BONOBO_EX_ID -> BONOBO_EX_REPOID.
(idle_cb): Use bonobo-activation and BONOBO_EX_REPOID().
(main): Cleaned up the various things that are unneeded in GNOME
2.
(upgrade_from_1_0_if_needed): Use EConfigListener.
* evolution-storage-set-view.h, evolution-storage-set-view.c:
BonoboXObjectified.
* e-storage.c (class_init): GLIB2-ified and made to use
e-shell-marshal.h.
(ES_CLASS): Use GTK_OBJECT_GET_CLASS().
(e_storage_new_folder): Added missing GTK_SIGNAL_FUNC() prototype.
* e-storage-set.c (class_init): GLIB2-ified and made to use
e-shell-marshal.h.
* e-storage-set-view.c (popup_folder_menu): For now, do not add
the pop-up since we lack bonobo_ui_container_get_win() and I am
not sure how to work around it.
(popup_folder_menu): Pass self as the for_widget arg to
gnome_popup_menu_do_popup_modal().
(class_init): GLIB2-ified, and got to use e-shell-marshal.h.
(marshal_NONE__GDKDRAGCONTEXT_STRING_STRING_STRING): Removed.
(impl_tree_drag_data_get): Don't set the selection for now -- we
have to fix the CORBA target stuff to match GTK 2.
(e_storage_set_view_construct): Pass NULL as the opt_ev arg to
bonobo_ui_component_set_container().
* e-splash.c: #include <libgnomecanvas/gnome-canvas-pixbuf.h>
instead of <gdk-pixbuf/gnome-canvas-pixbuf.h>.
(e_splash_new): Pass NULL as the error arg to
gdk_pixbuf_new_from_file().
* e-shortcuts.c (class_init): GLIB2-ified. Also use the
e-shell-marshal marshallers.
(e_shortcuts_new_view): Add missing GTK_SIGNAL_FUNC() cast.
* e-shortcuts-view.c: Use GTK_STOCK_* stuff instead of
GNOME_STOCK_* stuff.
(pop_up_right_click_menu_for_group): Pass self as the for_widget
arg to gnome_popup_menu_do_popup_modal().
(pop_up_right_click_menu_for_shortcut): Likewise.
(class_init): GLIB2-ified.
* e-shell.c: Do not #include <gal/util/e-unicode-i18n.h> or
#include <libgnome/gnome-defs.h>.
(set_interactive): Use BONOBO_EX_REPOID().
(setup_local_storage): Use _() not U_().
(destroy): Use gtk_widget_destroy() instead of
gtk_object_destroy() on priv->settings_dialog.
(class_init): GLIB2-ized.
(init): Initialize config_listener member.
(get_icon_path_for_component_info): Port to bonobo-activation from
OAF.
(setup_components): Likewise.
(destroy): Likewise.
(e_shell_construct): Use e_setup_check_config(), not
e_setup_check_db (). Use the e_config_listener instead of
bonobo-conf.
(save_settings_for_views): Likewise.
(save_misc_settings): Likewise.
(e_shell_restore_from_settings): Likewise.
(parse_default_uri): Likewise.
(e_shell_component_maybe_crashed): Pass NULL for opt_ev arg to
bonobo_unkown_ping()
(e_shell_component_maybe_crashed): Use
bonobo_engine_deregister_dead_components() instead of
bonobo_window_deregister_component_by_ref() which is no more.
(e_shell_send_receive): BONOBO_EX_REPOID() instead of
BONOBO_EX_ID().
(e_shell_get_config_listener): Return the config_listener.
* e-shell-view.c (find_inbox_in_storage): Use _() instead of U_().
(load_images): Pass NULL as the error arg to
gdk_pixbuf_new_from_file().
(load_images): Likewise.
(find_inbox_in_storage): Work around the lack of
g_utf8_strcasecmp() in glib-2.0.
(class_init): GLIB2-ified. Also, use the marshallers in
e-shell-marshal.h.
(pop_up_folder_bar): Use gtk_window_move()/gtk_widget_show()
instead gtk_widget_popup().
(unmerge_on_error): Work around the death of
bonobo_ui_component_get_win() and
bonobo_window_deregister_component_by_ref().
(e_shell_view_construct): Pass NULL as the uic arg to
bonobo_window_construct(). Add missing GTK_SIGNAL_FUNC() cast.
Match the new BonoboWindow behavior wrt the UIContainer and the
new opt_ev args.
(display_uri): Use bonobo_ui_engine_freeze() and
bonobo_ui_engine_thaw() since bonobo_window_freeze() and
bonobo_window_thaw() got axed [sigh].
(e_shell_view_save_settings): Use EConfigListener.
(e_shell_view_load_settings): Likewise.
(get_view_for_uri): Use bonobo_widget_new_control_from_objref()
instead of e_bonobo_widget_new_control_from_objref().
* e-shell-view-menu.c (command_help_faq): Pass NULL for the error
arg to gnome_url_show().
(command_about_box): Use GtkDialog instead of a GtkWindow of a
type GTK_WINDOW_DIALOG [which does not exist anymore].
(command_xml_dump): Removed.
(menu_do_misc): Do not add the corresponding verb.
* e-shell-user-creatable-items-handler.c (execute_verb): Use
BONOBO_EX_REPOID().
* e-shell-startup-wizard.c: Remove id member from SWData. Replace
member db with config_listener.
(e_shell_startup_wizard_create): Initialize config_listener.
(make_mail_dialog_pages): Do not set the listener id here.
(druid_event_notify_cb): Pass FALSE as the help_sensitive arg to
gnome_druid_set_buttons_sensitive().
(e_shell_startup_wizard_create): Likewise.
(make_mail_dialog_pages): Use bonobo-activation instead of OAF.
(get_intelligent_importers): Likewise.
(prepare_importer_page): Likewise.
(start_importers): Do nothing here for now.
(finish_func): Constify local variable displayname.
(finish_func): Updated to use the config_listener instead of the
bono-conf db.
(prepare_importer_page): Do not actually run the importer yet.
(e_shell_startup_wizard_create): Pass NULL as the domain arg to
glade_xml_new(). Use the config_listener.
* e-shell-shared-folder-picker-dialog.c (user_clicked):
BONOBO_EX_REPOID() instead of BONOBO_EX_ID().
(setup_name_selector): Likewise.
(setup_name_selector): Use bonobo-activation.
(show_dialog): Pass NULL as the domain arg to glade_xml_new().
(setup_name_selector): Add a missing GTK_SIGNAL_FUNC() cast.
* e-shell-settings-dialog.c: #include
<bonobo-activation/bonobo-activation.h>. Use
Bonobo_ActivationProperty instead of OAF_Property.
(set_dialog_size): Use gtk_style_get_font() to get the font from
the widget->style.
(load_pages): Converted to use bonobo-activation instead of OAF.
Pass NULL as the error arg to gdk_pixbuf_new_from_file().
* e-shell-offline-sync.c (sync_folder): BONOBO_EX_REPOID(), not
BONOBO_EX_ID().
(e_shell_offline_sync_all_folders): For now, avoid doing anything
[see changes to e-shell-config-offline.c below].
(setup_progress_listener): #if 0 for now.
(setup_dialog): Likewise.
(sync_folder): Likewise.
(cleanup): Likewise.
(progress_listener_servant_free): Likewise.
(progress_listener_servant_new): Likewise.
(impl_SyncFolderProgressListener_updateProgress): Likewise.
(impl_SyncFolderProgressListener_reportSuccess): Likewise.
(impl_SyncFolderProgressListener_reportFailure): Likewise.
(progress_dialog_close_callback): Likewise.
(progress_dialog_clicked_callback): Likewise.
* e-shell-offline-handler.c (prepare_for_offline): Use
BONOBO_EX_REPOID().
(pop_up_confirmation_dialog): Pass NULL as the domain arg to
glade_xml_new().
(class_init): GLIB2-ified.
* Makefile.am: Do not compile e-shell-importer.c,
e-shell-importer.h for now.
* e-shell-folder-title-bar.c (get_max_clipped_label_width): Use
gtk_style_get_font() to retrieve the font.
(class_init): GLIB2-ified.
(e_shell_folder_title_bar_construct): Get {x,y}thickness from
widget->style, not from widget->style->klass.
* e-shell-folder-selection-dialog.c: #include <string.h>,
<gtk/gtklabel.h> and <gtk/gtksignal.h>.
(class_init): GLIB2-ified.
* e-shell-folder-creation-dialog.c: No <libgnome/gnome-defs.h>,
add some GTK includes.
(e_shell_show_folder_creation_dialog): Pass NULL as the domain arg
to glade_xml_new(). Added missing GTK_SIGNAL_FUNC() cast.
* e-shell-folder-commands.c: Do not #include
<libgnomeui/gnome-stock.h> and #include
<bonobo-conf/Bonobo_Config.h>.
* e-shell-config-default-folders.c: Replace member db in
EvolutionDefaultFolderConfig with config_listener.
(e_shell_config_default_folders_create_widget): Init here.
(config_control_destroy_cb): Unref here.
(config_control_apply_cb): Use EConfigListener instead of
BonoboConf.
(setup_folder_selector): Likewise.
(e_shell_config_default_folders_create_widget): Pass NULL as the
domain arg to glade_xml_new().
* e-shell-config-offline.c (config_control_apply_callback): For
now, do not change the configuration. [Needs to be ported to
EConfigListener or something, but we were storing a sequence using
typecodes here and there is no trivial way to do that right now.]
(init_storage_set_view_status_from_config): Likewise, do not
retrieve the configuration here.
svn path=/trunk/; revision=18510
554 lines
15 KiB
C
554 lines
15 KiB
C
/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
|
||
/* main.c
|
||
*
|
||
* Copyright (C) 2000 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.
|
||
*
|
||
* Author: Ettore Perazzoli
|
||
*/
|
||
|
||
#include <config.h>
|
||
#include <fcntl.h>
|
||
#include <glib.h>
|
||
#include <stdio.h>
|
||
|
||
#include <gtk/gtkalignment.h>
|
||
#include <gtk/gtkframe.h>
|
||
#include <gtk/gtklabel.h>
|
||
#include <gtk/gtkmain.h>
|
||
#include <gtk/gtksignal.h>
|
||
#include <gtk/gtkwindow.h>
|
||
|
||
#include <gdk/gdkx.h>
|
||
#include <X11/Xlib.h>
|
||
|
||
#include <libgnome/gnome-i18n.h>
|
||
#include <libgnome/gnome-util.h>
|
||
#include <libgnomeui/gnome-ui-init.h>
|
||
#include <libgnomeui/gnome-window-icon.h>
|
||
|
||
#include <bonobo/bonobo-main.h>
|
||
#include <bonobo/bonobo-moniker-util.h>
|
||
#include <bonobo/bonobo-exception.h>
|
||
|
||
#include <bonobo-activation/bonobo-activation.h>
|
||
|
||
#include <glade/glade.h>
|
||
|
||
#ifdef GTKHTML_HAVE_GCONF
|
||
#include <gconf/gconf.h>
|
||
#endif
|
||
|
||
#include <gal/widgets/e-gui-utils.h>
|
||
#include <gal/widgets/e-cursors.h>
|
||
|
||
#include <string.h>
|
||
#include <unistd.h>
|
||
|
||
#include "e-util/e-gtk-utils.h"
|
||
|
||
#include "e-icon-factory.h"
|
||
#include "e-shell-constants.h"
|
||
#include "e-shell-config.h"
|
||
#include "e-setup.h"
|
||
|
||
#include "e-shell.h"
|
||
|
||
|
||
static EShell *shell = NULL;
|
||
static char *evolution_directory = NULL;
|
||
|
||
/* Command-line options. */
|
||
static gboolean no_splash = FALSE;
|
||
static gboolean start_online = FALSE;
|
||
static gboolean start_offline = FALSE;
|
||
static gboolean force_upgrade = FALSE;
|
||
|
||
extern char *evolution_debug_log;
|
||
|
||
|
||
static GtkWidget *
|
||
quit_box_new (void)
|
||
{
|
||
GtkWidget *window;
|
||
GtkWidget *label;
|
||
GtkWidget *frame;
|
||
|
||
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
||
gtk_window_set_policy (GTK_WINDOW (window), FALSE, FALSE, FALSE);
|
||
gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_CENTER);
|
||
|
||
/* (Just to prevent smart-ass window managers like Sawfish from setting
|
||
the make the dialog as big as the standard Evolution window). */
|
||
gtk_window_set_wmclass (GTK_WINDOW (window), "evolution-quit", "Evolution:quit");
|
||
|
||
e_make_widget_backing_stored (window);
|
||
|
||
gtk_window_set_title (GTK_WINDOW (window), _("Evolution"));
|
||
|
||
frame = gtk_frame_new (NULL);
|
||
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_OUT);
|
||
gtk_container_add (GTK_CONTAINER (window), frame);
|
||
|
||
label = gtk_label_new (_("Evolution is now exiting ..."));
|
||
gtk_misc_set_padding (GTK_MISC (label), 30, 25);
|
||
|
||
gtk_container_add (GTK_CONTAINER (frame), label);
|
||
|
||
gtk_widget_show_now (frame);
|
||
gtk_widget_show_now (label);
|
||
gtk_widget_show_now (window);
|
||
|
||
/* For some reason, the window fails to update without this
|
||
sometimes. */
|
||
gtk_widget_queue_draw (window);
|
||
gtk_widget_queue_draw (label);
|
||
gtk_widget_queue_draw (frame);
|
||
|
||
gdk_flush ();
|
||
|
||
while (gtk_events_pending ())
|
||
gtk_main_iteration ();
|
||
|
||
gdk_flush ();
|
||
|
||
return window;
|
||
}
|
||
|
||
static void
|
||
quit_box_destroyed_callback (GtkObject *object,
|
||
void *data)
|
||
{
|
||
GtkWidget **p;
|
||
|
||
p = (GtkWidget **) data;
|
||
*p = NULL;
|
||
}
|
||
|
||
static void
|
||
no_views_left_cb (EShell *shell, gpointer data)
|
||
{
|
||
GtkWidget *quit_box;
|
||
|
||
quit_box = quit_box_new ();
|
||
gtk_signal_connect (GTK_OBJECT (quit_box), "destroy", GTK_SIGNAL_FUNC (quit_box_destroyed_callback), &quit_box);
|
||
|
||
/* FIXME: This is wrong. We should exit only when the shell is
|
||
destroyed. But refcounting is broken at present, so this is a
|
||
reasonable workaround for now. */
|
||
|
||
e_shell_unregister_all (shell);
|
||
|
||
/* FIXME: And this is another ugly hack. We have a strange race
|
||
condition that I cannot work around. What happens is that the
|
||
EShell object gets unreffed and its aggregate EActivityHandler gets
|
||
destroyed too. But for some reason, the EActivityHanlder GtkObject
|
||
gets freed, while its CORBA object counterpart is still an active
|
||
server. So there is a slight chance that we receive CORBA
|
||
invocation that act on an uninitialized object, and we crash. (See
|
||
#8615.)
|
||
|
||
The CORBA invocation on the dead object only happens because we
|
||
::unref the BonoboConf database server in the ::destroy method of
|
||
the shell. Since this is a CORBA call, it allows incoming CORBA
|
||
calls to happen -- and these get invoked on the partially
|
||
uninitialized object.
|
||
|
||
Since I am not 100% sure what the reason for this half-stale object
|
||
is, I am just going to make sure that no CORBA ops happen in
|
||
::destroy... And this is achieved by placing this call here. (If
|
||
the DB is disconnected, there will be no ::unref of it in
|
||
::destroy.) */
|
||
|
||
e_shell_disconnect_db (shell);
|
||
|
||
bonobo_object_unref (BONOBO_OBJECT (shell));
|
||
|
||
if (quit_box != NULL)
|
||
gtk_widget_destroy (quit_box);
|
||
|
||
gtk_main_quit ();
|
||
}
|
||
|
||
static void
|
||
destroy_cb (GtkObject *object, gpointer data)
|
||
{
|
||
gtk_main_quit ();
|
||
}
|
||
|
||
|
||
/* Warning dialog to scare people off a little bit. */
|
||
|
||
static void
|
||
warning_dialog_clicked_callback (GnomeDialog *dialog,
|
||
int button_number,
|
||
void *data)
|
||
{
|
||
GtkCheckButton *dont_bother_me_again_checkbox;
|
||
EConfigListener *config_listener;
|
||
|
||
dont_bother_me_again_checkbox = GTK_CHECK_BUTTON (data);
|
||
|
||
config_listener = e_config_listener_new ();
|
||
|
||
e_config_listener_set_boolean (config_listener, "/Shell/skip_warning_dialog_1_1",
|
||
gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (dont_bother_me_again_checkbox)));
|
||
|
||
g_object_unref (config_listener);
|
||
|
||
gtk_widget_destroy (GTK_WIDGET (dialog));
|
||
}
|
||
|
||
static void
|
||
show_development_warning (GtkWindow *parent)
|
||
{
|
||
GtkWidget *label;
|
||
GtkWidget *warning_dialog;
|
||
GtkWidget *dont_bother_me_again_checkbox;
|
||
GtkWidget *alignment;
|
||
EConfigListener *config_listener;
|
||
|
||
config_listener = e_shell_get_config_listener (shell);
|
||
if (e_config_listener_get_boolean_with_default (config_listener, "/Shell/skip_warning_dialog_1_1", FALSE, NULL))
|
||
return;
|
||
|
||
warning_dialog = gnome_dialog_new ("Ximian Evolution " VERSION, GNOME_STOCK_BUTTON_OK, NULL);
|
||
gtk_window_set_transient_for (GTK_WINDOW (warning_dialog), parent);
|
||
|
||
label = gtk_label_new (
|
||
/* xgettext:no-c-format */
|
||
_("Hi. Thanks for taking the time to download this preview release\n"
|
||
"of the Ximian Evolution groupware suite.\n"
|
||
"\n"
|
||
"This version of Ximian Evolution is not yet complete. It's getting close,\n"
|
||
"but some features are either unfinished or don't work properly.\n"
|
||
"\n"
|
||
"If you want a stable version of Evolution, we urge you to uninstall,\n"
|
||
"this version, and install a 1.0.x version instead (1.0.8)\n"
|
||
"\n"
|
||
"If you find bugs, please report them to us at bugzilla.ximian.com.\n"
|
||
"This product comes with no warranty and is not intended for\n"
|
||
"individuals prone to violent fits of anger.\n"
|
||
"\n"
|
||
"We hope that you enjoy the results of our hard work, and we\n"
|
||
"eagerly await your contributions!\n"
|
||
));
|
||
gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
|
||
|
||
gtk_box_pack_start (GTK_BOX (GNOME_DIALOG (warning_dialog)->vbox),
|
||
label, TRUE, TRUE, 4);
|
||
|
||
label = gtk_label_new (
|
||
_(
|
||
"Thanks\n"
|
||
"The Ximian Evolution Team\n"
|
||
));
|
||
gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_RIGHT);
|
||
gtk_misc_set_alignment(GTK_MISC(label), 1, .5);
|
||
|
||
gtk_box_pack_start (GTK_BOX (GNOME_DIALOG (warning_dialog)->vbox),
|
||
label, TRUE, TRUE, 0);
|
||
|
||
dont_bother_me_again_checkbox = gtk_check_button_new_with_label (_("Don't tell me again"));
|
||
|
||
/* GTK sucks. (Just so you know.) */
|
||
alignment = gtk_alignment_new (0.0, 0.0, 0.0, 0.0);
|
||
|
||
gtk_container_add (GTK_CONTAINER (alignment), dont_bother_me_again_checkbox);
|
||
gtk_box_pack_start (GTK_BOX (GNOME_DIALOG (warning_dialog)->vbox),
|
||
alignment, FALSE, FALSE, 0);
|
||
|
||
gtk_widget_show_all (warning_dialog);
|
||
|
||
gtk_signal_connect (GTK_OBJECT (warning_dialog), "clicked",
|
||
GTK_SIGNAL_FUNC (warning_dialog_clicked_callback),
|
||
dont_bother_me_again_checkbox);
|
||
}
|
||
|
||
/* The following signal handlers are used to display the development warning as
|
||
soon as the first view is created. */
|
||
|
||
static void
|
||
view_map_callback (GtkWidget *widget,
|
||
void *data)
|
||
{
|
||
gtk_signal_disconnect_by_func (GTK_OBJECT (widget),
|
||
GTK_SIGNAL_FUNC (view_map_callback),
|
||
data);
|
||
|
||
show_development_warning (GTK_WINDOW (widget));
|
||
}
|
||
|
||
static void
|
||
new_view_created_callback (EShell *shell,
|
||
EShellView *view,
|
||
void *data)
|
||
{
|
||
gtk_signal_disconnect_by_func (GTK_OBJECT (shell),
|
||
GTK_SIGNAL_FUNC (new_view_created_callback),
|
||
data);
|
||
|
||
gtk_signal_connect (GTK_OBJECT (view), "map", GTK_SIGNAL_FUNC (view_map_callback), NULL);
|
||
}
|
||
|
||
|
||
static void
|
||
upgrade_from_1_0_if_needed (void)
|
||
{
|
||
EConfigListener *config_listener;
|
||
int result;
|
||
|
||
config_listener = e_config_listener_new ();
|
||
|
||
if (! force_upgrade
|
||
&& e_config_listener_get_boolean_with_default (config_listener, "/Shell/upgrade_from_1_0_to_1_2_performed",
|
||
FALSE, NULL))
|
||
return;
|
||
|
||
g_print ("\nOlder configuration files detected, upgrading...\n");
|
||
|
||
result = system (PREFIX "/bin/evolution-mail-upgrade");
|
||
|
||
if (result == 0)
|
||
g_print ("\n--> Configuration files upgraded from version 1.0.\n");
|
||
else
|
||
g_print ("\n*** Error upgrading configuration files -- status %d\n", result);
|
||
|
||
e_config_listener_set_boolean (config_listener, "/Shell/upgrade_from_1_0_to_1_2_performed", TRUE);
|
||
|
||
g_object_unref (config_listener);
|
||
}
|
||
|
||
|
||
/* This is for doing stuff that requires the GTK+ loop to be running already. */
|
||
|
||
static gint
|
||
idle_cb (void *data)
|
||
{
|
||
GSList *uri_list;
|
||
GNOME_Evolution_Shell corba_shell;
|
||
CORBA_Environment ev;
|
||
EShellConstructResult result;
|
||
EShellStartupLineMode startup_line_mode;
|
||
GSList *p;
|
||
gboolean have_evolution_uri;
|
||
gboolean display_default;
|
||
gboolean displayed_any;
|
||
|
||
upgrade_from_1_0_if_needed ();
|
||
|
||
CORBA_exception_init (&ev);
|
||
|
||
uri_list = (GSList *) data;
|
||
|
||
if (! start_online && ! start_offline)
|
||
startup_line_mode = E_SHELL_STARTUP_LINE_MODE_CONFIG;
|
||
else if (start_online)
|
||
startup_line_mode = E_SHELL_STARTUP_LINE_MODE_ONLINE;
|
||
else
|
||
startup_line_mode = E_SHELL_STARTUP_LINE_MODE_OFFLINE;
|
||
|
||
shell = e_shell_new (evolution_directory, ! no_splash, startup_line_mode, &result);
|
||
g_free (evolution_directory);
|
||
|
||
switch (result) {
|
||
case E_SHELL_CONSTRUCT_RESULT_OK:
|
||
e_shell_config_factory_register (shell);
|
||
|
||
gtk_signal_connect (GTK_OBJECT (shell), "no_views_left",
|
||
GTK_SIGNAL_FUNC (no_views_left_cb), NULL);
|
||
gtk_signal_connect (GTK_OBJECT (shell), "destroy",
|
||
GTK_SIGNAL_FUNC (destroy_cb), NULL);
|
||
|
||
if (!getenv ("EVOLVE_ME_HARDER"))
|
||
gtk_signal_connect (GTK_OBJECT (shell), "new_view_created",
|
||
GTK_SIGNAL_FUNC (new_view_created_callback), NULL);
|
||
|
||
corba_shell = bonobo_object_corba_objref (BONOBO_OBJECT (shell));
|
||
corba_shell = CORBA_Object_duplicate (corba_shell, &ev);
|
||
break;
|
||
|
||
case E_SHELL_CONSTRUCT_RESULT_CANNOTREGISTER:
|
||
corba_shell = bonobo_activation_activate_from_id (E_SHELL_OAFIID, 0, NULL, &ev);
|
||
if (ev._major != CORBA_NO_EXCEPTION || corba_shell == CORBA_OBJECT_NIL) {
|
||
e_notice (NULL, GNOME_MESSAGE_BOX_ERROR,
|
||
_("Cannot access the Ximian Evolution shell."));
|
||
CORBA_exception_free (&ev);
|
||
gtk_main_quit ();
|
||
return FALSE;
|
||
}
|
||
break;
|
||
|
||
default:
|
||
e_notice (NULL, GNOME_MESSAGE_BOX_ERROR,
|
||
_("Cannot initialize the Ximian Evolution shell: %s"),
|
||
e_shell_construct_result_to_string (result));
|
||
CORBA_exception_free (&ev);
|
||
gtk_main_quit ();
|
||
return FALSE;
|
||
|
||
}
|
||
|
||
have_evolution_uri = FALSE;
|
||
for (p = uri_list; p != NULL; p = p->next) {
|
||
const char *uri;
|
||
|
||
uri = (const char *) p->data;
|
||
if (strncmp (uri, E_SHELL_URI_PREFIX, E_SHELL_URI_PREFIX_LEN) == 0 ||
|
||
strncmp (uri, E_SHELL_DEFAULTURI_PREFIX, E_SHELL_DEFAULTURI_PREFIX_LEN) == 0)
|
||
have_evolution_uri = TRUE;
|
||
}
|
||
|
||
if (shell == NULL) {
|
||
/* We're talking to a remote shell. If the user didn't
|
||
* ask us to open any particular URI, then open another
|
||
* view of the default URI
|
||
*/
|
||
if (uri_list == NULL)
|
||
display_default = TRUE;
|
||
else
|
||
display_default = FALSE;
|
||
} else {
|
||
/* We're starting a new shell. If the user didn't specify
|
||
* any evolution: URIs to view, AND we can't load the
|
||
* user's previous settings, then show the default URI.
|
||
*/
|
||
if (! have_evolution_uri) {
|
||
if (! e_shell_restore_from_settings (shell, FALSE))
|
||
display_default = TRUE;
|
||
else
|
||
display_default = FALSE;
|
||
} else {
|
||
display_default = FALSE;
|
||
}
|
||
}
|
||
|
||
displayed_any = FALSE;
|
||
for (p = uri_list; p != NULL; p = p->next) {
|
||
const char *uri;
|
||
|
||
uri = (const char *) p->data;
|
||
GNOME_Evolution_Shell_handleURI (corba_shell, uri, &ev);
|
||
if (ev._major == CORBA_NO_EXCEPTION)
|
||
displayed_any = TRUE;
|
||
else {
|
||
g_warning ("CORBA exception %s when requesting URI -- %s",
|
||
BONOBO_EX_REPOID (&ev), uri);
|
||
CORBA_exception_free (&ev);
|
||
}
|
||
}
|
||
|
||
g_slist_free (uri_list);
|
||
|
||
if (display_default && ! displayed_any) {
|
||
const char *uri;
|
||
|
||
uri = E_SHELL_VIEW_DEFAULT_URI;
|
||
GNOME_Evolution_Shell_handleURI (corba_shell, uri, &ev);
|
||
if (ev._major != CORBA_NO_EXCEPTION)
|
||
g_warning ("CORBA exception %s when requesting URI -- %s", BONOBO_EX_REPOID (&ev), uri);
|
||
}
|
||
|
||
CORBA_Object_release (corba_shell, &ev);
|
||
|
||
CORBA_exception_free (&ev);
|
||
|
||
if (shell == NULL)
|
||
gtk_main_quit ();
|
||
|
||
return FALSE;
|
||
}
|
||
|
||
int
|
||
main (int argc, char **argv)
|
||
{
|
||
struct poptOption options[] = {
|
||
{ "no-splash", '\0', POPT_ARG_NONE, &no_splash, 0,
|
||
N_("Disable splash screen"), NULL },
|
||
{ "offline", '\0', POPT_ARG_NONE, &start_offline, 0,
|
||
N_("Start in offline mode"), NULL },
|
||
{ "online", '\0', POPT_ARG_NONE, &start_online, 0,
|
||
N_("Start in online mode"), NULL },
|
||
{ "debug", '\0', POPT_ARG_STRING, &evolution_debug_log, 0,
|
||
N_("Send the debugging output of all components to a file."), NULL },
|
||
{ "force-upgrade", '\0', POPT_ARG_NONE, &force_upgrade, 0,
|
||
N_("Force upgrading of configuration files from Evolution 1.0.x"), NULL },
|
||
POPT_AUTOHELP
|
||
{ NULL, '\0', 0, NULL, 0, NULL, NULL }
|
||
};
|
||
GSList *uri_list;
|
||
const char **args;
|
||
poptContext popt_context;
|
||
|
||
/* Make ElectricFence work. */
|
||
free (malloc (10));
|
||
|
||
gnome_program_init (PACKAGE, VERSION, LIBGNOMEUI_MODULE, argc, argv,
|
||
GNOME_PROGRAM_STANDARD_PROPERTIES,
|
||
GNOME_PARAM_POPT_TABLE, options,
|
||
GNOME_PARAM_HUMAN_READABLE_NAME, _("Evolution"),
|
||
NULL);
|
||
|
||
if (start_online && start_offline) {
|
||
fprintf (stderr, _("%s: --online and --offline cannot be used together.\n Use %s --help for more information.\n"),
|
||
argv[0], argv[0]);
|
||
exit (1);
|
||
}
|
||
|
||
if (evolution_debug_log) {
|
||
int fd;
|
||
|
||
fd = open (evolution_debug_log, O_WRONLY | O_CREAT | O_TRUNC, 0600);
|
||
if (fd) {
|
||
dup2 (fd, STDOUT_FILENO);
|
||
dup2 (fd, STDERR_FILENO);
|
||
close (fd);
|
||
} else
|
||
g_warning ("Could not set up debugging output file.");
|
||
}
|
||
|
||
glade_gnome_init ();
|
||
e_cursors_init ();
|
||
e_icon_factory_init ();
|
||
|
||
gnome_window_icon_set_default_from_file (EVOLUTION_IMAGES "/evolution-inbox.png");
|
||
|
||
/* FIXME */
|
||
evolution_directory = g_concat_dir_and_file (g_get_home_dir (), "evolution");
|
||
|
||
if (! e_setup (evolution_directory))
|
||
exit (1);
|
||
|
||
uri_list = NULL;
|
||
|
||
args = poptGetArgs (popt_context);
|
||
if (args != NULL) {
|
||
const char **p;
|
||
|
||
for (p = args; *p != NULL; p++)
|
||
uri_list = g_slist_prepend (uri_list, (char *) *p);
|
||
}
|
||
|
||
gtk_idle_add (idle_cb, uri_list);
|
||
|
||
gtk_widget_push_visual (gdk_rgb_get_visual ());
|
||
gtk_widget_push_colormap (gdk_rgb_get_cmap ());
|
||
|
||
bonobo_main ();
|
||
|
||
return 0;
|
||
}
|