diff options
author | Jory Pratt <anarchy@gentoo.org> | 2005-10-13 19:21:46 +0000 |
---|---|---|
committer | Jory Pratt <anarchy@gentoo.org> | 2005-10-13 19:21:46 +0000 |
commit | 32a8ae6612cddc0c7f239ce4f84361c34f7b255f (patch) | |
tree | a4146481a2a89b2fe45bba8af00f2757f3e853c8 | |
parent | unmasking kde 3.4.3 (monolithic and split ebuilds) (diff) | |
download | gentoo-2-32a8ae6612cddc0c7f239ce4f84361c34f7b255f.tar.gz gentoo-2-32a8ae6612cddc0c7f239ce4f84361c34f7b255f.tar.bz2 gentoo-2-32a8ae6612cddc0c7f239ce4f84361c34f7b255f.zip |
1.5 initial import, masked for all until further notice
(Portage version: 2.0.53_rc5)
14 files changed, 1952 insertions, 9 deletions
diff --git a/www-client/mozilla-firefox/ChangeLog b/www-client/mozilla-firefox/ChangeLog index 5b754a4f9e40..e65cf0fcef38 100644 --- a/www-client/mozilla-firefox/ChangeLog +++ b/www-client/mozilla-firefox/ChangeLog @@ -1,6 +1,18 @@ # ChangeLog for www-client/mozilla-firefox # Copyright 2000-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla-firefox/ChangeLog,v 1.96 2005/10/07 18:54:48 hansmi Exp $ +# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla-firefox/ChangeLog,v 1.97 2005/10/13 19:21:46 anarchy Exp $ + +*mozilla-firefox-1.5_beta2-r1 (13 Oct 2005) + + 13 Oct 2005; <anarchy@gentoo.org> + +files/1.5/mozilla-firefox-1.1a2-ia64.patch, + +files/1.5/embed-typeaheadfind.patch, + +files/1.5/firefox-cairo-canvas.patch, + +files/1.5/firefox-nopangoxft.patch, +files/1.5/firefox-visibility.patch, + +files/1.5/mozilla-hppa.patch, +files/1.5/mozilla-1.3-alpha-stubs.patch, + +files/gentoo-default-prefs.js, +files/icon/deerpark-icon.png, + files/icon/mozillafirefox.desktop, +mozilla-firefox-1.5_beta2-r1.ebuild: + 1.5 initial import, masked for all until further notice 07 Oct 2005; Michael Hanselmann <hansmi@gentoo.org> mozilla-firefox-1.0.7-r3.ebuild: diff --git a/www-client/mozilla-firefox/Manifest b/www-client/mozilla-firefox/Manifest index fa3b28abe247..a86ea66fbab5 100644 --- a/www-client/mozilla-firefox/Manifest +++ b/www-client/mozilla-firefox/Manifest @@ -1,4 +1,11 @@ MD5 da4785ef539cd7ea5606af67ac1f2299 ChangeLog 33743 +MD5 cb90e9f6097b975187892682ed286544 files/1.5/embed-typeaheadfind.patch 41361 +MD5 7847d262e628dcac303586fe02f2e8c4 files/1.5/firefox-cairo-canvas.patch 446 +MD5 91661761f2f232b08b74f5adc4f1eff0 files/1.5/firefox-nopangoxft.patch 839 +MD5 362f9e0b0f25b964f7120b68fb629ee0 files/1.5/firefox-visibility.patch 689 +MD5 23d1fbd03cc6dd346a4e4ce8f2d88ebf files/1.5/mozilla-1.3-alpha-stubs.patch 4646 +MD5 ff2980bf169954f9b255029e4312b6f8 files/1.5/mozilla-firefox-1.1a2-ia64.patch 2864 +MD5 8f8d70da6eb8cf07acbbb85fb0f08636 files/1.5/mozilla-hppa.patch 7863 MD5 1652483bf7e1d08241cd5e0436bea2ae files/10MozillaFirefox 32 MD5 e71e3d11bf8e3a03f965cf894593c28c files/digest-mozilla-firefox-1.0.6-r2 382 MD5 6da2b9dec8c7fbe104122a424727fb39 files/digest-mozilla-firefox-1.0.6-r3 451 @@ -8,13 +15,16 @@ MD5 8e6ffd5837cb4de55271592e3448b177 files/digest-mozilla-firefox-1.0.6-r6 447 MD5 8e6ffd5837cb4de55271592e3448b177 files/digest-mozilla-firefox-1.0.6-r7 447 MD5 1d1a1fe09e04d58a8d9faa9f14ffd0c6 files/digest-mozilla-firefox-1.0.7-r2 231 MD5 1d1a1fe09e04d58a8d9faa9f14ffd0c6 files/digest-mozilla-firefox-1.0.7-r3 231 +MD5 645b0b54e9e6a263423c6344e187071e files/digest-mozilla-firefox-1.5_beta2-r1 146 MD5 8e7d6f3220336cd4467d20bbe402e09a files/embedprompter-modal.patch 1548 MD5 48baf2f328e6478812c24e59037ff99c files/firefox-0.9-init.tar.bz2 3322 MD5 6a7a2240dc5864e7f8ee444e34e84461 files/firefox.1 2538 +MD5 9afab9469fd1d8af3d674a07ab0a0128 files/gentoo-default-prefs.js 281 MD5 3970f49b3f72cec38e126a2a140b524f files/gtk-prompt-service.patch 5520 MD5 eafec999c965792bf81df6bcbbe6c5ea files/gtk-tooltips.patch 2308 +MD5 f49aab1950ec54d7e8b2a51909dc6a5e files/icon/deerpark-icon.png 2963 MD5 bff260036c5dcca45da3218517fb33d8 files/icon/firefox-icon.png 3979 -MD5 fc5e3a5d794abcb431bafdbc80c89103 files/icon/mozillafirefox.desktop 341 +MD5 a0bcbedb1d99931658cb5e781442aed8 files/icon/mozillafirefox.desktop 169 MD5 23d1fbd03cc6dd346a4e4ce8f2d88ebf files/mozilla-1.3-alpha-stubs.patch 4646 MD5 bedafc238f92edd9cb98fae3d1af96df files/mozilla-1.7.12-gtk2xft-invalidate-pango_context.patch 620 MD5 1f71cb3a30531a90fb7d1d3445588ba6 files/mozilla-1.7.12-gtk2xft-link-pangoxft.patch 465 @@ -40,3 +50,4 @@ MD5 d8c6c3085e4fc8d06ef878579dddf116 mozilla-firefox-1.0.6-r6.ebuild 11233 MD5 8a30120dc035d60c58db0a9dc8c3b91b mozilla-firefox-1.0.6-r7.ebuild 9771 MD5 a98efa57e6fa9ad9a44343f5db5e8bf7 mozilla-firefox-1.0.7-r2.ebuild 8562 MD5 b686423c9050edfcfd7ff72ea4081f09 mozilla-firefox-1.0.7-r3.ebuild 9734 +MD5 f66e6976138d78eb40dfea00b3e4633f mozilla-firefox-1.5_beta2-r1.ebuild 9240 diff --git a/www-client/mozilla-firefox/files/1.5/embed-typeaheadfind.patch b/www-client/mozilla-firefox/files/1.5/embed-typeaheadfind.patch new file mode 100644 index 000000000000..d29780c0284b --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/embed-typeaheadfind.patch @@ -0,0 +1,1153 @@ +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/Makefile.in mozilla/extensions/typeaheadfind/Makefile.in +--- mozilla.orig/extensions/typeaheadfind/Makefile.in 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/Makefile.in 2005-03-26 11:39:29.000000000 -0500 +@@ -31,7 +31,7 @@ + + include $(DEPTH)/config/autoconf.mk + +-MODULE = typeaheadfind ++MODULE = typeaheadfindsea + DIRS = public src resources + + include $(topsrcdir)/config/rules.mk +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/public/Makefile.in mozilla/extensions/typeaheadfind/public/Makefile.in +--- mozilla.orig/extensions/typeaheadfind/public/Makefile.in 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/public/Makefile.in 2005-03-26 11:39:29.000000000 -0500 +@@ -31,11 +31,11 @@ + + include $(DEPTH)/config/autoconf.mk + +-MODULE=typeaheadfind +-XPIDL_MODULE=typeaheadfind ++MODULE=typeaheadfindsea ++XPIDL_MODULE=typeaheadfindsea + GRE_MODULE = 1 + +-XPIDLSRCS= ./nsITypeAheadFind.idl \ ++XPIDLSRCS= ./nsITypeAheadFindSea.idl \ + $(NULL) + + +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/public/nsITypeAheadFind.idl mozilla/extensions/typeaheadfind/public/nsITypeAheadFind.idl +--- mozilla.orig/extensions/typeaheadfind/public/nsITypeAheadFind.idl 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/public/nsITypeAheadFind.idl 1969-12-31 19:00:00.000000000 -0500 +@@ -1,88 +0,0 @@ +-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +-/* ***** BEGIN LICENSE BLOCK ***** +- * Version: MPL 1.1/GPL 2.0/LGPL 2.1 +- * +- * The contents of this file are subject to the Mozilla Public License Version +- * 1.1 (the "License"); you may not use this file except in compliance with +- * the License. You may obtain a copy of the License at +- * http://www.mozilla.org/MPL/ +- * +- * Software distributed under the License is distributed on an "AS IS" basis, +- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +- * for the specific language governing rights and limitations under the +- * License. +- * +- * The Original Code is mozilla.org code. +- * +- * The Initial Developer of the Original Code is +- * Netscape Communications Corporation. +- * Portions created by the Initial Developer are Copyright (C) 1998 +- * the Initial Developer. All Rights Reserved. +- * +- * Contributor(s): +- * Original Author: Aaron Leventhal (aaronl@netscape.com) +- * +- * Alternatively, the contents of this file may be used under the terms of +- * either the GNU General Public License Version 2 or later (the "GPL"), or +- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), +- * in which case the provisions of the GPL or the LGPL are applicable instead +- * of those above. If you wish to allow use of your version of this file only +- * under the terms of either the GPL or the LGPL, and not to allow others to +- * use your version of this file under the terms of the MPL, indicate your +- * decision by deleting the provisions above and replace them with the notice +- * and other provisions required by the GPL or the LGPL. If you do not delete +- * the provisions above, a recipient may use your version of this file under +- * the terms of any one of the MPL, the GPL or the LGPL. +- * +- * ***** END LICENSE BLOCK ***** */ +- +-#include "nsISupports.idl" +-#include "domstubs.idl" +-#include "nsISupportsPrimitives.idl" +- +-%{ C++ +- #include "nsIDOMEvent.h" +- +- #define NS_TYPEAHEADFIND_CID \ +- {0x46590685, 0xbc00, 0x4aac, {0xab, 0xed, 0x2c, 0x10, 0xa5, 0xb9, 0x45, 0xa4}} +- +- #define NS_TYPEAHEADFIND_CONTRACTID "@mozilla.org/typeaheadfind;1" +-%} +- +-interface nsIDOMEvent; +- +-[scriptable, uuid(AD1C62CC-72F4-4c5b-BE78-503854F9E0D8)] +-interface nsITypeAheadFind : nsISupports +-{ +- /** Is type ahead find mode currently on? */ +- readonly attribute boolean isActive; +- +- /** Manually start type ahead find mode */ +- void startNewFind(in nsIDOMWindow aWindow, in boolean aLinksOnly); +- +- /** Manually cancel type ahead find mode */ +- void cancelFind(); +- +- /** +- * Will find as you type start automatically if the user +- * types with the focus on page content other than a textfield or select? +- * If autostart is off, the startNewFind() method can be used to enact +- * type ahead find, as well as cmd_findTypeLinks or cmd_findTypeText. +- */ +- void setAutoStart(in nsIDOMWindow aWindow, in boolean aIsAutoStartOn); +- boolean getAutoStart(in nsIDOMWindow aWindow); +- +- /** +- * Find next recurrence if typeaheadfind was the last used find, +- * as opposed to regular find. Returns false in nsISupportsPRBool if we +- * don't handle the request. +- */ +- void findNext(in boolean aReverse, in nsISupportsInterfacePointer aCallerWindowSupports); +- +- /* +- * Go back and remove one character from find string +- * Returns true if backspace used +- */ +- boolean backOneChar(); +-}; +- +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/public/nsITypeAheadFindSea.idl mozilla/extensions/typeaheadfind/public/nsITypeAheadFindSea.idl +--- mozilla.orig/extensions/typeaheadfind/public/nsITypeAheadFindSea.idl 1969-12-31 19:00:00.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/public/nsITypeAheadFindSea.idl 2005-03-26 11:39:29.000000000 -0500 +@@ -0,0 +1,88 @@ ++/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ ++/* ***** BEGIN LICENSE BLOCK ***** ++ * Version: MPL 1.1/GPL 2.0/LGPL 2.1 ++ * ++ * The contents of this file are subject to the Mozilla Public License Version ++ * 1.1 (the "License"); you may not use this file except in compliance with ++ * the License. You may obtain a copy of the License at ++ * http://www.mozilla.org/MPL/ ++ * ++ * Software distributed under the License is distributed on an "AS IS" basis, ++ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License ++ * for the specific language governing rights and limitations under the ++ * License. ++ * ++ * The Original Code is mozilla.org code. ++ * ++ * The Initial Developer of the Original Code is ++ * Netscape Communications Corporation. ++ * Portions created by the Initial Developer are Copyright (C) 1998 ++ * the Initial Developer. All Rights Reserved. ++ * ++ * Contributor(s): ++ * Original Author: Aaron Leventhal (aaronl@netscape.com) ++ * ++ * Alternatively, the contents of this file may be used under the terms of ++ * either the GNU General Public License Version 2 or later (the "GPL"), or ++ * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), ++ * in which case the provisions of the GPL or the LGPL are applicable instead ++ * of those above. If you wish to allow use of your version of this file only ++ * under the terms of either the GPL or the LGPL, and not to allow others to ++ * use your version of this file under the terms of the MPL, indicate your ++ * decision by deleting the provisions above and replace them with the notice ++ * and other provisions required by the GPL or the LGPL. If you do not delete ++ * the provisions above, a recipient may use your version of this file under ++ * the terms of any one of the MPL, the GPL or the LGPL. ++ * ++ * ***** END LICENSE BLOCK ***** */ ++ ++#include "nsISupports.idl" ++#include "domstubs.idl" ++#include "nsISupportsPrimitives.idl" ++ ++%{ C++ ++ #include "nsIDOMEvent.h" ++ ++ #define NS_TYPEAHEADFINDSEA_CID \ ++ {0x46590685, 0xbc00, 0x4aac, {0xab, 0xed, 0x2c, 0x10, 0xa5, 0xb9, 0x45, 0xa4}} ++ ++ #define NS_TYPEAHEADFINDSEA_CONTRACTID "@mozilla.org/typeaheadfindsea;1" ++%} ++ ++interface nsIDOMEvent; ++ ++[scriptable, uuid(AD1C62CC-72F4-4c5b-BE78-503854F9E0D8)] ++interface nsITypeAheadFindSea : nsISupports ++{ ++ /** Is type ahead find mode currently on? */ ++ readonly attribute boolean isActive; ++ ++ /** Manually start type ahead find mode */ ++ void startNewFind(in nsIDOMWindow aWindow, in boolean aLinksOnly); ++ ++ /** Manually cancel type ahead find mode */ ++ void cancelFind(); ++ ++ /** ++ * Will find as you type start automatically if the user ++ * types with the focus on page content other than a textfield or select? ++ * If autostart is off, the startNewFind() method can be used to enact ++ * type ahead find, as well as cmd_findTypeLinks or cmd_findTypeText. ++ */ ++ void setAutoStart(in nsIDOMWindow aWindow, in boolean aIsAutoStartOn); ++ boolean getAutoStart(in nsIDOMWindow aWindow); ++ ++ /** ++ * Find next recurrence if typeaheadfindsea was the last used find, ++ * as opposed to regular find. Returns false in nsISupportsPRBool if we ++ * don't handle the request. ++ */ ++ void findNext(in boolean aReverse, in nsISupportsInterfacePointer aCallerWindowSupports); ++ ++ /* ++ * Go back and remove one character from find string ++ * Returns true if backspace used ++ */ ++ boolean backOneChar(); ++}; ++ +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/resources/content/prefs/typeaheadfind.js mozilla/extensions/typeaheadfind/resources/content/prefs/typeaheadfind.js +--- mozilla.orig/extensions/typeaheadfind/resources/content/prefs/typeaheadfind.js 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/resources/content/prefs/typeaheadfind.js 2005-03-26 11:39:29.000000000 -0500 +@@ -36,7 +36,7 @@ + * + * ***** END LICENSE BLOCK ***** */ + +-pref("accessibility.typeaheadfind", true); +-pref("accessibility.typeaheadfind.linksonly", true); +-pref("accessibility.typeaheadfind.startlinksonly", false); +-pref("accessibility.typeaheadfind.timeout", 5000); ++pref("accessibility.typeaheadfindsea", true); ++pref("accessibility.typeaheadfindsea.linksonly", true); ++pref("accessibility.typeaheadfindsea.startlinksonly", false); ++pref("accessibility.typeaheadfindsea.timeout", 5000); +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/resources/jar.mn mozilla/extensions/typeaheadfind/resources/jar.mn +--- mozilla.orig/extensions/typeaheadfind/resources/jar.mn 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/resources/jar.mn 2005-03-26 11:39:29.000000000 -0500 +@@ -1,5 +1,5 @@ + en-US.jar: +- locale/en-US/global/typeaheadfind.properties (locale/en-US/typeaheadfind.properties) ++ locale/en-US/global/typeaheadfindsea.properties (locale/en-US/typeaheadfindsea.properties) + + toolkit.jar: + content/global/notfound.wav (content/notfound.wav) +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/resources/locale/en-US/typeaheadfind.properties mozilla/extensions/typeaheadfind/resources/locale/en-US/typeaheadfind.properties +--- mozilla.orig/extensions/typeaheadfind/resources/locale/en-US/typeaheadfind.properties 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/resources/locale/en-US/typeaheadfind.properties 1969-12-31 19:00:00.000000000 -0500 +@@ -1,13 +0,0 @@ +-openparen = ( +-closeparen = ) +-textfound = Text found: " +-textnotfound = Text not found: " +-linkfound = Link found: " +-linknotfound = Link not found: " +-closequote = " +-stopfind = Find stopped. +-starttextfind = Starting -- find text as you type +-startlinkfind = Starting -- find links as you type +-repeated = repeated +-nextmatch = - next match +-prevmatch = - previous match +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/resources/locale/en-US/typeaheadfindsea.properties mozilla/extensions/typeaheadfind/resources/locale/en-US/typeaheadfindsea.properties +--- mozilla.orig/extensions/typeaheadfind/resources/locale/en-US/typeaheadfindsea.properties 1969-12-31 19:00:00.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/resources/locale/en-US/typeaheadfindsea.properties 2005-03-26 11:39:29.000000000 -0500 +@@ -0,0 +1,13 @@ ++openparen = ( ++closeparen = ) ++textfound = Text found: " ++textnotfound = Text not found: " ++linkfound = Link found: " ++linknotfound = Link not found: " ++closequote = " ++stopfind = Find stopped. ++starttextfind = Starting -- find text as you type ++startlinkfind = Starting -- find links as you type ++repeated = repeated ++nextmatch = - next match ++prevmatch = - previous match +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/Makefile.in mozilla/extensions/typeaheadfind/src/Makefile.in +--- mozilla.orig/extensions/typeaheadfind/src/Makefile.in 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/Makefile.in 2005-03-26 11:39:29.000000000 -0500 +@@ -31,15 +31,15 @@ + + include $(DEPTH)/config/autoconf.mk + +-MODULE = typeaheadfind +-LIBRARY_NAME = typeaheadfind ++MODULE = typeaheadfindsea ++LIBRARY_NAME = typeaheadfindsea + ifneq ($(OS_ARCH),WINNT) +-SHORT_LIBNAME = typahead ++SHORT_LIBNAME = typaheadsea + endif + GRE_MODULE = 1 + MOZILLA_INTERNAL_API = 1 + +-PACKAGE_FILE = typeaheadfind.pkg ++PACKAGE_FILE = typeaheadfindsea.pkg + + REQUIRES = appcomps \ + embedcomponents \ +@@ -66,7 +66,7 @@ + + EXPORT_LIBRARY = 1 + IS_COMPONENT = 1 +-MODULE_NAME = nsTypeAheadFind ++MODULE_NAME = nsTypeAheadFindSea + + CPPSRCS = \ + nsTypeAheadFind.cpp \ +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFind.cpp mozilla/extensions/typeaheadfind/src/nsTypeAheadFind.cpp +--- mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFind.cpp 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/nsTypeAheadFind.cpp 2005-03-26 11:39:29.000000000 -0500 +@@ -114,8 +114,8 @@ + //////////////////////////////////////////////////////////////////////// + + +-NS_INTERFACE_MAP_BEGIN(nsTypeAheadFind) +- NS_INTERFACE_MAP_ENTRY(nsITypeAheadFind) ++NS_INTERFACE_MAP_BEGIN(nsTypeAheadFindSea) ++ NS_INTERFACE_MAP_ENTRY(nsITypeAheadFindSea) + NS_INTERFACE_MAP_ENTRY(nsISupportsWeakReference) + NS_INTERFACE_MAP_ENTRY(nsITimerCallback) + NS_INTERFACE_MAP_ENTRY(nsIScrollPositionListener) +@@ -128,8 +128,8 @@ + NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIDOMEventListener, nsIDOMKeyListener) + NS_INTERFACE_MAP_END + +-NS_IMPL_ADDREF(nsTypeAheadFind) +-NS_IMPL_RELEASE(nsTypeAheadFind) ++NS_IMPL_ADDREF(nsTypeAheadFindSea) ++NS_IMPL_RELEASE(nsTypeAheadFindSea) + + static NS_DEFINE_IID(kRangeCID, NS_RANGE_CID); + static NS_DEFINE_CID(kStringBundleServiceCID, NS_STRINGBUNDLESERVICE_CID); +@@ -138,11 +138,11 @@ + + #define NS_FIND_CONTRACTID "@mozilla.org/embedcomp/rangefind;1" + +-nsTypeAheadFind* nsTypeAheadFind::sInstance = nsnull; +-PRInt32 nsTypeAheadFind::sAccelKey = -1; // magic value of -1 when unitialized ++nsTypeAheadFindSea* nsTypeAheadFindSea::sInstance = nsnull; ++PRInt32 nsTypeAheadFindSea::sAccelKey = -1; // magic value of -1 when unitialized + + +-nsTypeAheadFind::nsTypeAheadFind(): ++nsTypeAheadFindSea::nsTypeAheadFindSea(): + mIsFindAllowedInWindow(PR_FALSE), mAutoStartPref(PR_FALSE), + mLinksOnlyPref(PR_FALSE), mStartLinksOnlyPref(PR_FALSE), + mLinksOnly(PR_FALSE), mIsTypeAheadOn(PR_FALSE), mCaretBrowsingOn(PR_FALSE), +@@ -161,25 +161,25 @@ + static PRInt32 gInstanceCount; + ++gInstanceCount; + NS_ASSERTION(gInstanceCount == 1, +- "There should be only 1 instance of nsTypeAheadFind!"); ++ "There should be only 1 instance of nsTypeAheadFindSea!"); + #endif + } + + +-nsTypeAheadFind::~nsTypeAheadFind() ++nsTypeAheadFindSea::~nsTypeAheadFindSea() + { + RemoveDocListeners(); + mTimer = nsnull; + + nsCOMPtr<nsIPrefBranch2> prefInternal(do_GetService(NS_PREFSERVICE_CONTRACTID)); + if (prefInternal) { +- prefInternal->RemoveObserver("accessibility.typeaheadfind", this); ++ prefInternal->RemoveObserver("accessibility.typeaheadfindsea", this); + prefInternal->RemoveObserver("accessibility.browsewithcaret", this); + } + } + + nsresult +-nsTypeAheadFind::Init() ++nsTypeAheadFindSea::Init() + { + nsresult rv = NS_NewISupportsArray(getter_AddRefs(mManualFindWindows)); + NS_ENSURE_SUCCESS(rv, rv); +@@ -196,7 +196,7 @@ + } + + // ----------- Listen to prefs ------------------ +- rv = prefInternal->AddObserver("accessibility.typeaheadfind", this, PR_FALSE); ++ rv = prefInternal->AddObserver("accessibility.typeaheadfindsea", this, PR_FALSE); + NS_ENSURE_SUCCESS(rv, rv); + + rv = prefInternal->AddObserver("accessibility.browsewithcaret", this, PR_FALSE); +@@ -217,11 +217,11 @@ + return rv; + } + +-nsTypeAheadFind * +-nsTypeAheadFind::GetInstance() ++nsTypeAheadFindSea * ++nsTypeAheadFindSea::GetInstance() + { + if (!sInstance) { +- sInstance = new nsTypeAheadFind(); ++ sInstance = new nsTypeAheadFindSea(); + if (!sInstance) + return nsnull; + +@@ -241,14 +241,14 @@ + + + void +-nsTypeAheadFind::ReleaseInstance() ++nsTypeAheadFindSea::ReleaseInstance() + { + NS_IF_RELEASE(sInstance); + } + + + void +-nsTypeAheadFind::Shutdown() ++nsTypeAheadFindSea::Shutdown() + { + // Application shutdown + mTimer = nsnull; +@@ -264,14 +264,14 @@ + // ------- Pref Callbacks (2) --------------- + + nsresult +-nsTypeAheadFind::PrefsReset() ++nsTypeAheadFindSea::PrefsReset() + { + nsCOMPtr<nsIPrefBranch> prefBranch(do_GetService(NS_PREFSERVICE_CONTRACTID)); + NS_ENSURE_TRUE(prefBranch, NS_ERROR_FAILURE); + + PRBool wasTypeAheadOn = mIsTypeAheadOn; + +- prefBranch->GetBoolPref("accessibility.typeaheadfind", &mIsTypeAheadOn); ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea", &mIsTypeAheadOn); + + if (mIsTypeAheadOn != wasTypeAheadOn) { + if (!mIsTypeAheadOn) { +@@ -291,7 +291,7 @@ + do_GetService(kStringBundleServiceCID); + + if (stringBundleService) +- stringBundleService->CreateBundle(TYPEAHEADFIND_BUNDLE_URL, ++ stringBundleService->CreateBundle(TYPEAHEADFINDSEA_BUNDLE_URL, + getter_AddRefs(mStringBundle)); + + // Observe find again commands. We'll handle them if we were the last find +@@ -306,34 +306,34 @@ + } + + PRBool oldAutoStartPref = mAutoStartPref; +- prefBranch->GetBoolPref("accessibility.typeaheadfind.autostart", ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea.autostart", + &mAutoStartPref); + if (mAutoStartPref != oldAutoStartPref) { + ResetGlobalAutoStart(mAutoStartPref); + } + +- prefBranch->GetBoolPref("accessibility.typeaheadfind.linksonly", ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea.linksonly", + &mLinksOnlyPref); + +- prefBranch->GetBoolPref("accessibility.typeaheadfind.startlinksonly", ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea.startlinksonly", + &mStartLinksOnlyPref); + + PRBool isSoundEnabled = PR_TRUE; +- prefBranch->GetBoolPref("accessibility.typeaheadfind.enablesound", ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea.enablesound", + &isSoundEnabled); + nsXPIDLCString soundStr; + if (isSoundEnabled) { +- prefBranch->GetCharPref("accessibility.typeaheadfind.soundURL", ++ prefBranch->GetCharPref("accessibility.typeaheadfindsea.soundURL", + getter_Copies(soundStr)); + } + mNotFoundSoundURL = soundStr; + + PRBool isTimeoutEnabled = PR_FALSE; +- prefBranch->GetBoolPref("accessibility.typeaheadfind.enabletimeout", ++ prefBranch->GetBoolPref("accessibility.typeaheadfindsea.enabletimeout", + &isTimeoutEnabled); + PRInt32 timeoutLength = 0; + if (isTimeoutEnabled) { +- prefBranch->GetIntPref("accessibility.typeaheadfind.timeout", ++ prefBranch->GetIntPref("accessibility.typeaheadfindsea.timeout", + &timeoutLength); + } + mTimeoutLength = timeoutLength; +@@ -349,7 +349,7 @@ + // ------- nsITimer Methods (1) --------------- + + NS_IMETHODIMP +-nsTypeAheadFind::Notify(nsITimer *timer) ++nsTypeAheadFindSea::Notify(nsITimer *timer) + { + CancelFind(); + return NS_OK; +@@ -358,7 +358,7 @@ + // ----------- nsIObserver Methods (1) ------------------- + + NS_IMETHODIMP +-nsTypeAheadFind::Observe(nsISupports *aSubject, const char *aTopic, ++nsTypeAheadFindSea::Observe(nsISupports *aSubject, const char *aTopic, + const PRUnichar *aData) + { + PRBool isOpening; +@@ -476,7 +476,7 @@ + + + nsresult +-nsTypeAheadFind::UseInWindow(nsIDOMWindow *aDOMWin) ++nsTypeAheadFindSea::UseInWindow(nsIDOMWindow *aDOMWin) + { + NS_ENSURE_ARG_POINTER(aDOMWin); + +@@ -529,7 +529,7 @@ + // ------- nsIDOMEventListener Methods (1) --------------- + + NS_IMETHODIMP +-nsTypeAheadFind::HandleEvent(nsIDOMEvent* aEvent) ++nsTypeAheadFindSea::HandleEvent(nsIDOMEvent* aEvent) + { + nsAutoString eventType; + aEvent->GetType(eventType); +@@ -589,21 +589,21 @@ + // ------- nsIDOMKeyListener Methods (3) --------------- + + NS_IMETHODIMP +-nsTypeAheadFind::KeyDown(nsIDOMEvent* aEvent) ++nsTypeAheadFindSea::KeyDown(nsIDOMEvent* aEvent) + { + return NS_OK; + } + + + NS_IMETHODIMP +-nsTypeAheadFind::KeyUp(nsIDOMEvent* aEvent) ++nsTypeAheadFindSea::KeyUp(nsIDOMEvent* aEvent) + { + return NS_OK; + } + + + NS_IMETHODIMP +-nsTypeAheadFind::KeyPress(nsIDOMEvent* aEvent) ++nsTypeAheadFindSea::KeyPress(nsIDOMEvent* aEvent) + { + if (!mIsTypeAheadOn || mIsMenuBarActive || mIsMenuPopupActive) { + return NS_OK; +@@ -733,7 +733,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::BackOneChar(PRBool *aIsBackspaceUsed) ++nsTypeAheadFindSea::BackOneChar(PRBool *aIsBackspaceUsed) + { + if (!mFocusedDocSelection) { + *aIsBackspaceUsed = PR_FALSE; +@@ -863,7 +863,7 @@ + + + nsresult +-nsTypeAheadFind::HandleChar(PRUnichar aChar) ++nsTypeAheadFindSea::HandleChar(PRUnichar aChar) + { + // Add a printable char to mTypeAheadBuffer, then search for buffer contents + +@@ -1039,7 +1039,7 @@ + + + void +-nsTypeAheadFind::SaveFind() ++nsTypeAheadFindSea::SaveFind() + { + // Store find string for find-next + mFindNextBuffer = mTypeAheadBuffer; +@@ -1060,14 +1060,14 @@ + mFindService->SetSearchString(mFindNextBuffer); + } + +- // --- If accessibility.typeaheadfind.timeout is set, ++ // --- If accessibility.typeaheadfindsea.timeout is set, + // cancel find after specified # milliseconds --- + StartTimeout(); + } + + + void +-nsTypeAheadFind::PlayNotFoundSound() ++nsTypeAheadFindSea::PlayNotFoundSound() + { + if (mNotFoundSoundURL.IsEmpty()) // no sound + return; +@@ -1097,7 +1097,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleText(nsIDOMEvent* aTextEvent) ++nsTypeAheadFindSea::HandleText(nsIDOMEvent* aTextEvent) + { + // This is called multiple times in the middle of an + // IME composition +@@ -1145,7 +1145,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleStartComposition(nsIDOMEvent* aCompositionEvent) ++nsTypeAheadFindSea::HandleStartComposition(nsIDOMEvent* aCompositionEvent) + { + // This is called once at the start of an IME composition + +@@ -1167,7 +1167,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleEndComposition(nsIDOMEvent* aCompositionEvent) ++nsTypeAheadFindSea::HandleEndComposition(nsIDOMEvent* aCompositionEvent) + { + // This is called once at the end of an IME composition + +@@ -1198,28 +1198,28 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleQueryComposition(nsIDOMEvent* aCompositionEvent) ++nsTypeAheadFindSea::HandleQueryComposition(nsIDOMEvent* aCompositionEvent) + { + return NS_OK; + } + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleQueryReconversion(nsIDOMEvent* aCompositionEvent) ++nsTypeAheadFindSea::HandleQueryReconversion(nsIDOMEvent* aCompositionEvent) + { + return NS_OK; + } + + + NS_IMETHODIMP +-nsTypeAheadFind::HandleQueryCaretRect(nsIDOMEvent* aCompositionEvent) ++nsTypeAheadFindSea::HandleQueryCaretRect(nsIDOMEvent* aCompositionEvent) + { + return NS_OK; + } + + + nsresult +-nsTypeAheadFind::FindItNow(nsIPresShell *aPresShell, ++nsTypeAheadFindSea::FindItNow(nsIPresShell *aPresShell, + PRBool aIsRepeatingSameChar, PRBool aIsLinksOnly, + PRBool aIsFirstVisiblePreferred) + { +@@ -1241,7 +1241,7 @@ + + nsCOMPtr<nsISupports> startingContainer = presContext->GetContainer(); + nsCOMPtr<nsIDocShellTreeItem> treeItem(do_QueryInterface(startingContainer)); +- NS_ASSERTION(treeItem, "Bug 175321 Crashes with Type Ahead Find [@ nsTypeAheadFind::FindItNow]"); ++ NS_ASSERTION(treeItem, "Bug 175321 Crashes with Type Ahead Find [@ nsTypeAheadFindSea::FindItNow]"); + if (!treeItem) { + return NS_ERROR_FAILURE; + } +@@ -1465,7 +1465,7 @@ + + + nsresult +-nsTypeAheadFind::GetSearchContainers(nsISupports *aContainer, ++nsTypeAheadFindSea::GetSearchContainers(nsISupports *aContainer, + PRBool aIsRepeatingSameChar, + PRBool aIsFirstVisiblePreferred, + PRBool aCanUseDocSelection, +@@ -1573,7 +1573,7 @@ + + + void +-nsTypeAheadFind::RangeStartsInsideLink(nsIDOMRange *aRange, ++nsTypeAheadFindSea::RangeStartsInsideLink(nsIDOMRange *aRange, + nsIPresShell *aPresShell, + PRBool *aIsInsideLink, + PRBool *aIsStartingLink) +@@ -1680,7 +1680,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::ScrollPositionWillChange(nsIScrollableView *aView, ++nsTypeAheadFindSea::ScrollPositionWillChange(nsIScrollableView *aView, + nscoord aX, nscoord aY) + { + return NS_OK; +@@ -1688,7 +1688,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::ScrollPositionDidChange(nsIScrollableView *aScrollableView, ++nsTypeAheadFindSea::ScrollPositionDidChange(nsIScrollableView *aScrollableView, + nscoord aX, nscoord aY) + { + if (!mIsFindingText) +@@ -1699,7 +1699,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::NotifySelectionChanged(nsIDOMDocument *aDoc, ++nsTypeAheadFindSea::NotifySelectionChanged(nsIDOMDocument *aDoc, + nsISelection *aSel, PRInt16 aReason) + { + if (!mIsFindingText) { +@@ -1716,10 +1716,10 @@ + } + + +-// ---------------- nsITypeAheadFind -------------------- ++// ---------------- nsITypeAheadFindSea -------------------- + + NS_IMETHODIMP +-nsTypeAheadFind::FindNext(PRBool aFindBackwards, nsISupportsInterfacePointer *aCallerWindowSupports) ++nsTypeAheadFindSea::FindNext(PRBool aFindBackwards, nsISupportsInterfacePointer *aCallerWindowSupports) + { + NS_ENSURE_TRUE(aCallerWindowSupports, NS_ERROR_FAILURE); + +@@ -1731,7 +1731,7 @@ + return NS_OK; + } + +- // Compare the top level content pres shell of typeaheadfind ++ // Compare the top level content pres shell of typeaheadfindsea + // with the top level content pres shell window where find next is happening + // If they're different, exit so that webbrowswerfind can handle FindNext() + +@@ -1764,7 +1764,7 @@ + NS_ENSURE_TRUE(callerPresShell, NS_OK); + + if (callerPresShell != typeAheadPresShell) { +- // This means typeaheadfind is active in a different window or doc ++ // This means typeaheadfindsea is active in a different window or doc + // So it's not appropriate to find next for the current window + mFindNextBuffer.Truncate(); + return NS_OK; +@@ -1782,7 +1782,7 @@ + webBrowserFind->GetSearchString(getter_Copies(webBrowserFindString)); + if (!webBrowserFindString.Equals(mFindNextBuffer)) { + // If they're not equal, then the find dialog was used last, +- // not typeaheadfind. Typeaheadfind applies to the last find, ++ // not typeaheadfindsea. Typeaheadfind applies to the last find, + // so we should let nsIWebBrowserFind::FindNext() do it. + mFindNextBuffer.Truncate(); + return NS_OK; +@@ -1832,7 +1832,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::GetIsActive(PRBool *aIsActive) ++nsTypeAheadFindSea::GetIsActive(PRBool *aIsActive) + { + *aIsActive = mLinksOnlyManuallySet || !mTypeAheadBuffer.IsEmpty(); + +@@ -1845,7 +1845,7 @@ + */ + + NS_IMETHODIMP +-nsTypeAheadFind::StartNewFind(nsIDOMWindow *aWindow, PRBool aLinksOnly) ++nsTypeAheadFindSea::StartNewFind(nsIDOMWindow *aWindow, PRBool aLinksOnly) + { + if (!mFind || !mIsTypeAheadOn || !aWindow) + return NS_ERROR_FAILURE; // Type Ahead Find not correctly initialized +@@ -1878,7 +1878,7 @@ + } + + void +-nsTypeAheadFind::ResetGlobalAutoStart(PRBool aAutoStart) ++nsTypeAheadFindSea::ResetGlobalAutoStart(PRBool aAutoStart) + { + // Enumerate through the current top level windows + // and either attach or remove window listeners +@@ -1916,7 +1916,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::SetAutoStart(nsIDOMWindow *aDOMWin, PRBool aAutoStartOn) ++nsTypeAheadFindSea::SetAutoStart(nsIDOMWindow *aDOMWin, PRBool aAutoStartOn) + { + if (!aDOMWin) { + return NS_ERROR_FAILURE; +@@ -1946,7 +1946,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::GetAutoStart(nsIDOMWindow *aDOMWin, PRBool *aIsAutoStartOn) ++nsTypeAheadFindSea::GetAutoStart(nsIDOMWindow *aDOMWin, PRBool *aIsAutoStartOn) + { + *aIsAutoStartOn = PR_FALSE; + +@@ -2014,7 +2014,7 @@ + + + NS_IMETHODIMP +-nsTypeAheadFind::CancelFind() ++nsTypeAheadFindSea::CancelFind() + { + // Stop current find if: + // 1. Escape pressed +@@ -2070,7 +2070,7 @@ + // ------- Helper Methods --------------- + + void +-nsTypeAheadFind::GetTopContentPresShell(nsIDocShellTreeItem *aDocShellTreeItem, ++nsTypeAheadFindSea::GetTopContentPresShell(nsIDocShellTreeItem *aDocShellTreeItem, + nsIPresShell **aPresShell) + { + *aPresShell = nsnull; +@@ -2086,7 +2086,7 @@ + } + + void +-nsTypeAheadFind::GetStartWindow(nsIDOMWindow *aWindow, nsIDOMWindow **aStartWindow) ++nsTypeAheadFindSea::GetStartWindow(nsIDOMWindow *aWindow, nsIDOMWindow **aStartWindow) + { + // Return the root ancestor content window of aWindow + +@@ -2118,7 +2118,7 @@ + } + + nsresult +-nsTypeAheadFind::GetWebBrowserFind(nsIDOMWindow *aWin, ++nsTypeAheadFindSea::GetWebBrowserFind(nsIDOMWindow *aWin, + nsIWebBrowserFind **aWebBrowserFind) + { + NS_ENSURE_ARG_POINTER(aWin); +@@ -2143,7 +2143,7 @@ + + + void +-nsTypeAheadFind::StartTimeout() ++nsTypeAheadFindSea::StartTimeout() + { + if (mTimeoutLength) { + if (!mTimer) { +@@ -2159,7 +2159,7 @@ + } + + void +-nsTypeAheadFind::SetSelectionLook(nsIPresShell *aPresShell, ++nsTypeAheadFindSea::SetSelectionLook(nsIPresShell *aPresShell, + PRBool aChangeColor, + PRBool aEnabled) + { +@@ -2167,8 +2167,8 @@ + return; + + // Show caret when type ahead find is on +- // Also paint selection bright (typeaheadfind on) or normal +- // (typeaheadfind off) ++ // Also paint selection bright (typeaheadfindsea on) or normal ++ // (typeaheadfindsea off) + + if (aChangeColor) { + mFocusedDocSelCon->SetDisplaySelection(nsISelectionController::SELECTION_ATTENTION); +@@ -2211,7 +2211,7 @@ + + + void +-nsTypeAheadFind::RemoveDocListeners() ++nsTypeAheadFindSea::RemoveDocListeners() + { + nsCOMPtr<nsIPresShell> presShell(GetPresShell()); + nsIViewManager* vm = nsnull; +@@ -2245,7 +2245,7 @@ + + + void +-nsTypeAheadFind::AttachDocListeners(nsIPresShell *aPresShell) ++nsTypeAheadFindSea::AttachDocListeners(nsIPresShell *aPresShell) + { + if (!aPresShell) { + return; +@@ -2275,7 +2275,7 @@ + + + void +-nsTypeAheadFind::RemoveWindowListeners(nsIDOMWindow *aDOMWin) ++nsTypeAheadFindSea::RemoveWindowListeners(nsIDOMWindow *aDOMWin) + { + nsCOMPtr<nsIDOMEventTarget> chromeEventHandler; + GetChromeEventHandler(aDOMWin, getter_AddRefs(chromeEventHandler)); +@@ -2332,7 +2332,7 @@ + + + void +-nsTypeAheadFind::AttachWindowListeners(nsIDOMWindow *aDOMWin) ++nsTypeAheadFindSea::AttachWindowListeners(nsIDOMWindow *aDOMWin) + { + nsCOMPtr<nsIDOMEventTarget> chromeEventHandler; + GetChromeEventHandler(aDOMWin, getter_AddRefs(chromeEventHandler)); +@@ -2385,7 +2385,7 @@ + + + void +-nsTypeAheadFind::GetChromeEventHandler(nsIDOMWindow *aDOMWin, ++nsTypeAheadFindSea::GetChromeEventHandler(nsIDOMWindow *aDOMWin, + nsIDOMEventTarget **aChromeTarget) + { + nsCOMPtr<nsPIDOMWindow> privateDOMWindow(do_QueryInterface(aDOMWin)); +@@ -2401,7 +2401,7 @@ + } + + PRBool +-nsTypeAheadFind::IsTargetContentOkay(nsIContent *aContent) ++nsTypeAheadFindSea::IsTargetContentOkay(nsIContent *aContent) + { + if (!aContent) { + return PR_FALSE; +@@ -2439,7 +2439,7 @@ + + + nsresult +-nsTypeAheadFind::GetTargetIfTypeAheadOkay(nsIDOMEvent *aEvent, ++nsTypeAheadFindSea::GetTargetIfTypeAheadOkay(nsIDOMEvent *aEvent, + nsIContent **aTargetContent, + nsIPresShell **aTargetPresShell) + { +@@ -2522,7 +2522,7 @@ + + + void +-nsTypeAheadFind::GetSelection(nsIPresShell *aPresShell, ++nsTypeAheadFindSea::GetSelection(nsIPresShell *aPresShell, + nsISelectionController **aSelCon, + nsISelection **aDOMSel) + { +@@ -2544,7 +2544,7 @@ + + + PRBool +-nsTypeAheadFind::IsRangeVisible(nsIPresShell *aPresShell, ++nsTypeAheadFindSea::IsRangeVisible(nsIPresShell *aPresShell, + nsPresContext *aPresContext, + nsIDOMRange *aRange, PRBool aMustBeInViewPort, + PRBool aGetTopVisibleLeaf, +@@ -2698,7 +2698,7 @@ + + + nsresult +-nsTypeAheadFind::GetTranslatedString(const nsAString& aKey, ++nsTypeAheadFindSea::GetTranslatedString(const nsAString& aKey, + nsAString& aStringOut) + { + nsXPIDLString xsValue; +@@ -2716,7 +2716,7 @@ + + + void +-nsTypeAheadFind::DisplayStatus(PRBool aSuccess, nsIContent *aFocusedContent, ++nsTypeAheadFindSea::DisplayStatus(PRBool aSuccess, nsIContent *aFocusedContent, + PRBool aClearStatus, const PRUnichar *aText) + { + // pres shell -> pres context -> container -> tree item -> +@@ -2863,7 +2863,7 @@ + // Make sure we're not focused on a text field, listbox + // or other form control that needs typeahead keystrokes + if (focusedContent) { +- *aResult = nsTypeAheadFind::IsTargetContentOkay(focusedContent); ++ *aResult = nsTypeAheadFindSea::IsTargetContentOkay(focusedContent); + return NS_OK; + } + +@@ -2928,8 +2928,8 @@ + EnsureContentWindow(domWinInternal, getter_AddRefs(startContentWin)); + NS_ENSURE_TRUE(startContentWin, NS_ERROR_FAILURE); + +- nsCOMPtr<nsITypeAheadFind> typeAhead = +- do_GetService(NS_TYPEAHEADFIND_CONTRACTID); ++ nsCOMPtr<nsITypeAheadFindSea> typeAhead = ++ do_GetService(NS_TYPEAHEADFINDSEA_CONTRACTID); + NS_ENSURE_TRUE(typeAhead, NS_ERROR_FAILURE); + + return typeAhead->StartNewFind(startContentWin, isLinkSearch); +@@ -3013,7 +3013,7 @@ + } + + already_AddRefed<nsIPresShell> +-nsTypeAheadFind::GetPresShell() ++nsTypeAheadFindSea::GetPresShell() + { + if (!mFocusedWeakShell) + return nsnull; +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFind.h mozilla/extensions/typeaheadfind/src/nsTypeAheadFind.h +--- mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFind.h 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/nsTypeAheadFind.h 2005-03-26 11:39:29.000000000 -0500 +@@ -62,13 +62,13 @@ + #include "nsIDOMRange.h" + #include "nsIDOMWindow.h" + #include "nsIDocShellTreeItem.h" +-#include "nsITypeAheadFind.h" ++#include "nsITypeAheadFindSea.h" + #include "nsIStringBundle.h" + #include "nsISupportsArray.h" + #include "nsISound.h" + +-#define TYPEAHEADFIND_BUNDLE_URL \ +- "chrome://global/locale/typeaheadfind.properties" ++#define TYPEAHEADFINDSEA_BUNDLE_URL \ ++ "chrome://global/locale/typeaheadfindsea.properties" + #define TYPEAHEADFIND_NOTFOUND_WAV_URL \ + "chrome://global/content/notfound.wav" + +@@ -82,7 +82,7 @@ + + const int kMaxBadCharsBeforeCancel = 3; + +-class nsTypeAheadFind : public nsITypeAheadFind, ++class nsTypeAheadFindSea : public nsITypeAheadFindSea, + public nsIDOMKeyListener, + public nsIDOMTextListener, + public nsIDOMCompositionListener, +@@ -93,13 +93,13 @@ + public nsSupportsWeakReference + { + public: +- nsTypeAheadFind(); +- virtual ~nsTypeAheadFind(); ++ nsTypeAheadFindSea(); ++ virtual ~nsTypeAheadFindSea(); + +- NS_DEFINE_STATIC_CID_ACCESSOR(NS_TYPEAHEADFIND_CID); ++ NS_DEFINE_STATIC_CID_ACCESSOR(NS_TYPEAHEADFINDSEA_CID); + + NS_DECL_ISUPPORTS +- NS_DECL_NSITYPEAHEADFIND ++ NS_DECL_NSITYPEAHEADFINDSEA + NS_DECL_NSIOBSERVER + NS_DECL_NSIDOMEVENTLISTENER + NS_DECL_NSISELECTIONLISTENER +@@ -127,7 +127,7 @@ + // ----- nsITimerCallback ----------------------------- + NS_DECL_NSITIMERCALLBACK + +- static nsTypeAheadFind *GetInstance(); ++ static nsTypeAheadFindSea *GetInstance(); + static void ReleaseInstance(void); + static PRBool IsTargetContentOkay(nsIContent *aContent); + +@@ -185,7 +185,7 @@ + nsresult GetTranslatedString(const nsAString& aKey, nsAString& aStringOut); + + // Used by GetInstance and ReleaseInstance +- static nsTypeAheadFind *sInstance; ++ static nsTypeAheadFindSea *sInstance; + + // Current find state + nsString mTypeAheadBuffer; +@@ -196,7 +196,7 @@ + + // PRBool's are used instead of PRPackedBool's where the address of the + // boolean variable is getting passed into a method. For example: +- // GetBoolPref("accessibility.typeaheadfind.linksonly", &mLinksOnlyPref); ++ // GetBoolPref("accessibility.typeaheadfindsea.linksonly", &mLinksOnlyPref); + PRBool mIsFindAllowedInWindow; + PRBool mAutoStartPref; + PRBool mLinksOnlyPref; +@@ -251,7 +251,7 @@ + nsCOMPtr<nsIDOMWindow> mFocusedWindow; + nsCOMPtr<nsIWeakReference> mFocusedWeakShell; + +- // Windows where typeaheadfind doesn't auto start as the user types ++ // Windows where typeaheadfindsea doesn't auto start as the user types + nsCOMPtr<nsISupportsArray> mManualFindWindows; + }; + +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFindRegistration.cpp mozilla/extensions/typeaheadfind/src/nsTypeAheadFindRegistration.cpp +--- mozilla.orig/extensions/typeaheadfind/src/nsTypeAheadFindRegistration.cpp 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/nsTypeAheadFindRegistration.cpp 2005-03-26 11:39:40.000000000 -0500 +@@ -55,7 +55,7 @@ + + // This function is called at component registration time + static NS_METHOD +-nsTypeAheadFindRegistrationProc(nsIComponentManager *aCompMgr, nsIFile *aPath, ++nsTypeAheadFindSeaRegistrationProc(nsIComponentManager *aCompMgr, nsIFile *aPath, + const char *registryLocation, + const char *componentType, + const nsModuleComponentInfo *info) +@@ -64,7 +64,7 @@ + // an application component. This makes sure that we're + // initialized on application startup. + +- // Register nsTypeAheadFind to be instantiated on startup. ++ // Register nsTypeAheadFindSea to be instantiated on startup. + // XXX This is needed on linux, but for some reason not needed on win32. + nsresult rv; + nsCOMPtr<nsICategoryManager> categoryManager = +@@ -74,7 +74,7 @@ + rv = categoryManager->AddCategoryEntry(APPSTARTUP_CATEGORY, +- "Type Ahead Find", ++ "Type Ahead Find Sea", + "service," +- NS_TYPEAHEADFIND_CONTRACTID, ++ NS_TYPEAHEADFINDSEA_CONTRACTID, + PR_TRUE, PR_TRUE, nsnull); + } + +@@ -82,22 +82,22 @@ + } + + +-NS_GENERIC_FACTORY_SINGLETON_CONSTRUCTOR(nsTypeAheadFind, +- nsTypeAheadFind::GetInstance) ++NS_GENERIC_FACTORY_SINGLETON_CONSTRUCTOR(nsTypeAheadFindSea, ++ nsTypeAheadFindSea::GetInstance) + + static void PR_CALLBACK +-TypeAheadFindModuleDtor(nsIModule* self) ++TypeAheadFindSeaModuleDtor(nsIModule* self) + { +- nsTypeAheadFind::ReleaseInstance(); ++ nsTypeAheadFindSea::ReleaseInstance(); + } + + static const nsModuleComponentInfo components[] = + { +- { "TypeAheadFind Component", NS_TYPEAHEADFIND_CID, +- NS_TYPEAHEADFIND_CONTRACTID, nsTypeAheadFindConstructor, +- nsTypeAheadFindRegistrationProc, nsnull // Unregistration proc ++ { "TypeAheadFindSea Component", NS_TYPEAHEADFINDSEA_CID, ++ NS_TYPEAHEADFINDSEA_CONTRACTID, nsTypeAheadFindSeaConstructor, ++ nsTypeAheadFindSeaRegistrationProc, nsnull // Unregistration proc + } + }; + +-NS_IMPL_NSGETMODULE_WITH_DTOR(nsTypeAheadFind, components, +- TypeAheadFindModuleDtor) ++NS_IMPL_NSGETMODULE_WITH_DTOR(nsTypeAheadFindSea, components, ++ TypeAheadFindSeaModuleDtor) +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/typeaheadfind.pkg mozilla/extensions/typeaheadfind/src/typeaheadfind.pkg +--- mozilla.orig/extensions/typeaheadfind/src/typeaheadfind.pkg 2005-03-26 00:12:02.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/typeaheadfind.pkg 1969-12-31 19:00:00.000000000 -0500 +@@ -1,9 +0,0 @@ +-# why not ship this with GRE/embedding, if we're building it? +- +-[xpfe-browser browser] +-#if SHARED_LIBRARY +-dist/bin/components/@SHARED_LIBRARY@ +-#else +-!staticcomp @LIBRARY@ @MODULE_NAME@ +-#endif +-!xpt dist/bin/components/typeaheadfind.xpt +diff -urN --exclude=CVS mozilla.orig/extensions/typeaheadfind/src/typeaheadfindsea.pkg mozilla/extensions/typeaheadfind/src/typeaheadfindsea.pkg +--- mozilla.orig/extensions/typeaheadfind/src/typeaheadfindsea.pkg 1969-12-31 19:00:00.000000000 -0500 ++++ mozilla/extensions/typeaheadfind/src/typeaheadfindsea.pkg 2005-03-26 11:39:29.000000000 -0500 +@@ -0,0 +1,9 @@ ++# why not ship this with GRE/embedding, if we're building it? ++ ++[xpfe-browser browser] ++#if SHARED_LIBRARY ++dist/bin/components/@SHARED_LIBRARY@ ++#else ++!staticcomp @LIBRARY@ @MODULE_NAME@ ++#endif ++!xpt dist/bin/components/typeaheadfindsea.xpt diff --git a/www-client/mozilla-firefox/files/1.5/firefox-cairo-canvas.patch b/www-client/mozilla-firefox/files/1.5/firefox-cairo-canvas.patch new file mode 100644 index 000000000000..fdcb7e7a95b6 --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/firefox-cairo-canvas.patch @@ -0,0 +1,14 @@ +--- content/canvas/src/Makefile.in.orig 2005-08-23 01:46:46.000000000 +0000 ++++ content/canvas/src/Makefile.in 2005-08-23 01:49:49.000000000 +0000 +@@ -77,6 +77,11 @@ + libpixman \ + $(NULL) + ++ifndef MOZ_TREE_CAIRO ++LOCAL_INCLUDES += $(MOZ_CAIRO_CFLAGS) ++EXTRA_DSO_LDOPTS += $(MOZ_CAIRO_LIBS) ++endif ++ + # XXX some platforms can't handle building + # an empty .a/lib. Remove this dummy.cpp + # whenever w have a rendering context diff --git a/www-client/mozilla-firefox/files/1.5/firefox-nopangoxft.patch b/www-client/mozilla-firefox/files/1.5/firefox-nopangoxft.patch new file mode 100644 index 000000000000..608e803a1083 --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/firefox-nopangoxft.patch @@ -0,0 +1,20 @@ +--- mozilla/gfx/src/gtk/mozilla-decoder.cpp.noxft 2005-08-18 22:41:26.000000000 -0400 ++++ mozilla/gfx/src/gtk/mozilla-decoder.cpp 2005-08-18 22:38:01.000000000 -0400 +@@ -40,7 +40,7 @@ + #define PANGO_ENABLE_ENGINE + + #include "mozilla-decoder.h" +-#include <pango/pangoxft.h> ++#include <pango/pangocairo.h> + #include <pango/pangofc-fontmap.h> + #include <pango/pangofc-font.h> + #include <gdk/gdkx.h> +@@ -208,7 +208,7 @@ + } + } + +- pango_fc_font_map_add_decoder_find_func(PANGO_FC_FONT_MAP(pango_xft_get_font_map(GDK_DISPLAY(),gdk_x11_get_default_screen())), ++ pango_fc_font_map_add_decoder_find_func(PANGO_FC_FONT_MAP(pango_cairo_font_map_get_default()), + mozilla_find_decoder, + NULL, + NULL); diff --git a/www-client/mozilla-firefox/files/1.5/firefox-visibility.patch b/www-client/mozilla-firefox/files/1.5/firefox-visibility.patch new file mode 100644 index 000000000000..698c8770770a --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/firefox-visibility.patch @@ -0,0 +1,20 @@ + --- configure 2 Mar 2005 16:57:17 -0000 1.1395 ++++ configure 3 Mar 2005 17:50:31 -0000 +@@ -7042,7 +7042,7 @@ + + fi + +-if test "$GNU_CC"; then ++if /bin/false; then + echo $ac_n "checking for visibility(hidden) attribute""... $ac_c" 1>&6 + echo "configure:7048: checking for visibility(hidden) attribute" >&5 + if eval "test \"`echo '$''{'ac_cv_visibility_hidden'+set}'`\" = set"; then + +diff -u -r1.1.2.1 gcc_hidden.h +--- nsprpub/config/gcc_hidden.h 15 Dec 2004 05:52:39 -0000 1.1.2.1 ++++ nsprpub/config/gcc_hidden.h 3 Mar 2005 17:51:06 -0000 +@@ -1,2 +1,3 @@ +-/* Begin all files as hidden visibility */ ++/* Begin all files as hidden visibility + #pragma GCC visibility push(hidden) ++*/ diff --git a/www-client/mozilla-firefox/files/1.5/mozilla-1.3-alpha-stubs.patch b/www-client/mozilla-firefox/files/1.5/mozilla-1.3-alpha-stubs.patch new file mode 100644 index 000000000000..3aa192be9246 --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/mozilla-1.3-alpha-stubs.patch @@ -0,0 +1,121 @@ +diff -Naur mozilla/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_linux_alpha.cpp mozilla-alpha-stubs/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_linux_alpha.cpp +--- mozilla/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_linux_alpha.cpp 2001-09-28 15:12:51.000000000 -0500 ++++ mozilla-alpha-stubs/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_linux_alpha.cpp 2003-03-18 09:50:06.000000000 -0600 +@@ -20,6 +20,7 @@ + * the Initial Developer. All Rights Reserved. + * + * Contributor(s): ++ * Glen Nakamura <glen@imodulo.com> + * + * Alternatively, the contents of this file may be used under the terms of + * either the GNU General Public License Version 2 or later (the "GPL"), or +@@ -37,8 +38,6 @@ + + /* Platform specific code to invoke XPCOM methods on native objects */ + +-/* contributed by Glen Nakamura <glen.nakamura@usa.net> */ +- + #include "xptcprivate.h" + + /* Prototype specifies unmangled function name and disables unused warning */ +@@ -163,7 +162,11 @@ + "bis $16,$16,$1\n\t" /* load "this" */ + "ldq $2,16($15)\n\t" /* load "methodIndex" */ + "ldq $1,0($1)\n\t" /* load vtable */ ++#if defined(__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100 /* G++ V3 ABI */ ++ "s8addq $2,$31,$2\n\t" /* vtable index = "methodIndex" * 8 */ ++#else /* not G++ V3 ABI */ + "s8addq $2,16,$2\n\t" /* vtable index = "methodIndex" * 8 + 16 */ ++#endif /* G++ V3 ABI */ + "addq $1,$2,$1\n\t" + "ldq $27,0($1)\n\t" /* load address of function */ + "jsr $26,($27),0\n\t" /* call virtual function */ +@@ -176,4 +179,3 @@ + "ret $31,($26),1\n\t" + ".end XPTC_InvokeByIndex" + ); +- +diff -Naur mozilla/xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp mozilla-alpha-stubs/xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp +--- mozilla/xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp 2001-09-28 15:12:52.000000000 -0500 ++++ mozilla-alpha-stubs/xpcom/reflect/xptcall/src/md/unix/xptcstubs_linux_alpha.cpp 2003-03-18 09:50:06.000000000 -0600 +@@ -20,6 +20,7 @@ + * the Initial Developer. All Rights Reserved. + * + * Contributor(s): ++ * Glen Nakamura <glen@imodulo.com> + * + * Alternatively, the contents of this file may be used under the terms of + * either the GNU General Public License Version 2 or later (the "GPL"), or +@@ -37,8 +38,6 @@ + + /* Implement shared vtbl methods. */ + +-/* contributed by Glen Nakamura <glen.nakamura@usa.net> */ +- + #include "xptcprivate.h" + + /* Prototype specifies unmangled function name and disables unused warning */ +@@ -188,23 +187,45 @@ + * nsresult nsXPTCStubBase::Stub##n() + * Sets register $1 to "methodIndex" and jumps to SharedStub. + */ ++#define STUB_MANGLED_ENTRY(n, symbol) \ ++ "#### Stub"#n" ####" "\n\t" \ ++ ".text" "\n\t" \ ++ ".align 5" "\n\t" \ ++ ".globl " symbol "\n\t" \ ++ ".ent " symbol "\n" \ ++symbol ":" "\n\t" \ ++ ".frame $30,0,$26,0" "\n\t" \ ++ "ldgp $29,0($27)" "\n" \ ++"$" symbol "..ng:" "\n\t" \ ++ ".prologue 1" "\n\t" \ ++ "lda $1,"#n "\n\t" \ ++ "br $31,$SharedStub..ng" "\n\t" \ ++ ".end " symbol ++ ++#if defined(__GXX_ABI_VERSION) && __GXX_ABI_VERSION >= 100 /* G++ V3 ABI */ ++ ++#define STUB_ENTRY(n) \ ++__asm__( \ ++ ".if "#n" < 10" "\n\t" \ ++ STUB_MANGLED_ENTRY(n, "_ZN14nsXPTCStubBase5Stub"#n"Ev") "\n\t" \ ++ ".elseif "#n" < 100" "\n\t" \ ++ STUB_MANGLED_ENTRY(n, "_ZN14nsXPTCStubBase6Stub"#n"Ev") "\n\t" \ ++ ".elseif "#n" < 1000" "\n\t" \ ++ STUB_MANGLED_ENTRY(n, "_ZN14nsXPTCStubBase7Stub"#n"Ev") "\n\t" \ ++ ".else" "\n\t" \ ++ ".err \"Stub"#n" >= 1000 not yet supported.\"" "\n\t" \ ++ ".endif" \ ++ ); ++ ++#else /* not G++ V3 ABI */ ++ + #define STUB_ENTRY(n) \ + __asm__( \ +- "#### Stub"#n" ####\n" \ +-".text\n\t" \ +- ".align 5\n\t" \ +- ".globl Stub"#n"__14nsXPTCStubBase\n\t" \ +- ".ent Stub"#n"__14nsXPTCStubBase\n" \ +-"Stub"#n"__14nsXPTCStubBase:\n\t" \ +- ".frame $30,0,$26,0\n\t" \ +- "ldgp $29,0($27)\n" \ +-"$Stub"#n"__14nsXPTCStubBase..ng:\n\t" \ +- ".prologue 1\n\t" \ +- "lda $1,"#n"\n\t" \ +- "br $31,$SharedStub..ng\n\t" \ +- ".end Stub"#n"__14nsXPTCStubBase" \ ++ STUB_MANGLED_ENTRY(n, "Stub"#n"__14nsXPTCStubBase") \ + ); + ++#endif /* G++ V3 ABI */ ++ + #define SENTINEL_ENTRY(n) \ + nsresult nsXPTCStubBase::Sentinel##n() \ + { \ +@@ -213,4 +234,3 @@ + } + + #include "xptcstubsdef.inc" +- diff --git a/www-client/mozilla-firefox/files/1.5/mozilla-firefox-1.1a2-ia64.patch b/www-client/mozilla-firefox/files/1.5/mozilla-firefox-1.1a2-ia64.patch new file mode 100644 index 000000000000..f7d83cecfdf4 --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/mozilla-firefox-1.1a2-ia64.patch @@ -0,0 +1,75 @@ +--- mozilla.orig/extensions/transformiix/source/base/Double.cpp ++++ mozilla/extensions/transformiix/source/base/Double.cpp +@@ -75,14 +75,7 @@ + #define CPU_IS_ARM + #endif + +-#if (__GNUC__ == 2 && __GNUC_MINOR__ > 95) || __GNUC__ > 2 +-/** +- * This version of the macros is safe for the alias optimizations +- * that gcc does, but uses gcc-specific extensions. +- */ +- + typedef union txdpun { +- PRFloat64 d; + struct { + #if defined(IS_LITTLE_ENDIAN) && !defined(CPU_IS_ARM) + PRUint32 lo, hi; +@@ -90,8 +83,14 @@ + PRUint32 hi, lo; + #endif + } s; ++ PRFloat64 d; + } txdpun; + ++#if (__GNUC__ == 2 && __GNUC_MINOR__ > 95) || __GNUC__ > 2 ++/** ++ * This version of the macros is safe for the alias optimizations ++ * that gcc does, but uses gcc-specific extensions. ++ */ + #define TX_DOUBLE_HI32(x) (__extension__ ({ txdpun u; u.d = (x); u.s.hi; })) + #define TX_DOUBLE_LO32(x) (__extension__ ({ txdpun u; u.d = (x); u.s.lo; })) + +@@ -117,20 +116,20 @@ + + //-- Initialize Double related constants + #ifdef IS_BIG_ENDIAN +-const PRUint32 nanMask[2] = {TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_MANTMASK, +- 0xffffffff}; +-const PRUint32 infMask[2] = {TX_DOUBLE_HI32_EXPMASK, 0}; +-const PRUint32 negInfMask[2] = {TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_SIGNBIT, 0}; ++const txdpun nanMask = {TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_MANTMASK, ++ 0xffffffff}; ++const txdpun infMask = {TX_DOUBLE_HI32_EXPMASK, 0}; ++const txdpun negInfMask = {TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_SIGNBIT, 0}; + #else +-const PRUint32 nanMask[2] = {0xffffffff, +- TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_MANTMASK}; +-const PRUint32 infMask[2] = {0, TX_DOUBLE_HI32_EXPMASK}; +-const PRUint32 negInfMask[2] = {0, TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_SIGNBIT}; ++const txdpun nanMask = {0xffffffff, ++ TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_MANTMASK}; ++const txdpun infMask = {0, TX_DOUBLE_HI32_EXPMASK}; ++const txdpun negInfMask = {0, TX_DOUBLE_HI32_EXPMASK | TX_DOUBLE_HI32_SIGNBIT}; + #endif + +-const double Double::NaN = *((double*)nanMask); +-const double Double::POSITIVE_INFINITY = *((double*)infMask); +-const double Double::NEGATIVE_INFINITY = *((double*)negInfMask); ++const double Double::NaN = nanMask.d; ++const double Double::POSITIVE_INFINITY = infMask.d; ++const double Double::NEGATIVE_INFINITY = negInfMask.d; + + /* + * Determines whether the given double represents positive or negative +--- mozilla.orig/js/src/fdlibm/fdlibm.h ++++ mozilla/js/src/fdlibm/fdlibm.h +@@ -61,7 +61,7 @@ + #define __LITTLE_ENDIAN + #endif + +-#if defined(linux) && (defined(__i386__) || defined(__x86_64__) || defined(__ia64)) ++#if defined(linux) && (defined(__i386__) || defined(__x86_64__) || defined(__ia64) || defined(__MIPSEL)) + #define __LITTLE_ENDIAN + #endif + diff --git a/www-client/mozilla-firefox/files/1.5/mozilla-hppa.patch b/www-client/mozilla-firefox/files/1.5/mozilla-hppa.patch new file mode 100644 index 000000000000..d874ae1c4d5c --- /dev/null +++ b/www-client/mozilla-firefox/files/1.5/mozilla-hppa.patch @@ -0,0 +1,232 @@ +diff -uNr mozilla.orig/xpcom/reflect/xptcall/src/md/unix/Makefile.in mozilla/xpcom/reflect/xptcall/src/md/unix/Makefile.in +--- mozilla.orig/xpcom/reflect/xptcall/src/md/unix/Makefile.in 2004-12-21 13:37:00.503842544 +0000 ++++ mozilla/xpcom/reflect/xptcall/src/md/unix/Makefile.in 2004-12-21 13:41:49.439917584 +0000 +@@ -167,6 +167,19 @@ + endif + endif + ++# ++# Linux/HPPA/gcc ++# ++ifeq ($(OS_ARCH),Linux) ++ifneq (,$(filter parisc parisc64,$(OS_TEST))) ++#ifeq ($(CC),gcc) # Do not check for gcc since there is only this compiler on linux for hppa ++CPPSRCS := xptcinvoke_pa32.cpp xptcstubs_pa32.cpp ++ASFILES := xptcstubs_asm_parisc_linux.s xptcinvoke_asm_parisc_linux.s ++#endif ++endif ++endif ++ ++ + ###################################################################### + # M68k + ###################################################################### +diff -uNr mozilla.orig/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_asm_parisc_linux.s mozilla/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_asm_parisc_linux.s +--- mozilla.orig/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_asm_parisc_linux.s 1970-01-01 00:00:00.000000000 +0000 ++++ mozilla/xpcom/reflect/xptcall/src/md/unix/xptcinvoke_asm_parisc_linux.s 2004-12-21 13:39:03.390160984 +0000 +@@ -0,0 +1,128 @@ ++ ++ .LEVEL 1.1 ++ .text ++ .align 4 ++ ++framesz: ++ .equ 128 ++ ++; XPTC_InvokeByIndex(nsISuppots* that, PRUint32 methodIndex, ++; PRUint32 paramCount, nsXPTCVariant* params); ++ ++.globl XPTC_InvokeByIndex ++ .type XPTC_InvokeByIndex, @function ++ ++ ++XPTC_InvokeByIndex: ++ .PROC ++ .CALLINFO FRAME=72, CALLER,SAVE_RP, SAVE_SP, ENTRY_GR=3 ++ .ENTRY ++ ++ ; frame marker takes 48 bytes, ++ ; register spill area takes 8 bytes, ++ ; local stack area takes 72 bytes result in 128 bytes total ++ ++ STW %rp,-20(%sp) ++ STW,MA %r3,128(%sp) ++ ++ LDO -framesz(%r30),%r28 ++ STW %r28,-4(%r30) ; save previous sp ++ STW %r19,-32(%r30) ++ ++ STW %r26,-36-framesz(%r30) ; save argument registers in ++ STW %r25,-40-framesz(%r30) ; in PREVIOUS frame ++ STW %r24,-44-framesz(%r30) ; ++ STW %r23,-48-framesz(%r30) ; ++ ++; B,L .+8,%r2 ++; ADDIL L'invoke_count_bytes-$PIC_pcrel$1+4,%r2,%r1 ++; ; LDO R'invoke_count_bytes-$PIC_pcrel$2+8(%r1),%r1 ++;$PIC_pcrel$1 ++; LDSID (%r1),%r31 ++;$PIC_pcrel$2 ++; MTSP %r31,%sr0 ++ ++ .CALL ARGW0=GR,ARGW1=GR,ARGW2=GR ;in=24,25,26;out=28 ++ BL invoke_count_bytes,%r31 ++ COPY %r31,%r2 ++ ++ CMPIB,>= 0,%r28, .+76 ++ COPY %r30,%r3 ; copy stack ptr to saved stack ptr ++ ADD %r30,%r28,%r30 ; extend stack frame ++ LDW -4(%r3),%r28 ; move frame ++ STW %r28,-4(%r30) ++ LDW -8(%r3),%r28 ++ STW %r28,-8(%r30) ++ LDW -12(%r3),%r28 ++ STW %r28,-12(%r30) ++ LDW -16(%r3),%r28 ++ STW %r28,-16(%r30) ++ LDW -20(%r3),%r28 ++ STW %r28,-20(%r30) ++ LDW -24(%r3),%r28 ++ STW %r28,-24(%r30) ++ LDW -28(%r3),%r28 ++ STW %r28,-28(%r30) ++ LDW -32(%r3),%r28 ++ STW %r28,-32(%r30) ++ ++ LDO -40(%r30),%r26 ; load copy address ++ LDW -44-framesz(%r3),%r25 ; load rest of 2 arguments ++ LDW -48-framesz(%r3),%r24 ; ++ ++ LDW -32(%r30),%r19 ; shared lib call destroys r19; reload ++; B,L .+8,%r2 ++; ADDIL L'invoke_copy_to_stack-$PIC_pcrel$3+4,%r2,%r1 ++; LDO R'invoke_copy_to_stack-$PIC_pcrel$4+8(%r1),%r1 ++;$PIC_pcrel$3 ++; LDSID (%r1),%r31 ++;$PIC_pcrel$4 ++; MTSP %r31,%sr0 ++ .CALL ARGW0=GR,ARGW1=GR,ARGW2=GR ;in=24,25,26 ++ BL invoke_copy_to_stack,%r31 ++ COPY %r31,%r2 ++ ++ LDO -48(%r30),%r20 ++ EXTRW,U,= %r28,31,1,%r22 ++ FLDD 0(%r20),%fr7 ; load double arg 1 ++ EXTRW,U,= %r28,30,1,%r22 ++ FLDW 8(%r20),%fr5L ; load float arg 1 ++ EXTRW,U,= %r28,29,1,%r22 ++ FLDW 4(%r20),%fr6L ; load float arg 2 ++ EXTRW,U,= %r28,28,1,%r22 ++ FLDW 0(%r20),%fr7L ; load float arg 3 ++ ++ LDW -36-framesz(%r3),%r26 ; load ptr to 'that' ++ LDW -40(%r30),%r25 ; load the rest of dispatch argument registers ++ LDW -44(%r30),%r24 ++ LDW -48(%r30),%r23 ++ ++ LDW -36-framesz(%r3),%r20 ; load vtable addr ++ LDW -40-framesz(%r3),%r28 ; load index ++ LDW 0(%r20),%r20 ; follow vtable ++; LDO 0(%r20),%r20 ; offset vtable by 16 bytes (g++: 8, aCC: 16) ++ SH2ADDL %r28,%r20,%r28 ; add 4*index to vtable entry ++ LDW 0(%r28),%r22 ; load vtable entry ++ ++; B,L .+8,%r2 ++; ADDIL L'$$dyncall_external-$PIC_pcrel$5+4,%r2,%r1 ++; LDO R'$$dyncall_external-$PIC_pcrel$6+8(%r1),%r1 ++;$PIC_pcrel$5 ++; LDSID (%r1),%r31 ++;$PIC_pcrel$6 ++; MTSP %r31,%sr0 ++ .CALL ARGW0=GR,ARGW1=GR,ARGW2=GR,ARGW3=GR,RTNVAL=GR ;in=22-26;out=28; ++ BL $$dyncall,%r31 ++ COPY %r31,%r2 ++ ++ LDW -32(%r30),%r19 ++ COPY %r3,%r30 ; restore saved stack ptr ++ ++ LDW -148(%sp),%rp ++ LDWM -128(%sp),%r3 ++ BV,N (%rp) ++ NOP ++ .EXIT ++ .PROCEND ;in=23,24,25,26; ++ .SIZE XPTC_InvokeByIndex, .-XPTC_InvokeByIndex ++ +diff -uNr mozilla.orig/xpcom/reflect/xptcall/src/md/unix/xptcstubs_asm_parisc_linux.s mozilla/xpcom/reflect/xptcall/src/md/unix/xptcstubs_asm_parisc_linux.s +--- mozilla.orig/xpcom/reflect/xptcall/src/md/unix/xptcstubs_asm_parisc_linux.s 1970-01-01 00:00:00.000000000 +0000 ++++ mozilla/xpcom/reflect/xptcall/src/md/unix/xptcstubs_asm_parisc_linux.s 2004-12-21 13:39:03.392160680 +0000 +@@ -0,0 +1,73 @@ ++ .LEVEL 1.1 ++ .TEXT ++ .ALIGN 4 ++ ++curframesz: ++ .EQU 128 ++ ++ ++; SharedStub has stack size of 128 bytes ++ ++lastframesz: ++ .EQU 64 ++ ++; the StubN C++ function has a small stack size of 64 bytes ++ ++ ++.globl SharedStub ++ .type SharedStub, @function ++ ++SharedStub: ++ .PROC ++ .CALLINFO CALLER,FRAME=80,SAVE_RP ++ ++ .ENTRY ++ STW %rp,-20(%sp) ++ LDO 128(%sp),%sp ++ ++ STW %r19,-32(%r30) ++ STW %r26,-36-curframesz(%r30) ; save arg0 in previous frame ++ ++ LDO -80(%r30),%r28 ++ FSTD,MA %fr5,8(%r28) ; save darg0 ++ FSTD,MA %fr7,8(%r28) ; save darg1 ++ FSTW,MA %fr4L,4(%r28) ; save farg0 ++ FSTW,MA %fr5L,4(%r28) ; save farg1 ++ FSTW,MA %fr6L,4(%r28) ; save farg2 ++ FSTW,MA %fr7L,4(%r28) ; save farg3 ++ ++ ; Former value of register 26 is already properly saved by StubN, ++ ; but register 25-23 are not because of the arguments mismatch ++ STW %r25,-40-curframesz-lastframesz(%r30) ; save r25 ++ STW %r24,-44-curframesz-lastframesz(%r30) ; save r24 ++ STW %r23,-48-curframesz-lastframesz(%r30) ; save r23 ++ COPY %r26,%r25 ; method index is arg1 ++ LDW -36-curframesz-lastframesz(%r30),%r26 ; self is arg0 ++ LDO -40-curframesz-lastframesz(%r30),%r24 ; normal args is arg2 ++ LDO -80(%r30),%r23 ; floating args is arg3 ++ ++; BL .+8,%r2 ++; ADDIL L'PrepareAndDispatch-$PIC_pcrel$0+4,%r2 ++; LDO R'PrepareAndDispatch-$PIC_pcrel$1+8(%r1),%r1 ++;$PIC_pcrel$0 ++; LDSID (%r1),%r31 ++;$PIC_pcrel$1 ++; MTSP %r31,%sr0 ++ .CALL ARGW0=GR,ARGW1=GR,ARGW2=GR,ARGW3=GR,RTNVAL=GR ;in=23-26;out=28; ++ BL PrepareAndDispatch, %r31 ++ COPY %r31,%r2 ++ ++ LDW -32(%r30),%r19 ++ ++ LDW -148(%sp),%rp ++ LDO -128(%sp),%sp ++ ++ ++ BV,N (%rp) ++ NOP ++ NOP ++ ++ .EXIT ++ .PROCEND ;in=26;out=28; ++ ++ .SIZE SharedStub, .-SharedStub diff --git a/www-client/mozilla-firefox/files/digest-mozilla-firefox-1.5_beta2-r1 b/www-client/mozilla-firefox/files/digest-mozilla-firefox-1.5_beta2-r1 new file mode 100644 index 000000000000..b6191c90cf1a --- /dev/null +++ b/www-client/mozilla-firefox/files/digest-mozilla-firefox-1.5_beta2-r1 @@ -0,0 +1,2 @@ +MD5 08eb51cbab8050ebfd3d53e6592fc0f0 firefox-1.5b2-source.tar.bz2 34329054 +MD5 7960994910bda4c14a52bc119f9ceefc mozilla-jslibmath-alpha.patch 625 diff --git a/www-client/mozilla-firefox/files/gentoo-default-prefs.js b/www-client/mozilla-firefox/files/gentoo-default-prefs.js new file mode 100644 index 000000000000..47cfb37d3c38 --- /dev/null +++ b/www-client/mozilla-firefox/files/gentoo-default-prefs.js @@ -0,0 +1,7 @@ +pref("app.update.enabled", false); +pref("app.update.autoInstallEnabled", false); +pref("browser.display.use_system_colors", true); +pref("browser.link.open_external", 3); +pref("general.smoothScroll", true); +pref("general.autoScroll", true); + diff --git a/www-client/mozilla-firefox/files/icon/deerpark-icon.png b/www-client/mozilla-firefox/files/icon/deerpark-icon.png Binary files differnew file mode 100644 index 000000000000..67e1e8ab902d --- /dev/null +++ b/www-client/mozilla-firefox/files/icon/deerpark-icon.png diff --git a/www-client/mozilla-firefox/files/icon/mozillafirefox.desktop b/www-client/mozilla-firefox/files/icon/mozillafirefox.desktop index 7c161483d0c1..3d0df9095380 100644 --- a/www-client/mozilla-firefox/files/icon/mozillafirefox.desktop +++ b/www-client/mozilla-firefox/files/icon/mozillafirefox.desktop @@ -1,13 +1,8 @@ [Desktop Entry] -Version=1.0 -Encoding=UTF-8 Name=Mozilla Firefox -GenericName=Web Browser -Comment=Browse the Web +Comment=Web Browser Exec=/usr/bin/firefox %U -Icon=firefox-icon.png +Icon=deerpark-icon.png Terminal=false Type=Application -StartupWMClass=Firefox-bin -MimeType=text/html;text/xml;application/xhtml+xml;application/vnd.mozilla.xul+xml;text/mml; Categories=Application;Network; diff --git a/www-client/mozilla-firefox/mozilla-firefox-1.5_beta2-r1.ebuild b/www-client/mozilla-firefox/mozilla-firefox-1.5_beta2-r1.ebuild new file mode 100644 index 000000000000..abb7df58257a --- /dev/null +++ b/www-client/mozilla-firefox/mozilla-firefox-1.5_beta2-r1.ebuild @@ -0,0 +1,281 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/www-client/mozilla-firefox/mozilla-firefox-1.5_beta2-r1.ebuild,v 1.1 2005/10/13 19:21:46 anarchy Exp $ + +unset ALLOWED_FLAGS # stupid extra-functions.sh ... bug 49179 +MOZ_FREETYPE2="no" # Need to disable for newer .. remove here and in mozconfig + # when older is removed from tree. +MOZ_PANGO="yes" # Need to enable for newer .. remove here and in mozconfig + # when older is removed from tree. + +inherit flag-o-matic toolchain-funcs eutils mozconfig mozilla-launcher makeedit multilib fdo-mime versionator + +MY_P="$(replace_version_separator 2 '')" +FV=${MY_P/beta/b} + +DESCRIPTION="Firefox Web Browser" +HOMEPAGE="http://www.mozilla.org/projects/firefox/" +SRC_URI="http://ftp.mozilla.org/pub/mozilla.org/firefox/releases/${FV}/source/firefox-${FV}-source.tar.bz2 + mirror://gentoo/mozilla-jslibmath-alpha.patch" + +KEYWORDS="-*" +SLOT="0" +LICENSE="MPL-1.1 NPL-1.1" +IUSE="java mozdevelop" + +RDEPEND="java? ( virtual/jre ) + >=www-client/mozilla-launcher-1.39" + +DEPEND="${RDEPEND} + java? ( >=dev-java/java-config-0.2.0 )" + +S=${WORKDIR}/mozilla + +# Needed by src_compile() and src_install(). +# Would do in pkg_setup but that loses the export attribute, they +# become pure shell variables. +export MOZ_CO_PROJECT=browser +export BUILD_OFFICIAL=1 +export MOZILLA_OFFICIAL=1 + +src_unpack() { + unpack firefox-${FV}-source.tar.bz2 + cd ${S} || die "cd failed" + + #################################### + # + # architecture patches + # + #################################### + + # alpha stubs patch from lfs project. + # <taviso@gentoo.org> (26 Jun 2003) + use alpha && epatch ${FILESDIR}/1.5/mozilla-1.3-alpha-stubs.patch + + # amd64 visibility patch + if [[ ${ARCH} == amd64 ]] && [[ $(gcc-major-version) -eq 3 ]]; then + epatch ${FILESDIR}/1.5/firefox-visibility.patch + fi + + # hppa patches from Ivar <orskaug@stud.ntnu.no> + # <gmsoft@gentoo.org> (22 Dec 2004) + epatch ${FILESDIR}/1.5/mozilla-hppa.patch + + # patch to solve segfaults on ia64, from Debian, originally from David + # Mosberger + epatch ${FILESDIR}/1.5/mozilla-firefox-1.1a2-ia64.patch + + # patch to fix math operations on alpha, makes maps.google.com work! + epatch ${DISTDIR}/mozilla-jslibmath-alpha.patch + + #################################### + # + # general compilation and run-time fixes + # + #################################### + + # patch from fedora to remove the pangoxft things + epatch ${FILESDIR}/1.5/firefox-nopangoxft.patch + #cairo-canvas patch + epatch ${FILESDIR}/1.5/firefox-cairo-canvas.patch + + #################################### + # + # behavioral fixes + # + #################################### + + # patch to fix typeahead find for browsers which embed Firefox + # http://bugzilla.gnome.org/show_bug.cgi?id=157435 + epatch ${FILESDIR}/1.5/embed-typeaheadfind.patch + + # Fix scripts that call for /usr/local/bin/perl #51916 + ebegin "Patching smime to call perl from /usr/bin" + sed -i -e '1s,usr/local/bin,usr/bin,' ${S}/security/nss/cmd/smimetools/smime + eend $? || die "sed failed" +} + +src_compile() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + #################################### + # + # mozconfig, CFLAGS and CXXFLAGS setup + # + #################################### + + mozconfig_init + + mozconfig_annotate '' --enable-extensions=default,typeaheadfind + mozconfig_annotate '' --disable-mailnews + #mozconfig_annotate '' --enable-native-uconv + mozconfig_annotate '' --enable-image-encoder=all + + # Bug 60668: Galeon doesn't build without oji enabled, so enable it + # regardless of java setting. + mozconfig_annotate '' --enable-oji --enable-mathml + + # Other ff-specific settings + mozconfig_use_enable mozdevelop jsd + mozconfig_use_enable mozdevelop xpctools + mozconfig_use_extension mozdevelop venkman + mozconfig_annotate '' --with-default-mozilla-five-home=${MOZILLA_FIVE_HOME} + + # Finalize and report settings + mozconfig_final + + # hardened GCC uses -fstack-protector-all by default, which breaks us + has_hardened && append-flags -fno-stack-protector-all + # remove -fstack-protector because now it borks firefox + CFLAGS=${CFLAGS/-fstack-protector-all/} + CFLAGS=${CFLAGS/-fstack-protector/} + CXXFLAGS=${CXXFLAGS/-fstack-protector-all/} + CXXFLAGS=${CXXFLAGS/-fstack-protector/} + + #################################### + # + # Configure and build + # + #################################### + + CPPFLAGS="${CPPFLAGS} -DARON_WAS_HERE" \ + CC="$(tc-getCC)" CXX="$(tc-getCXX)" LD="$(tc-getLD)" \ + econf || die + + # It would be great if we could pass these in via CPPFLAGS or CFLAGS prior + # to econf, but the quotes cause configure to fail. + sed -i -e \ + 's|-DARON_WAS_HERE|-DGENTOO_NSPLUGINS_DIR=\\\"/usr/'"$(get_libdir)"'/nsplugins\\\" -DGENTOO_NSBROWSER_PLUGINS_DIR=\\\"/usr/'"$(get_libdir)"'/nsbrowser/plugins\\\"|' \ + ${S}/config/autoconf.mk \ + ${S}/nsprpub/config/autoconf.mk \ + ${S}/xpfe/global/buildconfig.html + + # Fixup the RPATH + sed -i -e \ + 's|#RPATH_FIXER|'"${MOZILLA_FIVE_HOME}"'|' \ + ${S}/config/rules.mk \ + ${S}/nsprpub/config/rules.mk \ + ${S}/security/coreconf/rules.mk \ + ${S}/security/coreconf/rules.mk + + # This removes extraneous CFLAGS from the Makefiles to reduce RAM + # requirements while compiling + edit_makefiles + + emake || die +} + +src_install() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + # Most of the installation happens here + dodir ${MOZILLA_FIVE_HOME} + cp -RL ${S}/dist/bin/* ${D}${MOZILLA_FIVE_HOME} + + # Create directory structure to support portage-installed extensions. + # See update_chrome() in mozilla-launcher + keepdir ${MOZILLA_FIVE_HOME}/chrome.d + keepdir ${MOZILLA_FIVE_HOME}/extensions.d + cp ${D}${MOZILLA_FIVE_HOME}/chrome/installed-chrome.txt \ + ${D}${MOZILLA_FIVE_HOME}/chrome.d/0_base-chrome.txt + + # Create /usr/bin/firefox + install_mozilla_launcher_stub firefox ${MOZILLA_FIVE_HOME} + + # Install icon and .desktop for menu entry + insinto /usr/share/pixmaps + doins ${FILESDIR}/icon/deerpark-icon.png + + # Fix bug 54179: Install .desktop file into /usr/share/applications + # instead of /usr/share/gnome/apps/Internet (18 Jun 2004 agriffis) + insinto /usr/share/applications + doins ${FILESDIR}/icon/mozillafirefox.desktop + + #################################### + # + # Install files necessary for applications to build against firefox + # + #################################### + + einfo "Installing includes and idl files..." + dodir ${MOZILLA_FIVE_HOME}/idl ${MOZILLA_FIVE_HOME}/include + cd ${S}/dist + cp -LfR include/* ${D}${MOZILLA_FIVE_HOME}/include || die "failed to copy" + cp -LfR idl/* ${D}${MOZILLA_FIVE_HOME}/idl || die "failed to copy" + + # Dirty hack to get some applications using this header running + dosym ${MOZILLA_FIVE_HOME}/include/necko/nsIURI.h \ + /usr/$(get_libdir)/${MOZILLA_FIVE_HOME##*/}/include/nsIURI.h + + # Fix firefox-config and install it + sed -i -e "s|/usr/lib/firefox-${MY_PV}|${MOZILLA_FIVE_HOME}|g + s|/usr/include/firefox-${MY_PV}|${MOZILLA_FIVE_HOME}/include|g + s|/usr/share/idl/firefox-${MY_PV}|${MOZILLA_FIVE_HOME}/idl|g + s|\(echo -L.*\)\($\)|\1 -Wl,-R${MOZILLA_FIVE_HOME}\2|" \ + ${S}/build/unix/firefox-config + exeinto ${MOZILLA_FIVE_HOME} + doexe ${S}/build/unix/firefox-config + + # Fix pkgconfig files and install them + sed -i -e "s|-L/usr/lib/firefox-${MY_PV}|-L\$\{libdir\}| + s|-I/usr/include/firefox-${MY_PV}|-I\$\{includedir\}|" \ + ${S}/build/unix/firefox-nspr.pc + insinto /usr/$(get_libdir)/pkgconfig + for x in ${S}/build/unix/*.pc; do + sed -i -e "s|^libdir=.*|libdir=${MOZILLA_FIVE_HOME}| + s|^includedir=.*|includedir=${MOZILLA_FIVE_HOME}/include| + s|^idldir=.*|idldir=${MOZILLA_FIVE_HOME}/idl| + s|\(^Libs: -L.*\)\($\)|\1 -Wl,-R\$\{libdir\}\2|" ${x} + doins ${x} + done + + #################################### + # + # Some preferences, probably gentoo.org as start-page also + # + #################################### + + dodir ${D}/${MOZILLA_FIVE_HOME}/greprefs + cp ${FILESDIR}/gentoo-default-prefs.js ${D}/${MOZILLA_FIVE_HOME}/greprefs/all-gentoo.js + dodir ${D}/${MOZILLA_FIVE_HOME}/defaults/pref + cp ${FILESDIR}/gentoo-default-prefs.js ${D}/${MOZILLA_FIVE_HOME}/defaults/pref/all-gentoo.js + + # Install docs + dodoc LEGAL LICENSE +} + +pkg_postinst() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + #################################### + # + # The registration is done here, + # mozilla-launcher do not do it correctly for now + # + #################################### + + touch ${MOZILLA_FIVE_HOME}/components/compreg.dat + touch ${MOZILLA_FIVE_HOME}/components/xpti.dat + [ -x ${MOZILLA_FIVE_HOME}/firefox ] && ${MOZILLA_FIVE_HOME}/firefox -register + [ -x ${MOZILLA_FIVE_HOME}/regxpcom ] && ${MOZILLA_FIVE_HOME}/regxpcom + + # This should be called in the postinst and postrm of all the + # mozilla, mozilla-bin, firefox, firefox-bin, thunderbird and + # thunderbird-bin ebuilds. + update_mozilla_launcher_symlinks +} + +pkg_postrm() { + declare MOZILLA_FIVE_HOME=/usr/$(get_libdir)/${PN} + + #################################### + # + # The registration is done here, + # mozilla-launcher do not do it correctly for now + # + #################################### + + [ -x ${MOZILLA_FIVE_HOME}/firefox ] && ${MOZILLA_FIVE_HOME}/firefox -register + [ -x ${MOZILLA_FIVE_HOME}/regxpcom ] && ${MOZILLA_FIVE_HOME}/regxpcom + update_mozilla_launcher_symlinks +} |