1 |
commit: b6776d23eea55ace243332d854cab965ba76dad4 |
2 |
Author: Ian Stakenvicius <axs <AT> gentoo <DOT> org> |
3 |
AuthorDate: Wed Aug 31 19:41:51 2016 +0000 |
4 |
Commit: Ian Stakenvicius <axs <AT> gentoo <DOT> org> |
5 |
CommitDate: Thu Sep 1 21:03:26 2016 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b6776d23 |
7 |
|
8 |
www-client/seamonkey-2.42.3.0_p0: build seamonkey-2.42 out of thunderbird-45 distfiles |
9 |
|
10 |
Seamonkey upstream is having large difficulties in rolling releases, so |
11 |
its time to take matters into our own hands. Packages suffixed with a _p0 version |
12 |
are packages that will be built out of thunderbird's distfiles, with the added |
13 |
extensions that are not normally included in the thunderbird codebase. |
14 |
|
15 |
Package-Manager: portage-2.2.28 |
16 |
|
17 |
www-client/seamonkey/Manifest | 7 + |
18 |
....42.3.0-fix-chatzillaless-locale-building.patch | 12 + |
19 |
www-client/seamonkey/metadata.xml | 10 +- |
20 |
www-client/seamonkey/seamonkey-2.42.3.0_p0.ebuild | 394 +++++++++++++++++++++ |
21 |
4 files changed, 420 insertions(+), 3 deletions(-) |
22 |
|
23 |
diff --git a/www-client/seamonkey/Manifest b/www-client/seamonkey/Manifest |
24 |
index 2bb89a6..33d0696 100644 |
25 |
--- a/www-client/seamonkey/Manifest |
26 |
+++ b/www-client/seamonkey/Manifest |
27 |
@@ -1,6 +1,10 @@ |
28 |
+DIST chatzilla-2.42.tar.xz 410828 SHA256 331174115fa8aec2bfcb2f602fb92c88ab8066068dcdd2e43550ed083bad210c SHA512 017d008e7afd299bd02c3168c9f276db80075695f48e0a27e05236462319ab75c7cadf527715cc3b7ba5b53d208b1a94dc951434d3a4da065e2b80f55717c250 WHIRLPOOL d98eadd4695739cbe5f47f380c805169a0aec027b17b670b9459e14996efe0176a4c2d120fed5148825a010510cb3227321b65d3dcd54f331d708bfdd7be86ec |
29 |
+DIST dom-inspector-2.0.16.tar.xz 156844 SHA256 c71af60db47ee9f4ced1931005325c834f45b6e6de0501a02b687c1e35ee3446 SHA512 9e49fe7747c91612be741255bc4d2031eb233da455dfc506ddcae7b05edc44ffa048718ffc96b2a7e3015909aff613afa449d5d53aa99d82160429a21d491ea1 WHIRLPOOL c052210aa7104e562e5a9c6df44c6bf6d3e6f62f54610920e3cddc98333f922701157e94ee89150d596753ae48822fb18432dd92ff35882974dacb2d3ca90b19 |
30 |
DIST enigmail-1.8.2.tar.gz 1604159 SHA256 1d2700799bc52aaa8e8c9f7a0f5111281ff9fbdffc093cdff070657d574eb2a6 SHA512 51eece988f466aeb4a343719a86dc7d95ec41dfc3ec7e3d8d2f360528675c605f8f2154f10aeea6ef82ed87c784f1d13bfc978e052a9ede0072b5137f6294b11 WHIRLPOOL e12a703899e0e4c98adc58b5f4bf1f74e24a2cf09c1a706a6edca6aca06140041b293f23e6e5b05c507177b4148533ebc3431fb75592aae07d791a899ba2c45c |
31 |
+DIST enigmail-1.9.1.tar.gz 1736876 SHA256 0393119725fa5931d9888a2a1c9796d440ee7975ca3d005eb63142768b10f993 SHA512 5417d7744ff5b8299d9799059f62013e546fb74206782169e5ce6baa0950d96d1c8996c99ec902ca73b241fd1268966e0a7ad30c032a1706a0efbf06fefc311c WHIRLPOOL 80cff68461edc743851de5a83cd04105f6689eb1289f46b72334a96b091dc430399a91b2ab004a39bd7cb04433ab0471dd07b44d39fc2eb3869487b07841fc5a |
32 |
DIST firefox-42.0-patches-0.4.tar.xz 13384 SHA256 e56db95dbf077a05189868b400bc6d6750f9cd816a7f38e29180f07975f4f098 SHA512 3c51022ab3eb53ae826824a7fd5870b2c639f70c255d461ac454a67e814dc0c61393ddb1a82527a60325c6373a4e1daaef0fbd088109fd2b65ba6d9538feaba4 WHIRLPOOL d6ab99e7525a7d7749d5805d5b9ff0430fff5b57262574a334d48d9ef08ed90784e90ab33f3794ec04308199dddae773f80a3d3c86c880b393924ee64f3dd0cb |
33 |
DIST firefox-42.0-patches-02.tar.xz 6424 SHA256 6c8a89c75ea4a359bf720f011e1bb856b653cd6676767b33ccb9d2f807a089e3 SHA512 d40266c98aa5bfeed243e3bd42f9146bc73492bd20bd07ac4941df83793a7e3a832220b65fc8c9eeb5f3a00089087251a2b758df5fc0d3dd3403468ec0b9eb53 WHIRLPOOL 93356507e31a5dca653a5fcc844c24acc1de6b2a01f3dbd7227c1e23eda4e8799a59cf1a50bb49b721249cb82c744d49f4671bfb7188275101c6de955afdb149 |
34 |
+DIST firefox-45.0-patches-04.tar.xz 18600 SHA256 2ee0ab58e0a1db7b573dd7ac407dcb9a43a85dd295c5d6d263f72ce629c5290c SHA512 cf5d4ddfe14dff92950baae066350ace0a503c5bdd9d837e4724fd2fb905a2fb540dcf34971531e79547dd62dfbf217d472f39ccc4802f34a245e24f406fdb5e WHIRLPOOL 1461c61ba7e54b7a91c758fdf91fda22260eaff4148b3cccab8ccfd9d09a3d80c0314e999284d392d9e961c42cd9720d6d30ac190074f74d1e53ecb1afa1b1e3 |
35 |
DIST mozilla-graphite2-1.3.5-upgrade_patches.tar.xz 92916 SHA256 6314600c4d19112a51fba1f406eaef34b50df78405aa7cb0080550322d9b9ff9 SHA512 7fa37fe27587b80aaf4a2625abf7a28553286ecfa837b4c7c7d5a217abf8cf01a2446471f7c320d484325c2f7461161b00df75ff9a5d9efc70140e9723f5ac2f WHIRLPOOL 749ba5919850945f0fe36dfac912206cd38c50ae244703d07e37ea8a99a6b0c4300d0dd443db6c7a7fea22792ac7ccc8f839d598260e3e9f044e03431513f5c8 |
36 |
DIST seamonkey-2.33-patches-01.tar.xz 944 SHA256 1612d94dddbd37fa4ce8307c1ba565c8439d082609b63c12b4971e361895566c SHA512 0132e7d06a1ea5d6c059f23e5b8a20016a1e911e8aa40ae15eaefcd141030b4d245297f1e13e508827d91bab5988db4775c8425e737654afba2ede9c2dee8392 WHIRLPOOL 4520c4eaa7e6a25f5c32e9cd1d46472e181fbd769a1c5a59c913834cec5556100eac01423b4abf4a47543d0fbae4bf83b0f4a4d6cec7a058587e2705043bf507 |
37 |
DIST seamonkey-2.39-be.xpi 845960 SHA256 289803bc8d1669aa8dc116e55ffbef60a611002c39dbe9e461ad3546d82043d5 SHA512 2332683e78d8f546fe85a9d7431c295f5f31341d46072eb0eafca6014d527367edc575f5384b332744d3ea9b1c37f5fb86d547f4c78919e4a9310c99c8705cae WHIRLPOOL 4b2fe60315e7146548311c6c8d2c335d21fed1fb0f9057e9c903968bae8dc251b7e60151965f1ca3a4f58dc210e08e6a7677a7f57c41f6d2577e156ef98ed5c0 |
38 |
@@ -55,3 +59,6 @@ DIST seamonkey-2.40-uk.xpi 875815 SHA256 9932ca0ac00312a9fd9bab3199f7e55564beb6f |
39 |
DIST seamonkey-2.40-zh-CN.xpi 839892 SHA256 28f634be2ed10526dbf6bf310b28f4da921d5809bce8216418c34ad07ac75443 SHA512 743e34a2aa6776ff665e4b0a6d763acbfd96cce6d51ee1cf6cc4b10cc999f0d63d10435040f57950433574828c8cc77feab56a9b640dce99643ee6c18a9a9a72 WHIRLPOOL b539345deee6aa8ca6b3f3017e9fba5737131928e8b2e47a188d5a01ef0d9202baa75591a4b4c9d1d1b95b28b9893f41d6ae47a7121cb42e8395568495382c49 |
40 |
DIST seamonkey-2.40-zh-TW.xpi 861767 SHA256 eaec998d922789be13cfc42660ab96abd0b1ec47cb4394b8a9f725969141ba89 SHA512 7ab516753547aba8fbe48cf147082f1f282ecd6fceac0deb9795dbbd1b2962cdf82bc02128a04527a664e3cd00a4b529bff6e33a4f9fff4cbe998e2ec302ffbc WHIRLPOOL d0eb50f6990acfae199ff0e21b6d738271e8e30d91b8d0678e00e4871be69779f57b7642979485c6b2bcfbabc22c9002bff76a3b3a702fb1b747ceb10bbeb134 |
41 |
DIST seamonkey-2.40.source.tar.xz 193702432 SHA256 7ecccc039d03f38d197b123b59ea42eac4c0c10e4bdec779b3665d79b435fa01 SHA512 5a81a25c75af254f1508aa615a082f013d7d06950859822a134c51a0f4c12918081f69e7835dc85114e4285a67bc4be4d509db8374dec848f6381dfce447b696 WHIRLPOOL efeaaab91980fa98d3c13c2c99d5ca3f8a265ab2d978cbb3ebfdad87df481d97be9105decbf44e1bac2d8214e753eb9bdb78d1c2f64eaedef0c8cfa0f251db01 |
42 |
+DIST seamonkey-2.42-patches-01.tar.xz 812 SHA256 289b36a4538e4f3ec3633c08084d018e52fd2edfbdd1748c341accd452d20ee0 SHA512 7c727324671c242940876acfce6a95ac1b47713c83be502c8a5dba26be3d5e7998a13ae93c8874d51c3250bd3916d4468cb51b3beb26e74ff7d9d6ffa4c63c95 WHIRLPOOL 4c90988ce1364e38848caf92fb3f565cab4d8ab990eb1eed2c11655eff81d3a77b02577cb43fd35102c04b03c18963989f61ef32c6e9c29bbed2d0e6f9cc78a5 |
43 |
+DIST seamonkey-2.42.3.0-l10n-sources.tar.xz 16552028 SHA256 2d348468c041b29b5ba5defb968dd42ff31733d4c6311c18ff95a9a2b170d649 SHA512 17c75e754ffff1e0d5789a3e9f1435367d68802a754a1b2fe6d1349fc7202a123c50b33a0ae6ebd820ff9069c3f89501c4062851cad83257ceb3577a8726b731 WHIRLPOOL 6b86cd6495e33894a7a1ed7e93bd7d77f7f0070fa5f036acd58fc7aca85994132af6251b1c1b074a557893668a738b37859423bf370e44f7732223ec05dd6165 |
44 |
+DIST thunderbird-45.3.0.source.tar.xz 201005896 SHA256 231f6a7a073344659e436a2b1ae58004c3a29e74375af2c8d0de13f3bc79fac7 SHA512 1226b35535d68b9c088ab8692f61120c99951e1ecbae4739ced711665a3237d248202831831f00536c724e2f6359db4601fa5c90f2793433eab4bd9dab0c1165 WHIRLPOOL 86c4145859ee39d4fcf48eacd5a0b61f6f9f70fee3c2e38fe5b225c06e17ea4b7c1c5ccfa2c9f4d0696e9d807a6b612990ccda7d35bd22a8687ef15a9c3747be |
45 |
|
46 |
diff --git a/www-client/seamonkey/files/seamonkey-2.42.3.0-fix-chatzillaless-locale-building.patch b/www-client/seamonkey/files/seamonkey-2.42.3.0-fix-chatzillaless-locale-building.patch |
47 |
new file mode 100644 |
48 |
index 00000000..e73d0e6 |
49 |
--- /dev/null |
50 |
+++ b/www-client/seamonkey/files/seamonkey-2.42.3.0-fix-chatzillaless-locale-building.patch |
51 |
@@ -0,0 +1,12 @@ |
52 |
+--- a/suite/locales/Makefile.in 2016-06-30 10:08:29.000000000 -0400 |
53 |
++++ b/suite/locales/Makefile.in 2016-07-12 12:00:22.491851899 -0400 |
54 |
+@@ -123,7 +123,9 @@ |
55 |
+ @$(MAKE) -C $(DEPTH)/toolkit/locales libs-$* |
56 |
+ @$(MAKE) -C $(DEPTH)/services/sync/locales AB_CD=$* XPI_NAME=locale-$* |
57 |
+ @$(MAKE) -C ../../editor/ui/locales AB_CD=$* XPI_NAME=locale-$* |
58 |
++ifneq ($(MOZ_EXTENSIONS),$(subst irc,,$(MOZ_EXTENSIONS))) |
59 |
+ @$(MAKE) -C $(DEPTH)/extensions/irc/locales libs-$* |
60 |
++endif |
61 |
+ @$(MAKE) -C $(DEPTH)/extensions/spellcheck/locales AB_CD=$* XPI_NAME=locale-$* |
62 |
+ @$(MAKE) -C $(DEPTH)/intl/locales AB_CD=$* XPI_NAME=locale-$* |
63 |
+ @$(MAKE) -C $(DEPTH)/devtools/client/locales AB_CD=$* XPI_NAME=locale-$* |
64 |
|
65 |
diff --git a/www-client/seamonkey/metadata.xml b/www-client/seamonkey/metadata.xml |
66 |
index 648e357..b3e2038 100644 |
67 |
--- a/www-client/seamonkey/metadata.xml |
68 |
+++ b/www-client/seamonkey/metadata.xml |
69 |
@@ -22,11 +22,15 @@ |
70 |
(forced-on when supported prior to 38.0)</flag> |
71 |
<flag name="roaming">Build roaming extension support (default on)</flag> |
72 |
<flag name="system-cairo">Use the system-wide <pkg>x11-libs/cairo</pkg> |
73 |
- Use system cairo instead of bundled.</flag> |
74 |
+ instead of bundled.</flag> |
75 |
+ <flag name="system-harfbuzz">Use the system-wide <pkg>media-libs/harfbuzz</pkg> |
76 |
+ instead of bundled.</flag> |
77 |
<flag name="system-icu">Use the sytem-wide <pkg>dev-libs/icu</pkg> |
78 |
- Use system icu indead of bundled.</flag> |
79 |
+ instead of bundled.</flag> |
80 |
<flag name="system-jpeg">Use the system-wide <pkg>media-libs/libjpeg-turbo</pkg> |
81 |
- Use system jpeg instead of bundled.</flag> |
82 |
+ instead of bundled.</flag> |
83 |
+ <flag name="system-libevent">Use the system-wide <pkg>dev-libs/libevent</pkg> |
84 |
+ instead of bundled.</flag> |
85 |
<flag name="system-libvpx">Use the system-wide <pkg>media-libs/libvpx</pkg> |
86 |
instead of bundled.</flag> |
87 |
<flag name="system-sqlite">Use the system-wide <pkg>dev-db/sqlite</pkg> |
88 |
|
89 |
diff --git a/www-client/seamonkey/seamonkey-2.42.3.0_p0.ebuild b/www-client/seamonkey/seamonkey-2.42.3.0_p0.ebuild |
90 |
new file mode 100644 |
91 |
index 00000000..5a752e1 |
92 |
--- /dev/null |
93 |
+++ b/www-client/seamonkey/seamonkey-2.42.3.0_p0.ebuild |
94 |
@@ -0,0 +1,394 @@ |
95 |
+# Copyright 1999-2016 Gentoo Foundation |
96 |
+# Distributed under the terms of the GNU General Public License v2 |
97 |
+# $Id$ |
98 |
+ |
99 |
+EAPI=6 |
100 |
+WANT_AUTOCONF="2.1" |
101 |
+ |
102 |
+# This list can be updated with scripts/get_langs.sh from the mozilla overlay |
103 |
+# note - could not roll langpacks for: ca fi |
104 |
+MOZ_LANGS=(be cs de en en-GB en-US es-AR es-ES fr gl hu it ja lt nb-NO nl |
105 |
+ pl pt-PT ru sk sv-SE tr uk zh-CN zh-TW) |
106 |
+ |
107 |
+MOZ_PV="${PV/_pre*}" |
108 |
+MOZ_PV="${MOZ_PV/_alpha/a}" |
109 |
+MOZ_PV="${MOZ_PV/_beta/b}" |
110 |
+MOZ_PV="${MOZ_PV/_rc/rc}" |
111 |
+MOZ_PV="${MOZ_PV/_p0}" |
112 |
+MOZ_P="${P}" |
113 |
+MY_MOZ_P="${PN}-${MOZ_PV}" |
114 |
+ |
115 |
+if [[ ${PV} == *_pre* ]] ; then |
116 |
+# the following are for upstream build candidates |
117 |
+# MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/candidates/${MOZ_PV}-candidates/build${PV##*_pre}" |
118 |
+# MOZ_LANGPACK_PREFIX="linux-i686/xpi/" |
119 |
+ # And the langpack stuff stays at eclass defaults |
120 |
+# the following is for self-rolled releases |
121 |
+ MOZ_HTTP_URI="https://dev.gentoo.org/~axs/distfiles" |
122 |
+ MOZ_LANGPACK_PREFIX="${MY_MOZ_P}." |
123 |
+ MOZ_LANGPACK_SUFFIX=".langpack.xpi" |
124 |
+ SRC_URI="${SRC_URI} |
125 |
+ ${MOZ_HTTP_URI}/${P}.source.tar.xz |
126 |
+ " |
127 |
+elif [[ ${PV} == *_p0 ]]; then |
128 |
+ # gentoo-unofficial release using thunderbird distfiles to build seamonkey instead |
129 |
+ TB_MAJOR=45 |
130 |
+ SMPV="${PV%.[0-9].*}" |
131 |
+ MOZ_P="${PN}-${SMPV}" |
132 |
+ MOZ_HTTP_URI="https://archive.mozilla.org/pub/thunderbird/releases/${MOZ_PV/${SMPV}/${TB_MAJOR}}" |
133 |
+ MOZ_GENERATE_LANGPACKS=1 |
134 |
+ S="${WORKDIR}/thunderbird-${MOZ_PV/${SMPV}/${TB_MAJOR}}" |
135 |
+ SRC_URI="${SRC_URI} |
136 |
+ ${MOZ_HTTP_URI}/source/${MY_MOZ_P/${MOZ_P}/thunderbird-${TB_MAJOR}}.source.tar.xz |
137 |
+ https://dev.gentoo.org/~axs/distfiles/${MY_MOZ_P}-l10n-sources.tar.xz |
138 |
+ https://dev.gentoo.org/~axs/distfiles/chatzilla-2.42.tar.xz |
139 |
+ https://dev.gentoo.org/~axs/distfiles/dom-inspector-2.0.16.tar.xz |
140 |
+ " |
141 |
+else |
142 |
+ MOZ_HTTP_URI="https://archive.mozilla.org/pub/${PN}/releases/${MOZ_PV}" |
143 |
+ MOZ_LANGPACK_PREFIX="langpack/${MY_MOZ_P}." |
144 |
+ MOZ_LANGPACK_SUFFIX=".langpack.xpi" |
145 |
+ S="${WORKDIR}/${PN}-${MOZ_PV}" |
146 |
+ SRC_URI="${SRC_URI} |
147 |
+ ${MOZ_HTTP_URI}/source/${MY_MOZ_P}.source.tar.xz -> ${P}.source.tar.xz |
148 |
+ " |
149 |
+fi |
150 |
+ |
151 |
+MOZCONFIG_OPTIONAL_WIFI=1 |
152 |
+MOZCONFIG_OPTIONAL_JIT="enabled" |
153 |
+inherit check-reqs flag-o-matic toolchain-funcs eutils mozconfig-v6.45 multilib pax-utils fdo-mime autotools mozextension nsplugins mozlinguas-v2 |
154 |
+ |
155 |
+PATCHFF="firefox-45.0-patches-04" |
156 |
+PATCH="${PN}-2.42-patches-01" |
157 |
+EMVER="1.9.1" |
158 |
+ |
159 |
+DESCRIPTION="Seamonkey Web Browser" |
160 |
+HOMEPAGE="http://www.seamonkey-project.org" |
161 |
+KEYWORDS="~alpha ~amd64 ~arm ~ppc ~ppc64 ~x86" |
162 |
+ |
163 |
+SLOT="0" |
164 |
+LICENSE="MPL-2.0 GPL-2 LGPL-2.1" |
165 |
+IUSE="+chatzilla +crypt +gmp-autoupdate +ipc minimal pulseaudio +roaming selinux test" |
166 |
+ |
167 |
+SRC_URI="${SRC_URI} |
168 |
+ https://dev.gentoo.org/~anarchy/mozilla/patchsets/${PATCHFF}.tar.xz |
169 |
+ https://dev.gentoo.org/~axs/mozilla/patchsets/${PATCHFF}.tar.xz |
170 |
+ https://dev.gentoo.org/~axs/mozilla/patchsets/${PATCH}.tar.xz |
171 |
+ https://dev.gentoo.org/~polynomial-c/mozilla/patchsets/${PATCHFF}.tar.xz |
172 |
+ https://dev.gentoo.org/~polynomial-c/mozilla/patchsets/${PATCH}.tar.xz |
173 |
+ crypt? ( https://www.enigmail.net/download/source/enigmail-${EMVER}.tar.gz )" |
174 |
+ |
175 |
+ASM_DEPEND=">=dev-lang/yasm-1.1" |
176 |
+ |
177 |
+RDEPEND=">=dev-libs/nss-3.22.3 |
178 |
+ >=dev-libs/nspr-4.12 |
179 |
+ crypt? ( || ( |
180 |
+ ( >=app-crypt/gnupg-2.0 |
181 |
+ || ( |
182 |
+ app-crypt/pinentry[gtk] |
183 |
+ app-crypt/pinentry[qt4] |
184 |
+ ) |
185 |
+ ) |
186 |
+ =app-crypt/gnupg-1.4* ) )" |
187 |
+ |
188 |
+DEPEND="${RDEPEND} |
189 |
+ !elibc_glibc? ( !elibc_uclibc? ( dev-libs/libexecinfo ) ) |
190 |
+ crypt? ( dev-lang/perl ) |
191 |
+ amd64? ( ${ASM_DEPEND} |
192 |
+ virtual/opengl ) |
193 |
+ x86? ( ${ASM_DEPEND} |
194 |
+ virtual/opengl )" |
195 |
+ |
196 |
+BUILD_OBJ_DIR="${S}/seamonk" |
197 |
+ |
198 |
+pkg_setup() { |
199 |
+ if [[ ${PV} == *_pre* ]] ; then |
200 |
+ ewarn "You're using an unofficial release of ${PN}. Don't file any bug in" |
201 |
+ ewarn "Gentoo's Bugtracker against this package in case it breaks for you." |
202 |
+ ewarn "Those belong to upstream: https://bugzilla.mozilla.org" |
203 |
+ fi |
204 |
+ |
205 |
+ moz_pkgsetup |
206 |
+} |
207 |
+ |
208 |
+pkg_pretend() { |
209 |
+ # Ensure we have enough disk space to compile |
210 |
+ if use debug || use test ; then |
211 |
+ CHECKREQS_DISK_BUILD="8G" |
212 |
+ else |
213 |
+ CHECKREQS_DISK_BUILD="4G" |
214 |
+ fi |
215 |
+ check-reqs_pkg_setup |
216 |
+} |
217 |
+ |
218 |
+src_unpack() { |
219 |
+ unpack ${A} |
220 |
+ |
221 |
+ # Unpack language packs |
222 |
+ mozlinguas_src_unpack |
223 |
+ |
224 |
+ # move the irc and inspector code into the correct locations |
225 |
+ mv "${WORKDIR}"/irc "${S}"/mozilla/extensions/irc || die |
226 |
+ mv "${WORKDIR}"/inspector "${S}"/mozilla/extensions/inspector || die |
227 |
+} |
228 |
+ |
229 |
+src_prepare() { |
230 |
+ # Apply our patches |
231 |
+ eapply "${WORKDIR}"/seamonkey \ |
232 |
+ "${FILESDIR}"/${MY_MOZ_P}-fix-chatzillaless-locale-building.patch |
233 |
+ |
234 |
+ # browser patches go here |
235 |
+ pushd "${S}"/mozilla &>/dev/null || die |
236 |
+ rm -f "${WORKDIR}"/firefox/2000-firefox_gentoo_install_dirs.patch |
237 |
+ eapply "${WORKDIR}"/firefox |
238 |
+ popd &>/dev/null || die |
239 |
+ |
240 |
+ # Shell scripts sometimes contain DOS line endings; bug 391889 |
241 |
+ grep -rlZ --include="*.sh" $'\r$' . | |
242 |
+ while read -r -d $'\0' file ; do |
243 |
+ einfo edos2unix "${file}" |
244 |
+ edos2unix "${file}" |
245 |
+ done |
246 |
+ |
247 |
+ # Allow user to apply any additional patches without modifing ebuild |
248 |
+ eapply_user |
249 |
+ |
250 |
+ local ms="${S}/mozilla" |
251 |
+ |
252 |
+ # Enable gnomebreakpad |
253 |
+ if use debug ; then |
254 |
+ sed -i -e "s:GNOME_DISABLE_CRASH_DIALOG=1:GNOME_DISABLE_CRASH_DIALOG=0:g" \ |
255 |
+ "${ms}"/build/unix/run-mozilla.sh || die "sed failed!" |
256 |
+ fi |
257 |
+ |
258 |
+ # Ensure that are plugins dir is enabled as default |
259 |
+ sed -i -e "s:/usr/lib/mozilla/plugins:/usr/lib/nsbrowser/plugins:" \ |
260 |
+ "${ms}"/xpcom/io/nsAppFileLocationProvider.cpp || die "sed failed to replace plugin path for 32bit!" |
261 |
+ sed -i -e "s:/usr/lib64/mozilla/plugins:/usr/lib64/nsbrowser/plugins:" \ |
262 |
+ "${ms}"/xpcom/io/nsAppFileLocationProvider.cpp || die "sed failed to replace plugin path for 64bit!" |
263 |
+ |
264 |
+ # Don't exit with error when some libs are missing which we have in |
265 |
+ # system. |
266 |
+ sed '/^MOZ_PKG_FATAL_WARNINGS/s@= 1@= 0@' \ |
267 |
+ -i "${S}"/suite/installer/Makefile.in || die |
268 |
+ # Don't error out when there's no files to be removed: |
269 |
+ sed 's@\(xargs rm\)$@\1 -f@' \ |
270 |
+ -i "${ms}"/toolkit/mozapps/installer/packager.mk || die |
271 |
+ |
272 |
+ eautoreconf |
273 |
+ cd "${S}"/mozilla || die |
274 |
+ eautoconf |
275 |
+ cd "${S}"/mozilla/js/src || die |
276 |
+ eautoconf |
277 |
+ cd "${S}"/mozilla/memory/jemalloc/src || die |
278 |
+ WANT_AUTOCONF= eautoconf |
279 |
+} |
280 |
+ |
281 |
+src_configure() { |
282 |
+ MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}" |
283 |
+ MEXTENSIONS="default" |
284 |
+ # Google API keys (see http://www.chromium.org/developers/how-tos/api-keys) |
285 |
+ # Note: These are for Gentoo Linux use ONLY. For your own distribution, please |
286 |
+ # get your own set of keys. |
287 |
+ _google_api_key=AIzaSyDEAOvatFo0eTgsV_ZlEzx0ObmepsMzfAc |
288 |
+ |
289 |
+ #################################### |
290 |
+ # |
291 |
+ # mozconfig, CFLAGS and CXXFLAGS setup |
292 |
+ # |
293 |
+ #################################### |
294 |
+ |
295 |
+ mozconfig_init |
296 |
+ mozconfig_config |
297 |
+ |
298 |
+ # It doesn't compile on alpha without this LDFLAGS |
299 |
+ use alpha && append-ldflags "-Wl,--no-relax" |
300 |
+ |
301 |
+ if ! use chatzilla ; then |
302 |
+ MEXTENSIONS+=",-irc" |
303 |
+ fi |
304 |
+ if ! use roaming ; then |
305 |
+ MEXTENSIONS+=",-sroaming" |
306 |
+ fi |
307 |
+ |
308 |
+ # Setup api key for location services |
309 |
+ echo -n "${_google_api_key}" > "${S}"/google-api-key |
310 |
+ mozconfig_annotate '' --with-google-api-keyfile="${S}/google-api-key" |
311 |
+ |
312 |
+ mozconfig_annotate '' --enable-extensions="${MEXTENSIONS}" |
313 |
+ mozconfig_annotate '' --enable-jsd |
314 |
+ mozconfig_annotate '' --enable-canvas |
315 |
+ |
316 |
+ # Other sm-specific settings |
317 |
+ mozconfig_annotate '' --with-default-mozilla-five-home=${MOZILLA_FIVE_HOME} |
318 |
+ |
319 |
+ mozconfig_annotate '' --enable-safe-browsing |
320 |
+ |
321 |
+ mozlinguas_mozconfig |
322 |
+ |
323 |
+ # Use an objdir to keep things organized. |
324 |
+ echo "mk_add_options MOZ_OBJDIR=${BUILD_OBJ_DIR}" \ |
325 |
+ >> "${S}"/.mozconfig |
326 |
+ |
327 |
+ # Finalize and report settings |
328 |
+ mozconfig_final |
329 |
+ |
330 |
+ if use crypt ; then |
331 |
+ pushd "${WORKDIR}"/enigmail &>/dev/null || die |
332 |
+ econf |
333 |
+ popd &>/dev/null || die |
334 |
+ fi |
335 |
+ |
336 |
+ # Work around breakage in makeopts with --no-print-directory |
337 |
+ MAKEOPTS="${MAKEOPTS/--no-print-directory/}" |
338 |
+ |
339 |
+ if [[ $(gcc-major-version) -lt 4 ]] ; then |
340 |
+ append-cxxflags -fno-stack-protector |
341 |
+ elif [[ $(gcc-major-version) -gt 4 || $(gcc-minor-version) -gt 3 ]] ; then |
342 |
+ if use amd64 || use x86 ; then |
343 |
+ append-flags -mno-avx |
344 |
+ fi |
345 |
+ fi |
346 |
+ |
347 |
+ emake V=1 -f client.mk configure |
348 |
+} |
349 |
+ |
350 |
+src_compile() { |
351 |
+ CC="$(tc-getCC)" CXX="$(tc-getCXX)" LD="$(tc-getLD)" \ |
352 |
+ MOZ_MAKE_FLAGS="${MAKEOPTS}" SHELL="${SHELL}" \ |
353 |
+ emake V=1 -f client.mk |
354 |
+ |
355 |
+ mozlinguas_src_compile |
356 |
+ |
357 |
+ # Only build enigmail extension if conditions are met. |
358 |
+ if use crypt ; then |
359 |
+ einfo "Building enigmail" |
360 |
+ pushd "${WORKDIR}"/enigmail &>/dev/null || die |
361 |
+ emake -j1 |
362 |
+ emake xpi |
363 |
+ popd &>/dev/null || die |
364 |
+ fi |
365 |
+} |
366 |
+ |
367 |
+src_install() { |
368 |
+ MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}" |
369 |
+ DICTPATH="\"${EPREFIX}/usr/share/myspell\"" |
370 |
+ |
371 |
+ local emid |
372 |
+ cd "${BUILD_OBJ_DIR}" || die |
373 |
+ |
374 |
+ # Pax mark xpcshell for hardened support, only used for startupcache creation. |
375 |
+ pax-mark m "${BUILD_OBJ_DIR}/dist/bin/xpcshell" |
376 |
+ |
377 |
+ # Copy our preference before omnijar is created. |
378 |
+ sed "s|SEAMONKEY_PVR|${PVR}|" "${FILESDIR}"/all-gentoo-1.js > \ |
379 |
+ "${BUILD_OBJ_DIR}/dist/bin/defaults/pref/all-gentoo.js" \ |
380 |
+ || die |
381 |
+ |
382 |
+ # Set default path to search for dictionaries. |
383 |
+ echo "pref(\"spellchecker.dictionary_path\", ${DICTPATH});" \ |
384 |
+ >> "${BUILD_OBJ_DIR}/dist/bin/defaults/pref/all-gentoo.js" \ |
385 |
+ || die |
386 |
+ |
387 |
+ echo 'pref("extensions.autoDisableScopes", 3);' >> \ |
388 |
+ "${BUILD_OBJ_DIR}/dist/bin/defaults/pref/all-gentoo.js" \ |
389 |
+ || die |
390 |
+ |
391 |
+ local plugin |
392 |
+ if ! use gmp-autoupdate ; then |
393 |
+ for plugin in gmp-gmpopenh264 ; do |
394 |
+ echo "pref(\"media.${plugin}.autoupdate\", false);" >> \ |
395 |
+ "${S}/${BUILD_OBJ_DIR}/dist/bin/browser/defaults/preferences/all-gentoo.js" \ |
396 |
+ || dir |
397 |
+ done |
398 |
+ fi |
399 |
+ |
400 |
+ MOZ_MAKE_FLAGS="${MAKEOPTS}" \ |
401 |
+ emake DESTDIR="${D}" install |
402 |
+ cp "${FILESDIR}"/${PN}.desktop "${T}" || die |
403 |
+ |
404 |
+ if use crypt ; then |
405 |
+ local em_dir="${WORKDIR}/enigmail/build" |
406 |
+ pushd "${T}" &>/dev/null || die |
407 |
+ unzip "${em_dir}"/enigmail*.xpi install.rdf || die |
408 |
+ emid=$(sed -n '/<em:id>/!d; s/.*\({.*}\).*/\1/; p; q' install.rdf) |
409 |
+ #' |
410 |
+ dodir ${MOZILLA_FIVE_HOME}/extensions/${emid} |
411 |
+ cd "${D}"${MOZILLA_FIVE_HOME}/extensions/${emid} || die |
412 |
+ unzip "${em_dir}"/enigmail*.xpi || die |
413 |
+ |
414 |
+ popd &>/dev/null || die |
415 |
+ fi |
416 |
+ |
417 |
+ sed 's|^\(MimeType=.*\)$|\1text/x-vcard;text/directory;application/mbox;message/rfc822;x-scheme-handler/mailto;|' \ |
418 |
+ -i "${T}"/${PN}.desktop || die |
419 |
+ sed 's|^\(Categories=.*\)$|\1Email;|' -i "${T}"/${PN}.desktop \ |
420 |
+ || die |
421 |
+ |
422 |
+ # Install language packs |
423 |
+ mozlinguas_src_install |
424 |
+ |
425 |
+ # Add StartupNotify=true bug 290401 |
426 |
+ if use startup-notification ; then |
427 |
+ echo "StartupNotify=true" >> "${T}"/${PN}.desktop || die |
428 |
+ fi |
429 |
+ |
430 |
+ # Install icon and .desktop for menu entry |
431 |
+ newicon "${S}"/suite/branding/nightly/content/icon64.png ${PN}.png |
432 |
+ domenu "${T}"/${PN}.desktop |
433 |
+ |
434 |
+ # Required in order to use plugins and even run seamonkey on hardened. |
435 |
+ pax-mark m "${ED}"${MOZILLA_FIVE_HOME}/{seamonkey,seamonkey-bin,plugin-container} |
436 |
+ |
437 |
+ if use minimal ; then |
438 |
+ rm -rf "${ED}"/usr/include "${ED}${MOZILLA_FIVE_HOME}"/{idl,include,lib,sdk} |
439 |
+ fi |
440 |
+ |
441 |
+ if use chatzilla ; then |
442 |
+ local emid='{59c81df5-4b7a-477b-912d-4e0fdf64e5f2}' |
443 |
+ |
444 |
+ # remove the en_US-only xpi file so a version with all requested locales can be installed |
445 |
+ if [[ -e "${ED}"${MOZILLA_FIVE_HOME}/distribution/extensions/${emid}.xpi ]]; then |
446 |
+ rm -f "${ED}"${MOZILLA_FIVE_HOME}/distribution/extensions/${emid}.xpi || die |
447 |
+ fi |
448 |
+ |
449 |
+ # merge the extra locales into the main extension |
450 |
+ mozlinguas_xpistage_langpacks "${BUILD_OBJ_DIR}"/dist/xpi-stage/chatzilla |
451 |
+ |
452 |
+ # install the merged extension |
453 |
+ mkdir -p "${T}/${emid}" || die |
454 |
+ cp -RLp -t "${T}/${emid}" "${BUILD_OBJ_DIR}"/dist/xpi-stage/chatzilla/* || die |
455 |
+ insinto ${MOZILLA_FIVE_HOME}/distribution/extensions |
456 |
+ doins -r "${T}/${emid}" |
457 |
+ fi |
458 |
+ |
459 |
+ # Handle plugins dir through nsplugins.eclass |
460 |
+ share_plugins_dir |
461 |
+ |
462 |
+ #doman "${BUILD_OBJ_DIR}/suite/app/${PN}.1" |
463 |
+ |
464 |
+ # revdep-rebuild entry |
465 |
+ insinto /etc/revdep-rebuild |
466 |
+ echo "SEARCH_DIRS_MASK=${MOZILLA_FIVE_HOME}*" >> ${T}/11${PN} |
467 |
+ doins "${T}"/11${PN} |
468 |
+} |
469 |
+ |
470 |
+pkg_preinst() { |
471 |
+ MOZILLA_FIVE_HOME="${ROOT}/usr/$(get_libdir)/${PN}" |
472 |
+ |
473 |
+ if [ -d ${MOZILLA_FIVE_HOME}/plugins ] ; then |
474 |
+ rm ${MOZILLA_FIVE_HOME}/plugins -rf |
475 |
+ fi |
476 |
+} |
477 |
+ |
478 |
+pkg_postinst() { |
479 |
+ MOZILLA_FIVE_HOME="/usr/$(get_libdir)/${PN}" |
480 |
+ |
481 |
+ # Update mimedb for the new .desktop file |
482 |
+ fdo-mime_desktop_database_update |
483 |
+ |
484 |
+ if use chatzilla ; then |
485 |
+ elog "chatzilla is now an extension which can be en-/disabled and configured via" |
486 |
+ elog "the Add-on manager." |
487 |
+ fi |
488 |
+} |