diff options
Diffstat (limited to 'embed/mozilla')
-rw-r--r-- | embed/mozilla/Makefile.am | 7 | ||||
-rw-r--r-- | embed/mozilla/default-prefs.js | 27 | ||||
-rw-r--r-- | embed/mozilla/mozilla-embed-single.cpp | 60 | ||||
-rw-r--r-- | embed/mozilla/mozilla-notifiers.cpp | 62 | ||||
-rw-r--r-- | embed/mozilla/mozilla-prefs.cpp | 200 | ||||
-rw-r--r-- | embed/mozilla/mozilla-prefs.h | 44 |
6 files changed, 114 insertions, 286 deletions
diff --git a/embed/mozilla/Makefile.am b/embed/mozilla/Makefile.am index 1db481fba..a2cc20c5f 100644 --- a/embed/mozilla/Makefile.am +++ b/embed/mozilla/Makefile.am @@ -99,12 +99,5 @@ libephymozillaembed_la_SOURCES = \ mozilla-i18n.h \ mozilla-notifiers.cpp \ mozilla-notifiers.h \ - mozilla-prefs.cpp \ - mozilla-prefs.h \ nsUnicharUtils.cpp \ nsUnicharUtils.h - -mozilla_DATA = default-prefs.js -mozilladir = $(pkgdatadir) - -EXTRA_DIST = $(mozilla_DATA) diff --git a/embed/mozilla/default-prefs.js b/embed/mozilla/default-prefs.js deleted file mode 100644 index be5a185c5..000000000 --- a/embed/mozilla/default-prefs.js +++ /dev/null @@ -1,27 +0,0 @@ -// Don't allow mozilla to raise window when setting focus (work around bugs) -user_pref("mozilla.widget.raise-on-setfocus", false); - -// set default search engine -user_pref("keyword.URL", "http://www.google.com/search?btnI=I%27m+Feeling+Lucky&q="); -user_pref("keyword.enabled", true); -user_pref("security.checkloaduri", false); - -// dont allow xpi installs from epiphany, there are crashes -user_pref("xpinstall.enabled", false); - -// deactivate mailcap and mime.types support -user_pref("helpers.global_mailcap_file", ""); -user_pref("helpers.global_mime_types_file", ""); -user_pref("helpers.private_mailcap_file", ""); -user_pref("helpers.private_mime_types_file", ""); - -// disable sucky XUL ftp view, have nice ns4-like html page instead -user_pref("network.dir.generate_html", true); - -// disable usless security warnings -user_pref("security.warn_entering_secure", false); -user_pref("security.warn_leaving_secure", false); -user_pref("security.warn_submit_insecure", false); - -// Always use the system colors if a page doesn't specify its own. -user_pref("browser.display.use_system_colors", true); diff --git a/embed/mozilla/mozilla-embed-single.cpp b/embed/mozilla/mozilla-embed-single.cpp index aa7daee03..612e2e546 100644 --- a/embed/mozilla/mozilla-embed-single.cpp +++ b/embed/mozilla/mozilla-embed-single.cpp @@ -21,7 +21,6 @@ #include "ephy-debug.h" #include "gtkmozembed.h" #include "mozilla-embed-single.h" -#include "mozilla-prefs.h" #include "ephy-prefs.h" #include "ephy-file-helpers.h" #include "mozilla-notifiers.h" @@ -36,6 +35,7 @@ #include <string.h> #include <nsICacheService.h> #include <nsCOMPtr.h> +#include <nsIPrefService.h> #include <nsNetCID.h> #include <nsIServiceManager.h> #include <nsIIOService.h> @@ -183,8 +183,45 @@ mozilla_embed_single_class_init (MozillaEmbedSingleClass *klass) static void mozilla_set_default_prefs (MozillaEmbedSingle *mes) { - mozilla_prefs_load (ephy_file ("default-prefs.js")); - mozilla_prefs_save (mes->priv->user_prefs); + nsCOMPtr<nsIPrefService> prefService; + + prefService = do_GetService (NS_PREFSERVICE_CONTRACTID); + g_return_if_fail (prefService != NULL); + + nsCOMPtr<nsIPrefBranch> pref; + prefService->GetBranch ("", getter_AddRefs(pref)); + g_return_if_fail (pref != NULL); + + /* Don't allow mozilla to raise window when setting focus (work around bugs) */ + pref->SetBoolPref ("mozilla.widget.raise-on-setfocus", PR_FALSE); + + /* set default search engine */ + pref->SetCharPref ("keyword.URL", "http://www.google.com/search?btnI=I%27m+Feeling+Lucky&q="); + pref->SetBoolPref ("keyword.enabled", PR_TRUE); + pref->SetBoolPref ("security.checkloaduri", PR_FALSE); + + /* dont allow xpi installs from epiphany, there are crashes */ + pref->SetBoolPref ("xpinstall.enabled", PR_FALSE); + + /* deactivate mailcap and mime.types support */ + pref->SetCharPref ("helpers.global_mailcap_file", ""); + pref->SetCharPref ("helpers.global_mime_types_file", ""); + pref->SetCharPref ("helpers.private_mailcap_file", ""); + pref->SetCharPref ("helpers.private_mime_types_file", ""); + + /* disable sucky XUL ftp view, have nice ns4-like html page instead */ + pref->SetBoolPref ("network.dir.generate_html", PR_TRUE); + + /* disable usless security warnings */ + pref->SetBoolPref ("security.warn_entering_secure", PR_FALSE); + pref->SetBoolPref ("security.warn_leaving_secure", PR_FALSE); + pref->SetBoolPref ("security.warn_submit_insecure", PR_FALSE); + + /* Always use the system colors if a page doesn't specify its own. */ + pref->SetBoolPref ("browser.display.use_system_colors", PR_TRUE); + + /* Smooth scrolling on */ + pref->SetBoolPref ("general.smoothScroll", PR_TRUE); } static void @@ -364,8 +401,6 @@ mozilla_embed_single_finalize (GObject *object) mozilla_notifiers_free (); - mozilla_prefs_save (mes->priv->user_prefs); - gtk_moz_embed_pop_startup (); g_free (mes->priv->user_prefs); @@ -599,11 +634,22 @@ impl_get_font_list (EphyEmbedSingle *shell, if (default_font != NULL) { - char key [255]; + char key[255]; + char *value = NULL; + nsCOMPtr<nsIPrefService> prefService; + + prefService = do_GetService (NS_PREFSERVICE_CONTRACTID); + g_return_val_if_fail (prefService != NULL, G_FAILED); + + nsCOMPtr<nsIPrefBranch> pref; + prefService->GetBranch ("", getter_AddRefs(pref)); + g_return_val_if_fail (pref != NULL, G_FAILED); sprintf (key, "font.name.%s.%s", fontType, langGroup); - *default_font = mozilla_prefs_get_string (key); + pref->GetCharPref (key, &value); + *default_font = g_strdup (value); + nsMemory::Free (value); } return G_OK; diff --git a/embed/mozilla/mozilla-notifiers.cpp b/embed/mozilla/mozilla-notifiers.cpp index 0ef4b18d0..1dd53a385 100644 --- a/embed/mozilla/mozilla-notifiers.cpp +++ b/embed/mozilla/mozilla-notifiers.cpp @@ -24,7 +24,6 @@ #include "ephy-embed-single.h" #include "mozilla-notifiers.h" #include "eel-gconf-extensions.h" -#include "mozilla-prefs.h" #include "MozRegisterComponents.h" #include "ephy-prefs.h" #include "ephy-embed-prefs.h" @@ -37,6 +36,9 @@ #include <stdlib.h> #include <sys/utsname.h> #include "nsBuildID.h" +#include "nsCOMPtr.h" +#include "nsIPrefService.h" +#include "nsIServiceManager.h" static void mozilla_own_colors_notifier(GConfClient *client, @@ -188,6 +190,64 @@ custom_notifiers [] = {NULL, NULL} }; +static gboolean +mozilla_prefs_set_string(const char *preference_name, const char *new_value) +{ + g_return_val_if_fail (preference_name != NULL, FALSE); + g_return_val_if_fail (new_value != NULL, FALSE); + nsCOMPtr<nsIPrefService> prefService = + do_GetService (NS_PREFSERVICE_CONTRACTID); + nsCOMPtr<nsIPrefBranch> pref; + prefService->GetBranch ("", getter_AddRefs(pref)); + + if (pref) + { + nsresult rv = pref->SetCharPref (preference_name, new_value); + return NS_SUCCEEDED (rv) ? TRUE : FALSE; + } + + return FALSE; +} + +static gboolean +mozilla_prefs_set_boolean (const char *preference_name, + gboolean new_boolean_value) +{ + g_return_val_if_fail (preference_name != NULL, FALSE); + + nsCOMPtr<nsIPrefService> prefService = + do_GetService (NS_PREFSERVICE_CONTRACTID); + nsCOMPtr<nsIPrefBranch> pref; + prefService->GetBranch ("", getter_AddRefs(pref)); + + if (pref) + { + nsresult rv = pref->SetBoolPref (preference_name, + new_boolean_value ? PR_TRUE : PR_FALSE); + return NS_SUCCEEDED (rv) ? TRUE : FALSE; + } + return FALSE; +} + +static gboolean +mozilla_prefs_set_int (const char *preference_name, int new_int_value) +{ + g_return_val_if_fail (preference_name != NULL, FALSE); + + nsCOMPtr<nsIPrefService> prefService = + do_GetService (NS_PREFSERVICE_CONTRACTID); + nsCOMPtr<nsIPrefBranch> pref; + prefService->GetBranch ("", getter_AddRefs(pref)); + + if (pref) + { + nsresult rv = pref->SetIntPref (preference_name, new_int_value); + return NS_SUCCEEDED (rv) ? TRUE : FALSE; + } + + return FALSE; +} + static void mozilla_font_size_notifier (GConfClient *client, guint cnxn_id, diff --git a/embed/mozilla/mozilla-prefs.cpp b/embed/mozilla/mozilla-prefs.cpp deleted file mode 100644 index 55f9dcc6b..000000000 --- a/embed/mozilla/mozilla-prefs.cpp +++ /dev/null @@ -1,200 +0,0 @@ -/* - * Copyright (C) 2000-2002 Marco Pesenti Gritti - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * 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. - */ - -#include "mozilla-prefs.h" - -#include <nsCOMPtr.h> -#include <nsIPrefService.h> -#include <nsIServiceManager.h> -#include <nsMemory.h> -#include <nsILocalFile.h> -#include <nsString.h> -#include <glib/gmessages.h> -#include <glib/gstrfuncs.h> - -void -mozilla_prefs_load (const char *filename) -{ - nsresult rv; - - nsCOMPtr<nsILocalFile> prefsLocalFile; - rv = NS_NewLocalFile (NS_ConvertUTF8toUCS2(filename), PR_TRUE, getter_AddRefs (prefsLocalFile)); - g_return_if_fail (NS_SUCCEEDED(rv)); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - g_return_if_fail (prefService != nsnull); - - nsCOMPtr<nsIFile> prefsFile; - prefsLocalFile->QueryInterface(NS_GET_IID(nsIFile), (void **)&prefsFile); - g_return_if_fail (prefsFile != nsnull); - - prefService->ReadUserPrefs (prefsFile); -} - -gboolean -mozilla_prefs_save (const char *filename) -{ - nsresult rv; - - nsCOMPtr<nsILocalFile> prefsLocalFile; - rv = NS_NewLocalFile (NS_ConvertUTF8toUCS2(filename), PR_TRUE, getter_AddRefs (prefsLocalFile)); - g_return_val_if_fail (NS_SUCCEEDED(rv), FALSE); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - g_return_val_if_fail (prefService != nsnull, FALSE); - - nsCOMPtr<nsIFile> prefsFile; - prefsLocalFile->QueryInterface(NS_GET_IID(nsIFile), (void **)&prefsFile); - g_return_val_if_fail (prefsFile != nsnull, FALSE); - - rv = prefService->SavePrefFile (prefsFile); - - return NS_SUCCEEDED (rv) ? TRUE : FALSE; -} - -gboolean -mozilla_prefs_set_string(const char *preference_name, const char *new_value) -{ - g_return_val_if_fail (preference_name != NULL, FALSE); - g_return_val_if_fail (new_value != NULL, FALSE); - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - nsresult rv = pref->SetCharPref (preference_name, new_value); - return NS_SUCCEEDED (rv) ? TRUE : FALSE; - } - - return FALSE; -} - -gboolean -mozilla_prefs_set_boolean (const char *preference_name, - gboolean new_boolean_value) -{ - g_return_val_if_fail (preference_name != NULL, FALSE); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - nsresult rv = pref->SetBoolPref (preference_name, - new_boolean_value ? PR_TRUE : PR_FALSE); - return NS_SUCCEEDED (rv) ? TRUE : FALSE; - } - return FALSE; -} - -gboolean -mozilla_prefs_set_int (const char *preference_name, int new_int_value) -{ - g_return_val_if_fail (preference_name != NULL, FALSE); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - nsresult rv = pref->SetIntPref (preference_name, new_int_value); - return NS_SUCCEEDED (rv) ? TRUE : FALSE; - } - - return FALSE; -} - -gboolean -mozilla_prefs_get_boolean (const char *preference_name, - gboolean default_value) -{ - PRBool value; - - g_return_val_if_fail (preference_name != NULL, FALSE); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - nsresult result; - - result = pref->GetBoolPref (preference_name, &value); - if (NS_FAILED (result)) return default_value; - } - - return (value == PR_TRUE) ? TRUE : FALSE; -} - -gint -mozilla_prefs_get_int (const char *preference_name) -{ - int value = -1; - - g_return_val_if_fail (preference_name != NULL, FALSE); - - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - pref->GetIntPref (preference_name, &value); - } - - return value; -} - -gchar * -mozilla_prefs_get_string(const char *preference_name) -{ - gchar *value = NULL; - gchar *result = NULL; - - g_return_val_if_fail (preference_name != NULL, FALSE); - nsCOMPtr<nsIPrefService> prefService = - do_GetService (NS_PREFSERVICE_CONTRACTID); - nsCOMPtr<nsIPrefBranch> pref; - prefService->GetBranch ("", getter_AddRefs(pref)); - - if (pref) - { - pref->GetCharPref (preference_name, &value); - } - - /* it's allocated by mozilla, so I could not g_free it */ - if (value) - { - result = g_strdup (value); - nsMemory::Free (value); - } - - return result; -} - diff --git a/embed/mozilla/mozilla-prefs.h b/embed/mozilla/mozilla-prefs.h deleted file mode 100644 index 91d98c2e0..000000000 --- a/embed/mozilla/mozilla-prefs.h +++ /dev/null @@ -1,44 +0,0 @@ -/* - * Copyright (C) 2000-2002 Marco Pesenti Gritti - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * 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. - */ - -#ifndef MOZILLA_PREFS_H -#define MOZILLA_PREFS_H - -#include "glib/gtypes.h" - -void mozilla_prefs_load (const char *filename); - -gboolean mozilla_prefs_save (const char *filename); - -gboolean mozilla_prefs_set_string (const char *preference_name, - const char *new_value); - -gboolean mozilla_prefs_set_boolean (const char *preference_name, - gboolean new_boolean_value); - -gboolean mozilla_prefs_set_int (const char *preference_name, - int new_int_value); - -gboolean mozilla_prefs_get_boolean (const char *preference_name, - gboolean default_value); - -int mozilla_prefs_get_int (const char *preference_name); - -gchar *mozilla_prefs_get_string (const char *preference_name); - -#endif |