diff options
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | embed/ephy-embed-prefs.h | 2 | ||||
-rw-r--r-- | src/ephy-main.c | 71 |
3 files changed, 43 insertions, 37 deletions
@@ -1,3 +1,10 @@ +2006-01-27 Christian Persch <chpe@cvs.gnome.org> + + * src/ephy-main.c: (main): + + Disable pango rendering by default, unless MOZ_ENABLE_PANGO env + var is set. Bug #328844. + 2006-01-26 Crispin Flowerday <gnome@flowerday.cx> * src/Makefile.am: diff --git a/embed/ephy-embed-prefs.h b/embed/ephy-embed-prefs.h index fe2d4ee7f..caf6db01b 100644 --- a/embed/ephy-embed-prefs.h +++ b/embed/ephy-embed-prefs.h @@ -29,7 +29,7 @@ #define CONF_NETWORK_SOCKS_PROXY_PORT "/system/proxy/socks_port" #define CONF_NETWORK_PROXY_AUTO_URL "/system/proxy/autoconfig_url" #define CONF_NETWORK_PROXY_IGNORE_HOSTS "/system/http_proxy/ignore_hosts" -#define CONF_DESKTOP_FONT_VARIABLE "/desktop/gnome/interface/font_name" +#define CONF_DESKTOP_FONT_VARIABLE "/desktop/gnome/interface/document_font_name" #define CONF_DESKTOP_FONT_MONOSPACE "/desktop/gnome/interface/monospace_font_name" /* DEPRECATED, we migrate them */ diff --git a/src/ephy-main.c b/src/ephy-main.c index 1d14bda0b..a50030bc0 100644 --- a/src/ephy-main.c +++ b/src/ephy-main.c @@ -486,6 +486,7 @@ main (int argc, DBusGProxy *proxy; GError *error = NULL; guint32 user_time; + const char *env; #ifndef GNOME_PARAM_GOPTION_CONTEXT GPtrArray *fake_argv_array; #endif @@ -614,36 +615,42 @@ main (int argc, exit (1); } + /* Create DBUS proxy */ + proxy = ephy_dbus_get_proxy (ephy_dbus_get_default (), EPHY_DBUS_SESSION); + if (proxy == NULL) + { + error = g_error_new (STARTUP_ERROR_QUARK, + 0, + "Unable to get DBus proxy; aborting activation."); /* FIXME i18n */ + + _ephy_dbus_release (); + + show_error_message (&error); + + exit (1); + } + /* If we're remoting, no need to start up any further services, * just forward the call. */ if (!_ephy_dbus_is_name_owner ()) { - /* FIXME */ - proxy = ephy_dbus_get_proxy (ephy_dbus_get_default (), EPHY_DBUS_SESSION); - if (proxy == NULL) + if (!call_dbus_proxy (proxy, user_time, &error)) { - error = g_error_new (STARTUP_ERROR_QUARK, - 0, - "Unable to get DBus proxy; aborting activation."); /* FIXME i18n */ - } - - if (proxy != NULL && - call_dbus_proxy (proxy, user_time, &error)) - { - gtk_main (); - _ephy_dbus_release (); - gdk_notify_startup_complete (); - exit (0); + show_error_message (&error); + + exit (1); } - _ephy_dbus_release (); + /* Wait for the response */ + gtk_main (); - show_error_message (&error); + _ephy_dbus_release (); - exit (1); + gdk_notify_startup_complete (); + exit (0); } /* We're not remoting; start our services */ @@ -668,27 +675,17 @@ main (int argc, gtk_about_dialog_set_url_hook (handle_url, NULL, NULL); gtk_about_dialog_set_email_hook (handle_email, NULL, NULL); - /* Now create the shell */ - _ephy_shell_create_instance (); - - /* Create DBUS proxy */ - proxy = ephy_dbus_get_proxy (ephy_dbus_get_default (), EPHY_DBUS_SESSION); - if (proxy == NULL) + /* Work around bug #328844 */ + env = g_getenv ("MOZ_ENABLE_PANGO"); + if (env == NULL || + env[0] == '\0' || + strcmp (env, "0") == 0) { - error = g_error_new (STARTUP_ERROR_QUARK, - 0, - "Unable to get DBus proxy; aborting activation."); /* FIXME i18n */ - - g_object_unref (ephy_shell_get_default ()); - - ephy_file_helpers_shutdown (); - _ephy_dbus_release (); - - show_error_message (&error); - - exit (1); + g_setenv ("MOZ_DISABLE_PANGO", "1", TRUE); } + /* Now create the shell */ + _ephy_shell_create_instance (); g_object_weak_ref (G_OBJECT (proxy), (GWeakNotify) dbus_g_proxy_finalized_cb, g_object_ref (ephy_shell_get_default ())); @@ -696,6 +693,8 @@ main (int argc, if (!call_dbus_proxy (proxy, user_time, &error)) { g_object_unref (ephy_shell_get_default ()); + g_object_unref (proxy); + g_assert (ephy_shell_get_default () == NULL); ephy_file_helpers_shutdown (); _ephy_dbus_release (); |