commit:     ee81f36292d2116e67467a336df2bf706fe2b716
Author:     Myckel Habets <myckel <AT> sdf <DOT> org>
AuthorDate: Thu Jan 27 15:50:45 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 29 05:49:00 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ee81f362

www-client/seamonkey: add 2.53.10.2

Bug: https://bugs.gentoo.org/828479
Closes: https://bugs.gentoo.org/824066
Closes: https://bugs.gentoo.org/831977
Signed-off-by: Myckel Habets <gentoo-bugs <AT> habets-dobben.nl>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 www-client/seamonkey/Manifest                      |   4 +
 .../files/seamonkey-2.53.10.2-ownertab.patch       | 249 +++++++++
 www-client/seamonkey/seamonkey-2.53.10.2.ebuild    | 557 +++++++++++++++++++++
 3 files changed, 810 insertions(+)

diff --git a/www-client/seamonkey/Manifest b/www-client/seamonkey/Manifest
index 558ad9359458..b6ef41e0a942 100644
--- a/www-client/seamonkey/Manifest
+++ b/www-client/seamonkey/Manifest
@@ -1,3 +1,7 @@
+DIST seamonkey-2.53.10.2-patches-01.tar.gz 77910 BLAKE2B 
9f75470936c15a6c6be27a4751f0ed32dbd7629017b1f142250ef80ecf1adfc6fc7d88c3d1e4a44efaee93b9e15d0171910582ac4a7abcae65fa26bdb6950469
 SHA512 
ddb0984aaa5e16ced69dad59bb812fbc3ba14c3de96edfea8778ff5450f4f520657031470b80492226fc273fedb7195361c9f56352a53d381061a1171e830d5b
+DIST seamonkey-2.53.10.2.source-l10n.tar.xz 13616204 BLAKE2B 
75e3efd51fa4628b3853c2fc86357d1a44addd11ea5409ee10fcce5114fb2a92a9f70af24e3e5fb955a15f8568149cd4c7af67a321716313ad71c474a3caeb2a
 SHA512 
9796ac45203e91d1531ed88239ff8771cd666027a1dbf41885b3626ec03e4289854704cac53a56a68f3df9dd82232321cafde24b5f1c49b22722812bf8781a36
+DIST seamonkey-2.53.10.2.source.tar.xz 284350364 BLAKE2B 
15ff60b5728b84c00831d4dccde7600648889d56ecbe034708390cd83d096f760157d84f5df266ede2d4388302b0df83684397c276e1a0f6d1dfe3e799265ca1
 SHA512 
59233c2bfc0cf3c9e290e1165fea4cd285cabb339f66dbad7bdbe0b7fd9b2acbc37c385b775d2a3d045d1a6648012488cc018eb3f879139c2a582e7d37e01d7a
+DIST seamonkey-2.53.3-system_libvpx-1.8.patch.gz 3197 BLAKE2B 
7a84d2184f4812eabfe3626eb6b2364f2f8c0ba24d4e53440e9d38658b89a3f1c23bdcbd623fd9aca3bfd04743e582587e9c42ba3d983cc9ec4059ea9503830a
 SHA512 
ffc6f179f07cb9dcce2924c64bfed84a5cc724d857b32e5e349967e72022536c5192c3966e1089bab8efd91671584d6474334730ebefe1c4398f564a5f1753be
 DIST seamonkey-2.53.3-system_libvpx-1.8.patch.xz 3128 BLAKE2B 
f73802d2715a11964a4b4d34b582a2999ab42cff9ed005c5ca8c002ae745a973fbb682c3e568f6727a7fe93dc2d7a5ba3367adc4e1d256b8ab0cf8d940fceb8a
 SHA512 
80b87c260445af181d1a0d39de9f95ac7c93f76e12328c1799e8607f50ca9e2a20bc4f15de3f32efbbabb444fd5352612b2629fee61875fa0acd6d050df338a2
 DIST seamonkey-2.53.8.1-rust-1.45.0.patch.xz 12256 BLAKE2B 
b311b69ee11a5875beca421b45733e6cd9b0aaa7c00a51e4fdda3e6ecabdef70b683c119a63e404c5763b19b9c6720cc59c0e6033eb2b06b0e97e7f01a8b727d
 SHA512 
1056602044c719da26cf54566ac058a84258c5639a9d717904e97e38323f69100fb5183464602147744fd657aaef322f7fd130773b85896a15c5466a8a3f1e2e
 DIST seamonkey-2.53.8.1.source-l10n.tar.xz 13542220 BLAKE2B 
8b043136595e481077e60cf202ae66d04ad30f089e842f6d4660807cdaf086b99c9252afccf8a6302558f4a1ce38e8e59f72ade6f72929335b0bf7bce72b4569
 SHA512 
047defbfac18f360ad089d90de3c0e139d3707dcfa74570fcfa1f2f1e789ca2930d08ee0c94f7d88cc79f4e162eda2d0073493656528e0f9b579f452fe13ad8f

diff --git a/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch 
b/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch
new file mode 100644
index 000000000000..02140bd5e8f7
--- /dev/null
+++ b/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch
@@ -0,0 +1,249 @@
+# HG changeset patch
+# User Dmitry Butskoy <[email protected]>
+# Date 1628960364 -7200
+# Parent  45d5ea1452b1c406303ff3be289df08cde3d5a04
+Bug 1623054 - Set owner tab for proper tab focus handling after close. r=IanN 
a=IanN
+Upstream bug-report: https://bugzilla.mozilla.org/show_bug.cgi?id=1623054
+
+diff --git seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js 
seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
+--- seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
++++ seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
+@@ -224,16 +224,17 @@ pref("browser.tabs.autoHide", false);
+ pref("browser.tabs.forceHide", false);
+ pref("browser.tabs.closeWindowWithLastTab", true);
+ pref("browser.tabs.warnOnClose", true);
+ pref("browser.tabs.warnOnCloseOther", true);
+ pref("browser.tabs.warnOnOpen", true);
+ pref("browser.tabs.maxOpenBeforeWarn", 15);
+ pref("browser.tabs.insertRelatedAfterCurrent", true);
+ pref("browser.tabs.insertAllTabsAfterCurrent", false);
++pref("browser.tabs.selectOwnerOnClose", true);
+ pref("browser.tabs.avoidBrowserFocus", false);
+ 
+ // For future use
+ pref("browser.tabs.loadBookmarksInBackground", false);
+ 
+ // how many browsers can be saved in the DOM (by the tabbed browser)
+ pref("browser.tabs.max_tabs_undo", 3);
+ // should popups by saved in the DOM (by the tabbed browser)
+diff --git seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js 
seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
+--- seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
++++ seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
+@@ -1637,16 +1637,17 @@ function openLinkIn(url, where, params)
+     // fall through
+   case "tab":
+     var browser = w.getBrowser();
+     var tab = browser.addTab(url, {
+                 referrerURI: aReferrerURI,
+                 referrerPolicy: aReferrerPolicy,
+                 charset: aCharset,
+                 postData: aPostData,
++                ownerTab: loadInBackground ? null : browser.selectedTab,
+                 allowThirdPartyFixup: aAllowThirdPartyFixup,
+                 relatedToCurrent: aRelatedToCurrent,
+                 allowMixedContent: aAllowMixedContent,
+                 noReferrer: aNoReferrer,
+                 userContextId: aUserContextId,
+                 originPrincipal: aPrincipal,
+                 triggeringPrincipal: aTriggeringPrincipal,
+               });
+diff --git seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml 
seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
+--- seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
++++ seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
+@@ -1152,16 +1152,27 @@
+             newBrowser.docShellIsActive = 
this.mCurrentTab.linkedBrowser.docShellIsActive;
+             if (this.mCurrentBrowser) {
+               this.mCurrentBrowser.droppedLinkHandler = null;
+               this.mCurrentBrowser.docShellIsActive = false;
+               this.mCurrentBrowser.removeAttribute("primary");
+               this.finder.mListeners.forEach(l => 
this.mCurrentBrowser.finder.removeResultListener(l));
+             }
+ 
++            let oldTab = this.mCurrentTab;
++
++            // Preview mode should not reset the owner.
++            if (!this._previewMode && !oldTab.selected)
++              oldTab.owner = null;
++
++            let lastRelatedTab = this.mLastRelatedIndex ? 
this.tabs[this.mLastRelatedIndex] : null;
++            if (lastRelatedTab && !lastRelatedTab.selected) {
++              lastRelatedTab.owner = null;
++            }
++
+             newBrowser.setAttribute("primary", "true");
+             this.mCurrentBrowser = newBrowser;
+             this.mCurrentTab = this.selectedTab;
+             this.mCurrentTab.removeAttribute("unread");
+             this.finder.mListeners.forEach(l => 
this.mCurrentBrowser.finder.addResultListener(l));
+ 
+             var tabListener = 
this.mTabListeners[this.tabContainer.selectedIndex];
+ 
+@@ -1445,16 +1456,19 @@
+                 opener: null,
+               };
+             }
+ 
+             params.focusNewTab = params.inBackground != null ?
+                 !params.inBackground :
+                 !Services.prefs.getBoolPref("browser.tabs.loadInBackground");
+ 
++            if (params.focusNewTab)
++              params.ownerTab = this.selectedTab;
++
+             return this.addTab(aURI, params);
+          ]]>
+         </body>
+       </method>
+ 
+       <method name="loadTabs">
+         <parameter name="aURIs"/>
+         <parameter name="aLoadInBackground"/>
+@@ -1556,43 +1570,49 @@
+         <parameter name="aPostData"/>
+         <parameter name="aFocusNewTab"/>
+         <parameter name="aAllowThirdPartyFixup"/>
+         <body>
+           <![CDATA[
+             var aTriggeringPrincipal;
+             var aReferrerPolicy;
+             var aFromExternal;
++            var aOwner;
+             var aRelatedToCurrent;
+             var aAllowMixedContent;
+             var aNoReferrer;
+             var aUserContextId;
+             var aOriginPrincipal;
+             var aOpener;
+             if (arguments.length == 2 &&
+                 arguments[1] != null &&
+                 typeof arguments[1] == "object" &&
+                 !(arguments[1] instanceof Ci.nsIURI)) {
+               let params = arguments[1];
+               aTriggeringPrincipal  = params.triggeringPrincipal;
+               aReferrerURI          = params.referrerURI;
+               aReferrerPolicy       = params.referrerPolicy;
+               aCharset              = params.charset;
+               aPostData             = params.postData;
++              aOwner                = params.ownerTab;
+               aFocusNewTab          = params.focusNewTab;
+               aAllowThirdPartyFixup = params.allowThirdPartyFixup;
+               aFromExternal         = params.fromExternal;
+               aRelatedToCurrent     = params.relatedToCurrent;
+               aAllowMixedContent    = params.allowMixedContent;
+               aNoReferrer           = params.noReferrer;
+               aUserContextId        = params.userContextId;
+               aOriginPrincipal      = params.originPrincipal;
+               aOpener               = params.opener;
+             }
+ 
++            // If we're adding tabs, we're past interrupt mode, ditch the 
owner.
++            if (this.mCurrentTab.owner)
++              this.mCurrentTab.owner = null;
++
+             this._browsers = null; // invalidate cache
+ 
+             var t = this.referenceTab.cloneNode(true);
+ 
+             var blank = !aURI || aURI == "about:blank";
+ 
+             if (!blank)
+               t.setAttribute("label", aURI);
+@@ -1650,16 +1670,20 @@
+ 
+             // We start our browsers out as inactive.
+             b.docShellIsActive = false;
+ 
+             this.mStrip.collapsed = false;
+ 
+             Services.prefs.setBoolPref("browser.tabs.forceHide", false);
+ 
++            // If this new tab is owned by another, assert that relationship.
++            if (aOwner)
++              t.owner = aOwner;
++
+             // wire up a progress listener for the new browser object.
+             var position = this.tabs.length - 1;
+             var tabListener = this.mTabProgressListener(t, b, blank);
+             const filter = 
Cc["@mozilla.org/appshell/component/browser-status-filter;1"]
+                              .createInstance(Ci.nsIWebProgress);
+             filter.addProgressListener(tabListener, 
Ci.nsIWebProgress.NOTIFY_ALL);
+             b.webProgress.addProgressListener(filter, 
Ci.nsIWebProgress.NOTIFY_ALL);
+             this.mTabListeners[position] = tabListener;
+@@ -1699,16 +1723,20 @@
+             // aReferrerURI is null or undefined if the tab is opened from
+             // an external application or bookmark, i.e. somewhere other
+             // than the current tab.
+             if ((aRelatedToCurrent || aReferrerURI ||
+                  
Services.prefs.getBoolPref("browser.tabs.insertAllTabsAfterCurrent")) &&
+                 
Services.prefs.getBoolPref("browser.tabs.insertRelatedAfterCurrent")) {
+               var lastRelatedIndex = this.mLastRelatedIndex ||
+                                      this.tabContainer.selectedIndex;
++              if (this.mLastRelatedIndex)
++                this.tabs[this.mLastRelatedIndex].owner = null;
++              else
++                t.owner = this.selectedTab;
+               this.moveTabTo(t, ++lastRelatedIndex);
+               this.mLastRelatedIndex = lastRelatedIndex;
+             }
+ 
+             if (aFocusNewTab) {
+               var parentTab = this.selectedTab;
+               this.selectedTab = t;
+               this.mPreviousTab = parentTab;
+@@ -2037,16 +2065,23 @@
+             oldBrowser.webProgress.removeProgressListener(filter);
+             filter.removeProgressListener(this.mTabListeners[index]);
+             this.mTabFilters.splice(index, 1);
+             this.mTabListeners.splice(index, 1);
+ 
+             // We are no longer the primary content area
+             oldBrowser.removeAttribute("primary");
+ 
++            // Remove this tab as the owner of any other tabs, since it's 
going away.
++            for (let tab of this.tabs) {
++              if ("owner" in tab && tab.owner == aTab)
++                // |tab| is a child of the tab we're removing, make it an 
orphan.
++                tab.owner = null;
++            }
++
+             // Now select the new tab before nuking the old one.
+             var currentIndex = this.tabContainer.selectedIndex;
+ 
+             var newIndex = -1;
+             if (currentIndex > index)
+               newIndex = currentIndex - 1;
+             else if (currentIndex < index)
+               newIndex = currentIndex;
+@@ -2057,23 +2092,30 @@
+ 
+             if (oldBrowser == this.mCurrentBrowser)
+               this.mCurrentBrowser = null;
+ 
+             // Invalidate browsers cache, as the tab is removed from the
+             // tab container.
+             this._browsers = null;
+ 
+-            // Clean up before/afterselected attributes before removing the 
tab
++            let owner = ("owner" in aTab) ? aTab.owner : null;
++
++            // Clean up before/after selected attributes before removing the
++            // tab.
+             aTab._selected = false;
+             aTab.remove();
+ 
+             // When the current tab is removed select a new tab
+             // and fire select events on tabpanels and tabs
+-            if (this.mPreviousTab && (aTab == this.mCurrentTab))
++            if (owner && !owner.hidden && !owner.closing &&
++                
Services.prefs.getBoolPref("browser.tabs.selectOwnerOnClose")) {
++              this.selectedTab = owner;
++            }
++            else if (this.mPreviousTab && (aTab == this.mCurrentTab))
+               this.selectedTab = this.mPreviousTab;
+             else {
+               this.tabContainer.selectedIndex = newIndex;
+ 
+               // We need to explicitly clear this, because 
updateCurrentBrowser
+               // doesn't get called for a background tab
+               this.mPreviousTab = null;
+             }

diff --git a/www-client/seamonkey/seamonkey-2.53.10.2.ebuild 
b/www-client/seamonkey/seamonkey-2.53.10.2.ebuild
new file mode 100644
index 000000000000..d79808ae9be3
--- /dev/null
+++ b/www-client/seamonkey/seamonkey-2.53.10.2.ebuild
@@ -0,0 +1,557 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+WANT_AUTOCONF="2.1"
+
+PYTHON_COMPAT=( python3_{7..9} )
+PYTHON_REQ_USE='ncurses,sqlite,ssl,threads(+)'
+
+# This list can be updated with scripts/get_langs.sh from the mozilla overlay
+# note - could not roll langpacks for: ca fi
+#MOZ_LANGS=(ca cs de en-GB es-AR es-ES fi fr gl hu it ja lt nb-NO nl pl pt-PT
+#          ru sk sv-SE tr uk zh-CN zh-TW)
+MOZ_LANGS=(cs de en-GB es-AR es-ES fr hu it ja lt nl pl pt-PT
+           ru sk sv-SE zh-CN zh-TW)
+
+MOZ_PV="${PV/_pre*}"
+MOZ_PV="${MOZ_PV/_alpha/a}"
+MOZ_PV="${MOZ_PV/_beta/b}"
+MOZ_PV="${MOZ_PV/_rc/rc}"
+MOZ_P="${P}"
+MY_MOZ_P="${PN}-${MOZ_PV}"
+
+if [[ ${PV} == *_pre* ]] ; then
+       
MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/candidates/${MOZ_PV}-candidates/build${PV##*_pre}";
+else
+       MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/releases/${MOZ_PV}";
+fi
+
+SRC_URI="${MOZ_HTTP_URI}/source/${MY_MOZ_P}.source.tar.xz -> ${P}.source.tar.xz
+       ${MOZ_HTTP_URI}/source/${MY_MOZ_P}.source-l10n.tar.xz -> 
${P}.source-l10n.tar.xz"
+S="${WORKDIR}/${MY_MOZ_P}"
+
+MOZ_GENERATE_LANGPACKS=1
+MOZ_L10N_SOURCEDIR="${S}/${P}-l10n"
+inherit autotools check-reqs desktop edos2unix flag-o-matic mozcoreconf-v6 
mozlinguas-v2 pax-utils toolchain-funcs xdg-utils
+
+DESCRIPTION="Seamonkey Web Browser"
+HOMEPAGE="https://www.seamonkey-project.org/";
+
+PATCH="${PN}-2.53.10.2-patches-01"
+SRC_URI+="
+       https://dev.gentoo.org/~sam/distfiles/${CATEGORY}/${PN}/${PATCH}.tar.gz
+       system-libvpx? ( 
https://dev.gentoo.org/~sam/distfiles/${CATEGORY}/${PN}/${PN}-2.53.3-system_libvpx-1.8.patch.gz
 )
+
+"
+
+LICENSE="MPL-2.0 GPL-2 LGPL-2.1"
+SLOT="0"
+SYSTEM_IUSE=( +system-{av1,harfbuzz,icu,jpeg,libevent,libvpx,png,sqlite} )
+IUSE="+chatzilla cpu_flags_arm_neon +crypt dbus debug +gmp-autoupdate +ipc jack
+lto pulseaudio +roaming selinux startup-notification test wifi"
+IUSE+=" ${SYSTEM_IUSE[@]}"
+KEYWORDS="~amd64 ~ppc64 ~x86"
+
+RESTRICT="!test? ( test )"
+
+ASM_DEPEND=">=dev-lang/yasm-1.1"
+
+BDEPEND="
+       app-arch/unzip
+       app-arch/zip
+       >=dev-lang/nasm-2.13
+       dev-lang/perl
+       >=sys-devel/binutils-2.16.1
+       virtual/pkgconfig
+       >=virtual/rust-1.58.1
+       amd64? ( ${ASM_DEPEND} )
+       lto? ( sys-devel/binutils[gold] )
+       x86? ( ${ASM_DEPEND} )
+"
+COMMON_DEPEND="
+       >=app-text/hunspell-1.5.4:=
+       dev-libs/atk
+       >=dev-libs/glib-2.26:2
+       >=dev-libs/libffi-3.0.10:=
+       >=dev-libs/nspr-4.23
+       >=dev-libs/nss-3.47.1
+       media-libs/fontconfig
+       >=media-libs/freetype-2.4.10
+       >=media-libs/mesa-10.2:=
+       >=sys-libs/zlib-1.2.3
+       >=x11-libs/cairo-1.10[X]
+       x11-libs/gdk-pixbuf
+       >=x11-libs/gtk+-2.18:2
+       >=x11-libs/gtk+-3.4.0:3
+       x11-libs/libX11
+       x11-libs/libXcomposite
+       x11-libs/libXdamage
+       x11-libs/libXext
+       x11-libs/libXfixes
+       x11-libs/libXrender
+       x11-libs/libXt
+       >=x11-libs/pango-1.22.0
+       >=x11-libs/pixman-0.19.2
+       media-video/ffmpeg
+       virtual/freedesktop-icon-theme
+       dbus? (
+               >=dev-libs/dbus-glib-0.72
+               >=sys-apps/dbus-0.60
+       )
+       jack? ( virtual/jack )
+       crypt? ( <x11-plugins/enigmail-2.1.0 )
+       kernel_linux? ( !pulseaudio? ( media-libs/alsa-lib ) )
+       pulseaudio? ( || (
+               media-sound/pulseaudio
+               >=media-sound/apulse-0.1.9
+       ) )
+       startup-notification? ( >=x11-libs/startup-notification-0.8 )
+       system-av1? (
+               >=media-libs/dav1d-0.3.0:=
+               >=media-libs/libaom-1.0.0:=
+       )
+       system-harfbuzz? (
+               >=media-gfx/graphite2-1.3.9-r1
+               >=media-libs/harfbuzz-1.3.3:0=
+       )
+       system-icu? ( >=dev-libs/icu-59.1:= )
+       system-jpeg? ( >=media-libs/libjpeg-turbo-1.2.1 )
+       system-libevent? ( >=dev-libs/libevent-2.0:0= )
+       system-libvpx? ( >=media-libs/libvpx-1.8.0:0=[postproc] )
+       system-png? ( >=media-libs/libpng-1.6.31:0=[apng] )
+       system-sqlite? ( >=dev-db/sqlite-3.36.0:3[secure-delete,debug=] )
+       wifi? (
+               kernel_linux? (
+                       >=dev-libs/dbus-glib-0.72
+                       net-misc/networkmanager
+                       >=sys-apps/dbus-0.60
+               )
+       )
+"
+RDEPEND="${COMMON_DEPEND}
+       selinux? ( sec-policy/selinux-mozilla )
+"
+DEPEND="${COMMON_DEPEND}
+       amd64? ( virtual/opengl )
+       x86? ( virtual/opengl )
+"
+
+# allow GMP_PLUGIN_LIST to be set in an eclass or
+# overridden in the enviromnent (advanced hackers only)
+[[ -z ${GMP_PLUGIN_LIST} ]] && GMP_PLUGIN_LIST=( gmp-gmpopenh264 
gmp-widevinecdm )
+
+BUILD_OBJ_DIR="${S}/seamonk"
+
+pkg_setup() {
+       if [[ ${PV} == *_beta* ]] || [[ ${PV} == *_pre* ]] ; then
+               ewarn "You're using an unofficial release of ${PN}. Don't file 
any bug in"
+               ewarn "Gentoo's Bugtracker against this package in case it 
breaks for you."
+               ewarn "Those belong to upstream: https://bugzilla.mozilla.org";
+       fi
+
+       moz_pkgsetup
+}
+
+pkg_pretend() {
+       # Ensure we have enough disk space to compile
+       if use debug || use lto || use test ; then
+               CHECKREQS_DISK_BUILD="16G"
+       else
+               CHECKREQS_DISK_BUILD="12G"
+       fi
+       check-reqs_pkg_setup
+}
+
+spkg_setup() {
+       # Ensure we have enough disk space to compile
+       if use debug || use lto || use test ; then
+               CHECKREQS_DISK_BUILD="16G"
+       else
+               CHECKREQS_DISK_BUILD="12G"
+       fi
+       check-reqs_pkg_setup
+}
+
+src_unpack() {
+       local l10n_sources="${P}.source-l10n.tar.xz"
+       unpack ${A/ ${l10n_sources}}
+
+       mkdir "${S}/${P}-l10n" || die
+       cd "${S}/${P}-l10n" || die
+       unpack ${l10n_sources}
+}
+
+src_prepare() {
+       # Apply our patches
+       eapply "${WORKDIR}"/mozilla
+
+       # https://bugzilla.mozilla.org/show_bug.cgi?id=1623054
+       eapply "${FILESDIR}/${PN}-2.53.10.2-ownertab.patch"
+
+       # Shell scripts sometimes contain DOS line endings; bug 391889
+       grep -rlZ --include="*.sh" $'\r$' . |
+       while read -r -d $'\0' file ; do
+               einfo edos2unix "${file}"
+               edos2unix "${file}"
+       done
+
+       use system-libvpx \
+               && eapply -p2 "${WORKDIR}/${PN}-2.53.3-system_libvpx-1.8.patch"
+
+       # Allow user to apply any additional patches without modifing ebuild
+       eapply_user
+
+       # Don't error for format with gcc-9
+       grep -rl -- '-Werror=format' | xargs sed -i 's/error=format/no-&/' || 
die
+
+       # Enable gnomebreakpad
+       if use debug ; then
+               sed -i -e 
"s:GNOME_DISABLE_CRASH_DIALOG=1:GNOME_DISABLE_CRASH_DIALOG=0:g" \
+                       build/unix/run-mozilla.sh || die
+       fi
+
+       # Ensure that are plugins dir is enabled as default
+       sed -i -e 
"s:/usr/$(get_libdir)/mozilla/plugins:/usr/$(get_libdir)/${PN}/plugins:" \
+               xpcom/io/nsAppFileLocationProvider.cpp || die
+
+       # Don't exit with error when some libs are missing which we have in
+       # system.
+       sed '/^MOZ_PKG_FATAL_WARNINGS/s@= 1@= 0@' \
+               -i comm/suite/installer/Makefile.in || die
+       # Don't error out when there's no files to be removed:
+       sed 's@\(xargs rm\)$@\1 -f@' \
+               -i toolkit/mozapps/installer/packager.mk || die
+
+       # Don't build libs-% locale files for chatzilla if we are not building 
chatzilla
+       # (this is hard-coded in the build system at present rather than being 
based on configuration)
+       if ! use chatzilla ; then
+               sed '/extensions\/irc\/locales libs-/s@^@#@' \
+                       -i comm/suite/locales/Makefile.in || die
+       fi
+
+       eautoreconf old-configure.in
+       cd js/src || die
+       eautoconf old-configure.in
+}
+
+src_configure() {
+       MEXTENSIONS="default"
+       # Google API keys (see 
http://www.chromium.org/developers/how-tos/api-keys)
+       # Note: These are for Gentoo Linux use ONLY. For your own distribution, 
please
+       # get your own set of keys.
+       _google_api_key=AIzaSyDEAOvatFo0eTgsV_ZlEzx0ObmepsMzfAc
+
+       ######################################
+       #
+       # mozconfig, CFLAGS and CXXFLAGS setup
+       #
+       ######################################
+
+       mozconfig_init
+
+       ##################################
+       # Former mozconfig_config() part #
+       ##################################
+
+       # Migrated from mozcoreconf-2
+       mozconfig_annotate 'system_libs' --with-system-bz2
+       mozconfig_annotate 'system_libs' --with-system-zlib
+
+       # Disable for testing purposes only
+       mozconfig_annotate 'Upstream bug 1341234' --disable-stylo
+
+       # Must pass release in order to properly select linker via gold useflag
+       mozconfig_annotate 'Enable by Gentoo' --enable-release
+
+       # Must pass --enable-gold if using ld.gold
+       if tc-ld-is-gold ; then
+               mozconfig_annotate 'tc-ld-is-gold=true' --enable-gold
+       else
+               mozconfig_annotate 'tc-ld-is-gold=false' --disable-gold
+       fi
+
+       # Enable position independent executables
+       mozconfig_annotate 'enabled by Gentoo' --enable-pie
+
+       mozconfig_use_enable debug
+       mozconfig_use_enable debug tests
+       if ! use debug ; then
+               mozconfig_annotate 'disabled by Gentoo' --disable-debug-symbols
+       else
+               mozconfig_annotate 'enabled by Gentoo' --enable-debug-symbols
+       fi
+
+       mozconfig_use_enable startup-notification
+
+       # wifi pulls in dbus so manage both here
+       mozconfig_use_enable wifi necko-wifi
+       if use kernel_linux && use wifi && ! use dbus ; then
+               echo "Enabling dbus support due to wifi request"
+               mozconfig_annotate 'dbus required by necko-wifi on linux' 
--enable-dbus
+       else
+               mozconfig_use_enable dbus
+               mozconfig_annotate 'disabled' --disable-necko-wifi
+       fi
+
+       # These are enabled by default in all mozilla applications
+       mozconfig_annotate '' --with-system-nspr 
--with-nspr-prefix="${SYSROOT}${EPREFIX}"/usr
+       mozconfig_annotate '' --with-system-nss 
--with-nss-prefix="${SYSROOT}${EPREFIX}"/usr
+       mozconfig_annotate '' --x-includes="${SYSROOT}${EPREFIX}"/usr/include 
--x-libraries="${SYSROOT}${EPREFIX}"/usr/$(get_libdir)
+       if use system-libevent ; then
+               mozconfig_annotate '' 
--with-system-libevent="${SYSROOT}${EPREFIX}"/usr
+       fi
+       mozconfig_annotate '' --prefix="${EPREFIX}"/usr
+       mozconfig_annotate '' --libdir="${EPREFIX}"/usr/$(get_libdir)
+       mozconfig_annotate 'Gentoo default' --enable-system-hunspell
+       mozconfig_annotate '' --disable-crashreporter
+       mozconfig_annotate '' --enable-system-ffi
+       mozconfig_annotate '' --disable-gconf
+       mozconfig_annotate '' --with-intl-api
+
+       # skia has no support for big-endian platforms
+       if [[ $(tc-endian) == "big" ]] ; then
+               mozconfig_annotate 'big endian target' --disable-skia
+       else
+               mozconfig_annotate '' --enable-skia
+       fi
+
+       # default toolkit is cairo-gtk3, optional use flags can change this
+       mozconfig_annotate '' --enable-default-toolkit=cairo-gtk3
+
+       # Instead of the standard --build= and --host=, mozilla uses --host 
instead
+       # of --build, and --target intstead of --host.
+       # Note, mozilla also has --build but it does not do what you think it 
does.
+       # Set both --target and --host as mozilla uses python to guess values 
otherwise
+       mozconfig_annotate '' --target="${CHOST}"
+       mozconfig_annotate '' --host="${CBUILD:-${CHOST}}"
+
+       mozconfig_use_enable pulseaudio
+       # force the deprecated alsa sound code if pulseaudio is disabled
+       if use kernel_linux && ! use pulseaudio ; then
+               mozconfig_annotate '-pulseaudio' --enable-alsa
+       fi
+
+       # For testing purpose only
+       mozconfig_annotate 'Sandbox' --enable-content-sandbox
+
+       mozconfig_use_enable system-sqlite
+       mozconfig_use_with system-jpeg
+       mozconfig_use_with system-icu
+       mozconfig_use_with system-libvpx
+       mozconfig_use_with system-png
+       mozconfig_use_with system-harfbuzz
+       mozconfig_use_with system-harfbuzz system-graphite2
+       mozconfig_use_with system-av1
+
+       # Modifications to better support ARM, bug 553364
+       if use cpu_flags_arm_neon ; then
+               mozconfig_annotate '' --with-fpu=neon
+               mozconfig_annotate '' --with-thumb=yes
+               mozconfig_annotate '' --with-thumb-interwork=no
+       fi
+       if [[ ${CHOST} == armv* ]] ; then
+               mozconfig_annotate '' --with-float-abi=hard
+               if ! use system-libvpx ; then
+                       sed -i -e "s|softfp|hard|" media/libvpx/moz.build || die
+               fi
+       fi
+
+       if use lto ; then
+               # Linking only works when using ld.gold when LTO is enabled
+               mozconfig_annotate "forcing ld=gold due to USE=lto" 
--enable-linker=gold
+               # ThinLTO is currently broken, see bmo#1644409
+               mozconfig_annotate '+lto' --enable-lto=full
+       else
+               if tc-ld-is-gold ; then
+                       mozconfig_annotate "linker is set to gold" 
--enable-linker=gold
+               else
+                       mozconfig_annotate "linker is set to bfd" 
--enable-linker=bfd
+               fi
+       fi
+       # LTO flag was handled via configure
+       filter-flags '-flto*'
+
+       ##################################
+       # Former mozconfig_config() end  #
+       ##################################
+
+       # enable JACK, bug 600002
+       mozconfig_use_enable jack
+
+       # It doesn't compile on alpha without this LDFLAGS
+       use alpha && append-ldflags "-Wl,--no-relax"
+
+       # Linking fails without this due to memory exhaustion
+       use x86 && append-ldflags "-Wl,--no-keep-memory"
+
+       if ! use roaming ; then
+               MEXTENSIONS+=",-sroaming"
+       fi
+
+       # Setup api key for location services
+       printf '%s' "${_google_api_key}" > "${S}"/google-api-key
+       mozconfig_annotate '' 
--with-google-location-service-api-keyfile="${S}/google-api-key"
+       mozconfig_annotate '' 
--with-google-safebrowsing-api-keyfile="${S}/google-api-key"
+
+       mozconfig_annotate '' --enable-extensions="${MEXTENSIONS}"
+       mozconfig_use_enable chatzilla irc
+       mozconfig_annotate '' --enable-dominspector
+
+       # use startup-cache for faster startup time
+       mozconfig_annotate '' --enable-startupcache
+
+       # Broken on some arches
+       mozconfig_annotate '' --disable-elf-hack
+
+       # Use an objdir to keep things organized.
+       echo "mk_add_options MOZ_OBJDIR=${BUILD_OBJ_DIR}" >> "${S}"/.mozconfig
+       echo "mk_add_options XARGS=/usr/bin/xargs" >> "${S}"/.mozconfig
+
+       mozlinguas_mozconfig
+
+       # Finalize and report settings
+       mozconfig_final
+
+       # Work around breakage in makeopts with --no-print-directory
+       MAKEOPTS="${MAKEOPTS/--no-print-directory/}"
+
+       if [[ $(gcc-major-version) -lt 4 ]] ; then
+               append-cxxflags -fno-stack-protector
+       elif [[ $(gcc-major-version) -gt 4 || $(gcc-minor-version) -gt 3 ]] ; 
then
+               if use amd64 || use x86 ; then
+                       append-flags -mno-avx
+               fi
+       fi
+
+       # Pass $MAKEOPTS to build system
+       export MOZ_MAKE_FLAGS="${MAKEOPTS}"
+       # Use system's Python environment
+       export MACH_USE_SYSTEM_PYTHON=1
+       # Disable notification when build system has finished
+       export MOZ_NOSPAM=1
+
+       # workaround for funky/broken upstream configure...
+       export SHELL="${SHELL:-${EPREFIX}/bin/bash}"
+       #emake V=1 -f client.mk configure
+       ./mach configure || die
+}
+
+src_compile() {
+       #MOZ_MAKE_FLAGS="${MAKEOPTS}" SHELL="${SHELL}" \
+       #emake V=1 -f client.mk
+       ./mach build --verbose || die
+
+       mozlinguas_src_compile
+}
+
+src_install() {
+       MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}"
+       DICTPATH="\"${EPREFIX}/usr/share/myspell\""
+
+       local emid
+       pushd "${BUILD_OBJ_DIR}" &>/dev/null || die
+
+       # Pax mark xpcshell for hardened support, only used for startupcache 
creation.
+       pax-mark m dist/bin/xpcshell
+
+       # Copy our preference before omnijar is created.
+       sed "s|SEAMONKEY_PVR|${PVR}|" "${FILESDIR}"/all-gentoo-1.js > \
+               dist/bin/defaults/pref/all-gentoo.js \
+               || die
+
+       # Set default path to search for dictionaries.
+       echo "pref(\"spellchecker.dictionary_path\", ${DICTPATH});" \
+               >> dist/bin/defaults/pref/all-gentoo.js \
+               || die
+
+       echo 'pref("extensions.autoDisableScopes", 3);' >> \
+               dist/bin/defaults/pref/all-gentoo.js \
+               || die
+
+       local plugin
+       if ! use gmp-autoupdate ; then
+               for plugin in "${GMP_PLUGIN_LIST[@]}" ; do
+                       echo "pref(\"media.${plugin}.autoupdate\", false);" >> \
+                               dist/bin/defaults/pref/all-gentoo.js || die
+               done
+       fi
+
+       popd &>/dev/null || die
+
+       #MOZ_MAKE_FLAGS="${MAKEOPTS}" SHELL="${SHELL:-${EPREFIX}/bin/bash}" \
+       #emake DESTDIR="${D}" install
+       DESTDIR="${D}" ./mach install || die
+       MOZ_P="${MY_MOZ_P}" mozlinguas_src_install
+
+       cp "${FILESDIR}"/${PN}.desktop "${T}" || die
+
+       sed 
's|^\(MimeType=.*\)$|\1text/x-vcard;text/directory;application/mbox;message/rfc822;x-scheme-handler/mailto;|'
 \
+               -i "${T}"/${PN}.desktop || die
+       sed 's|^\(Categories=.*\)$|\1Email;|' -i "${T}"/${PN}.desktop \
+               || die
+
+       # Install icon and .desktop for menu entry
+       newicon "${S}"/comm/suite/branding/${PN}/default64.png ${PN}.png
+       domenu "${T}"/${PN}.desktop
+
+       # Required in order to use plugins and even run seamonkey on hardened.
+       pax-mark m 
"${ED}"/${MOZILLA_FIVE_HOME}/{seamonkey,seamonkey-bin,plugin-container}
+
+       if use chatzilla ; then
+               emid='{59c81df5-4b7a-477b-912d-4e0fdf64e5f2}'
+
+               # remove the en_US-only xpi file so a version with all 
requested locales can be installed
+               if [[ -e "${ED}"/${MOZILLA_FIVE_HOME}/extensions/${emid}.xpi ]] 
; then
+                       rm -f 
"${ED}"/${MOZILLA_FIVE_HOME}/extensions/${emid}.xpi || die
+               fi
+
+               # merge the extra locales into the main extension
+               mozlinguas_xpistage_langpacks dist/xpi-stage/chatzilla
+
+               # install the merged extension
+               mkdir -p "${T}/${emid}" || die
+               cp -RLp -t "${T}/${emid}" dist/xpi-stage/chatzilla/* || die
+               insinto ${MOZILLA_FIVE_HOME}/extensions
+               doins -r "${T}/${emid}"
+       fi
+
+       # Provide a place for plugins
+       keepdir "${MOZILLA_FIVE_HOME}/plugins"
+
+       # revdep-rebuild entry
+       insinto /etc/revdep-rebuild
+       echo "SEARCH_DIRS_MASK=${MOZILLA_FIVE_HOME}*" >> ${T}/11${PN}
+       doins "${T}"/11${PN}
+
+}
+
+pkg_preinst() {
+       SEAMONKEY_PLUGINS_DIR="${ROOT}/usr/$(get_libdir)/${PN}/plugins"
+
+       if [[ -L "${SEAMONKEY_PLUGINS_DIR}" ]] ; then
+               rm "${SEAMONKEY_PLUGINS_DIR}" || die
+       fi
+}
+
+pkg_postinst() {
+       # Update mimedb for the new .desktop file
+       xdg_desktop_database_update
+
+       if ! use gmp-autoupdate ; then
+               elog "USE='-gmp-autoupdate' has disabled the following plugins 
from updating or"
+               elog "installing into new profiles:"
+               local plugin
+               for plugin in "${GMP_PLUGIN_LIST[@]}"; do elog "\t ${plugin}" ; 
done
+       fi
+
+       if use chatzilla ; then
+               elog "chatzilla is now an extension which can be en-/disabled 
and configured via"
+               elog "the Add-on manager."
+       fi
+}
+
+pkg_postrm() {
+       xdg_desktop_database_update
+}

Reply via email to