1 |
commit: 6b0d441066a018f166e97f3d8b23f624d390a59e |
2 |
Author: Thomas Deutschmann <whissi <AT> gentoo <DOT> org> |
3 |
AuthorDate: Mon Jul 12 23:28:39 2021 +0000 |
4 |
Commit: Thomas Deutschmann <whissi <AT> gentoo <DOT> org> |
5 |
CommitDate: Mon Jul 12 23:32:23 2021 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6b0d4410 |
7 |
|
8 |
dev-lang/spidermonkey: bump to v78.12.0 |
9 |
|
10 |
Closes: https://bugs.gentoo.org/793920 |
11 |
Package-Manager: Portage-3.0.21, Repoman-3.0.3 |
12 |
Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org> |
13 |
|
14 |
dev-lang/spidermonkey/Manifest | 2 + |
15 |
dev-lang/spidermonkey/spidermonkey-78.12.0.ebuild | 454 ++++++++++++++++++++++ |
16 |
2 files changed, 456 insertions(+) |
17 |
|
18 |
diff --git a/dev-lang/spidermonkey/Manifest b/dev-lang/spidermonkey/Manifest |
19 |
index 0a82e536c8e..62e6fa2f0ed 100644 |
20 |
--- a/dev-lang/spidermonkey/Manifest |
21 |
+++ b/dev-lang/spidermonkey/Manifest |
22 |
@@ -2,8 +2,10 @@ DIST firefox-68.0-patches-15.tar.xz 16060 BLAKE2B f9e6cd58ea51bed1af90a9d30fd551 |
23 |
DIST firefox-68.12.0esr.source.tar.xz 313856956 BLAKE2B eeaa4acc9fabf15ec1b313170a30cee8e1fc10a8b08512b915b83b7d6a81c09b365733ed94638bd434864fd7b0cb8cbf1bc2e43441be69e31117e8e6a099234c SHA512 839b02422e4c87bdb12e0995cd35ca8c1996f3fba00bbb46b419e46b67df5ec48a264cb14632db777ce29166ee4fdcb06e2ee3ce847e64328c58c9a2f9129f4c |
24 |
DIST firefox-78.10.1esr.source.tar.xz 334444960 BLAKE2B 76f9bae7f9fddbf3ab14293d1ec9e51b173961d0d5e0e1ef98b65328294f520369b89fb300a91d9f502b93215a15c228925a469b7b14ec576c9a9be874a6561a SHA512 a22773d9b3f0dca253805257f358a906769d23f15115e3a8851024f701e27dee45f056f7d34ebf1fcde0a3f91ec299639c2a12556e938a232cdea9e59835fde1 |
25 |
DIST firefox-78.11.0esr.source.tar.xz 333002576 BLAKE2B a8268886f86afb41b86d227f8a8f642674ea9c0a85365acb517c6997099dbddad9779efa772cce645da6443a78d6e94c89a750152386f8dff7bbbf31bf5df129 SHA512 d02fc2eda587155b1c54ca12a6c5cde220a29f41f154f1c9b71ae8f966d8cc9439201a5b241e03fc0795b74e2479f7aa5d6b69f70b7639432e5382f321f7a6f4 |
26 |
+DIST firefox-78.12.0esr.source.tar.xz 333737488 BLAKE2B 775a55511a48f4210807d2648833bca6f95d9f4cd48b5d0de8cf0bf2609590c1615fca7ff855ae3643a25466d131e15dc293e6a57aa05e1d91d2cf819b0b89ca SHA512 646eb803e0d0e541773e3111708c7eaa85e784e4bae6e4a77dcecdc617ee29e2e349c9ef16ae7e663311734dd7491aebd904359124dda62672dbc18bfb608f0a |
27 |
DIST firefox-78esr-patches-13.tar.xz 83664 BLAKE2B 92250d5bc3821ee1ff032236bd00e01a53e0af4f9e39696a634edb39f0a182bf5ff74b7fc0f107c9c53136c64485c398391e3a857c8b2b904115fd13d17e2a4f SHA512 96739811bea833a6a9cb09075dfe49c6fa7f613e8bd41e1d830d6ae6851ce8e2f5d27c87d0035b6f3a099340dfd7eebe6ecb930ff25079e76cea92a7610293ca |
28 |
DIST firefox-78esr-patches-14.tar.xz 82976 BLAKE2B 08cc3618c8069f4169b7647e7eb699153d558bb89f8a4f1ed74d5ccd339f77119cd8f253df011f0c2f255ad889b65e843171d7559f469788463ca7e9aa2e96aa SHA512 1611c6f9d2c7d586e7b53810c1cfdb2682f5d289b1b019b71694b1ab2d8bbdfe827a73cfaf59f7e4808c0b90409ca4fa57e27655d8cdf0c578ffdbad33659f26 |
29 |
+DIST firefox-78esr-patches-15.tar.xz 65604 BLAKE2B 86e421e555ffd5f7f201d0f1a1c446c649739c67cdf8dca536efa115e09d9c357ce1551b7270c77e8bfe7dd53e0f3e6386496283879cf5e0c59b3c864951ebb3 SHA512 b229e895f083a0404cda1da0d8ae937429d5975ac52ab20e8b15611d9c737381a1076ebfa8c8a127dacac0e12a2a905ffd579facde2d80c6facc911e5739e34b |
30 |
DIST js185-1.0.0.tar.gz 6164605 BLAKE2B 76a37f0ceae05d3475853875bd0ce4be6e525e4114816f8f281ea6fc6b60a71060975a0fa1cb843f57ad1e2f842dfb26b24244fa0fd6c20f6ae2ebbe430f70be SHA512 2af7122a7c7007fd7b6668776fe1222515a810b3e43bbf0f76b8f94e1ef406ffd3fb5ccec393021b00274c05b38a77235bc8d6886994c56762fcaf0aa7cf6718 |
31 |
DIST mozjs-52.9.1pre1.tar.bz2 30178574 BLAKE2B 0920432b5140e78297a9bcbccb54268d75a223d5e75e4ff90b3b01aab4f7736b4a4e05c47b3a925ff0a74607a0abad3b6583c75d070ef5142009b20ebaf6e4bf SHA512 187b231b246a5ae09e55c0fef77866b316d75f38f4c2e066d5d4325d8da63433027020c929439cab46af3253ac63ab2f780223a8fd2c6ff535b3409bb6c4aa0f |
32 |
DIST mozjs-60.5.2.tar.bz2 32816585 BLAKE2B 45ac4c9646e1275faf60eeedbf486f802cd106583eb7f640fe2243adc7cbb811dced5cefa94426cceca63468b0112be84078ffcef24cb2b8c1a7b6c8173c0d45 SHA512 5fb73330e7803bdd524fbe7cfdf4e6b72e85d4b22b0c827400317b5d052d1088d36e558ceac376393089e9d03e658b24e69262851fc04a66bbcda47135423dc0 |
33 |
|
34 |
diff --git a/dev-lang/spidermonkey/spidermonkey-78.12.0.ebuild b/dev-lang/spidermonkey/spidermonkey-78.12.0.ebuild |
35 |
new file mode 100644 |
36 |
index 00000000000..3d1bee7e161 |
37 |
--- /dev/null |
38 |
+++ b/dev-lang/spidermonkey/spidermonkey-78.12.0.ebuild |
39 |
@@ -0,0 +1,454 @@ |
40 |
+# Copyright 1999-2021 Gentoo Authors |
41 |
+# Distributed under the terms of the GNU General Public License v2 |
42 |
+ |
43 |
+EAPI="7" |
44 |
+ |
45 |
+# Patch version |
46 |
+FIREFOX_PATCHSET="firefox-78esr-patches-15.tar.xz" |
47 |
+SPIDERMONKEY_PATCHSET="spidermonkey-78-patches-04.tar.xz" |
48 |
+ |
49 |
+LLVM_MAX_SLOT=12 |
50 |
+ |
51 |
+PYTHON_COMPAT=( python3_{7..9} ) |
52 |
+ |
53 |
+WANT_AUTOCONF="2.1" |
54 |
+ |
55 |
+inherit autotools check-reqs flag-o-matic llvm multiprocessing prefix python-any-r1 toolchain-funcs |
56 |
+ |
57 |
+MY_PN="mozjs" |
58 |
+MY_PV="${PV/_pre*}" # Handle Gentoo pre-releases |
59 |
+ |
60 |
+MY_MAJOR=$(ver_cut 1) |
61 |
+ |
62 |
+MOZ_ESR=yes |
63 |
+ |
64 |
+MOZ_PV=${PV} |
65 |
+MOZ_PV_SUFFIX= |
66 |
+if [[ ${PV} =~ (_(alpha|beta|rc).*)$ ]] ; then |
67 |
+ MOZ_PV_SUFFIX=${BASH_REMATCH[1]} |
68 |
+ |
69 |
+ # Convert the ebuild version to the upstream Mozilla version |
70 |
+ MOZ_PV="${MOZ_PV/_alpha/a}" # Handle alpha for SRC_URI |
71 |
+ MOZ_PV="${MOZ_PV/_beta/b}" # Handle beta for SRC_URI |
72 |
+ MOZ_PV="${MOZ_PV%%_rc*}" # Handle rc for SRC_URI |
73 |
+fi |
74 |
+ |
75 |
+if [[ -n ${MOZ_ESR} ]] ; then |
76 |
+ # ESR releases have slightly different version numbers |
77 |
+ MOZ_PV="${MOZ_PV}esr" |
78 |
+fi |
79 |
+ |
80 |
+MOZ_PN="firefox" |
81 |
+MOZ_P="${MOZ_PN}-${MOZ_PV}" |
82 |
+MOZ_PV_DISTFILES="${MOZ_PV}${MOZ_PV_SUFFIX}" |
83 |
+MOZ_P_DISTFILES="${MOZ_PN}-${MOZ_PV_DISTFILES}" |
84 |
+ |
85 |
+MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/releases/${MOZ_PV}" |
86 |
+ |
87 |
+if [[ ${PV} == *_rc* ]] ; then |
88 |
+ MOZ_SRC_BASE_URI="https://archive.mozilla.org/pub/${MOZ_PN}/candidates/${MOZ_PV}-candidates/build${PV##*_rc}" |
89 |
+fi |
90 |
+ |
91 |
+PATCH_URIS=( |
92 |
+ https://dev.gentoo.org/~{whissi,polynomial-c,axs}/mozilla/patchsets/${FIREFOX_PATCHSET} |
93 |
+ https://dev.gentoo.org/~{whissi,polynomial-c,axs}/mozilla/patchsets/${SPIDERMONKEY_PATCHSET} |
94 |
+) |
95 |
+ |
96 |
+SRC_URI="${MOZ_SRC_BASE_URI}/source/${MOZ_P}.source.tar.xz -> ${MOZ_P_DISTFILES}.source.tar.xz |
97 |
+ ${PATCH_URIS[@]}" |
98 |
+ |
99 |
+DESCRIPTION="SpiderMonkey is Mozilla's JavaScript engine written in C and C++" |
100 |
+HOMEPAGE="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey" |
101 |
+ |
102 |
+KEYWORDS="~amd64 ~arm ~arm64 ~mips ~ppc64 ~riscv ~s390 ~x86" |
103 |
+ |
104 |
+SLOT="78" |
105 |
+LICENSE="MPL-2.0" |
106 |
+IUSE="clang cpu_flags_arm_neon debug +jit lto test" |
107 |
+ |
108 |
+RESTRICT="!test? ( test )" |
109 |
+ |
110 |
+BDEPEND="${PYTHON_DEPS} |
111 |
+ >=virtual/rust-1.41.0 |
112 |
+ virtual/pkgconfig |
113 |
+ || ( |
114 |
+ ( |
115 |
+ sys-devel/llvm:12 |
116 |
+ clang? ( |
117 |
+ sys-devel/clang:12 |
118 |
+ lto? ( =sys-devel/lld-12* ) |
119 |
+ ) |
120 |
+ ) |
121 |
+ ( |
122 |
+ sys-devel/llvm:11 |
123 |
+ clang? ( |
124 |
+ sys-devel/clang:11 |
125 |
+ lto? ( =sys-devel/lld-11* ) |
126 |
+ ) |
127 |
+ ) |
128 |
+ ( |
129 |
+ sys-devel/llvm:10 |
130 |
+ clang? ( |
131 |
+ sys-devel/clang:10 |
132 |
+ lto? ( =sys-devel/lld-10* ) |
133 |
+ ) |
134 |
+ ) |
135 |
+ ) |
136 |
+ lto? ( |
137 |
+ !clang? ( sys-devel/binutils[gold] ) |
138 |
+ )" |
139 |
+ |
140 |
+CDEPEND=">=dev-libs/icu-67.1:= |
141 |
+ >=dev-libs/nspr-4.25 |
142 |
+ sys-libs/readline:0= |
143 |
+ >=sys-libs/zlib-1.2.3" |
144 |
+ |
145 |
+DEPEND="${CDEPEND} |
146 |
+ test? ( |
147 |
+ $(python_gen_any_dep 'dev-python/six[${PYTHON_USEDEP}]') |
148 |
+ )" |
149 |
+ |
150 |
+RDEPEND="${CDEPEND}" |
151 |
+ |
152 |
+S="${WORKDIR}/firefox-${MY_PV}/js/src" |
153 |
+ |
154 |
+llvm_check_deps() { |
155 |
+ if ! has_version -b "sys-devel/llvm:${LLVM_SLOT}" ; then |
156 |
+ ewarn "sys-devel/llvm:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 |
157 |
+ return 1 |
158 |
+ fi |
159 |
+ |
160 |
+ if use clang ; then |
161 |
+ if ! has_version -b "sys-devel/clang:${LLVM_SLOT}" ; then |
162 |
+ ewarn "sys-devel/clang:${LLVM_SLOT} is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 |
163 |
+ return 1 |
164 |
+ fi |
165 |
+ |
166 |
+ if use lto ; then |
167 |
+ if ! has_version -b "=sys-devel/lld-${LLVM_SLOT}*" ; then |
168 |
+ ewarn "=sys-devel/lld-${LLVM_SLOT}* is missing! Cannot use LLVM slot ${LLVM_SLOT} ..." >&2 |
169 |
+ return 1 |
170 |
+ fi |
171 |
+ fi |
172 |
+ fi |
173 |
+ |
174 |
+ einfo "Using LLVM slot ${LLVM_SLOT} to build" >&2 |
175 |
+} |
176 |
+ |
177 |
+python_check_deps() { |
178 |
+ if use test ; then |
179 |
+ has_version "dev-python/six[${PYTHON_USEDEP}]" |
180 |
+ fi |
181 |
+} |
182 |
+ |
183 |
+pkg_pretend() { |
184 |
+ if use test ; then |
185 |
+ CHECKREQS_DISK_BUILD="7600M" |
186 |
+ else |
187 |
+ CHECKREQS_DISK_BUILD="6400M" |
188 |
+ fi |
189 |
+ |
190 |
+ check-reqs_pkg_pretend |
191 |
+} |
192 |
+ |
193 |
+pkg_setup() { |
194 |
+ if [[ ${MERGE_TYPE} != binary ]] ; then |
195 |
+ if use test ; then |
196 |
+ CHECKREQS_DISK_BUILD="7600M" |
197 |
+ else |
198 |
+ CHECKREQS_DISK_BUILD="6400M" |
199 |
+ fi |
200 |
+ |
201 |
+ check-reqs_pkg_setup |
202 |
+ |
203 |
+ llvm_pkg_setup |
204 |
+ |
205 |
+ if use clang && use lto ; then |
206 |
+ local version_lld=$(ld.lld --version 2>/dev/null | awk '{ print $2 }') |
207 |
+ [[ -n ${version_lld} ]] && version_lld=$(ver_cut 1 "${version_lld}") |
208 |
+ [[ -z ${version_lld} ]] && die "Failed to read ld.lld version!" |
209 |
+ |
210 |
+ # temp fix for https://bugs.gentoo.org/768543 |
211 |
+ # we can assume that rust 1.{49,50}.0 always uses llvm 11 |
212 |
+ local version_rust=$(rustc -Vv 2>/dev/null | grep -F -- 'release:' | awk '{ print $2 }') |
213 |
+ [[ -n ${version_rust} ]] && version_rust=$(ver_cut 1-2 "${version_rust}") |
214 |
+ [[ -z ${version_rust} ]] && die "Failed to read version from rustc!" |
215 |
+ |
216 |
+ if ver_test "${version_rust}" -ge "1.49" && ver_test "${version_rust}" -le "1.50" ; then |
217 |
+ local version_llvm_rust="11" |
218 |
+ else |
219 |
+ local version_llvm_rust=$(rustc -Vv 2>/dev/null | grep -F -- 'LLVM version:' | awk '{ print $3 }') |
220 |
+ [[ -n ${version_llvm_rust} ]] && version_llvm_rust=$(ver_cut 1 "${version_llvm_rust}") |
221 |
+ [[ -z ${version_llvm_rust} ]] && die "Failed to read used LLVM version from rustc!" |
222 |
+ fi |
223 |
+ |
224 |
+ if ver_test "${version_lld}" -ne "${version_llvm_rust}" ; then |
225 |
+ eerror "Rust is using LLVM version ${version_llvm_rust} but ld.lld version belongs to LLVM version ${version_lld}." |
226 |
+ eerror "You will be unable to link ${CATEGORY}/${PN}. To proceed you have the following options:" |
227 |
+ eerror " - Manually switch rust version using 'eselect rust' to match used LLVM version" |
228 |
+ eerror " - Switch to dev-lang/rust[system-llvm] which will guarantee matching version" |
229 |
+ eerror " - Build ${CATEGORY}/${PN} without USE=lto" |
230 |
+ die "LLVM version used by Rust (${version_llvm_rust}) does not match with ld.lld version (${version_lld})!" |
231 |
+ fi |
232 |
+ fi |
233 |
+ |
234 |
+ python-any-r1_pkg_setup |
235 |
+ |
236 |
+ # Build system is using /proc/self/oom_score_adj, bug #604394 |
237 |
+ addpredict /proc/self/oom_score_adj |
238 |
+ |
239 |
+ if ! mountpoint -q /dev/shm ; then |
240 |
+ # If /dev/shm is not available, configure is known to fail with |
241 |
+ # a traceback report referencing /usr/lib/pythonN.N/multiprocessing/synchronize.py |
242 |
+ ewarn "/dev/shm is not mounted -- expect build failures!" |
243 |
+ fi |
244 |
+ |
245 |
+ # Ensure we use C locale when building, bug #746215 |
246 |
+ export LC_ALL=C |
247 |
+ fi |
248 |
+} |
249 |
+ |
250 |
+src_prepare() { |
251 |
+ pushd ../.. &>/dev/null || die |
252 |
+ |
253 |
+ use lto && rm -v "${WORKDIR}"/firefox-patches/*-LTO-Only-enable-LTO-*.patch |
254 |
+ |
255 |
+ eapply "${WORKDIR}"/firefox-patches |
256 |
+ eapply "${WORKDIR}"/spidermonkey-patches |
257 |
+ |
258 |
+ default |
259 |
+ |
260 |
+ # Make LTO respect MAKEOPTS |
261 |
+ sed -i \ |
262 |
+ -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \ |
263 |
+ build/moz.configure/lto-pgo.configure \ |
264 |
+ || die "sed failed to set num_cores" |
265 |
+ |
266 |
+ # sed-in toolchain prefix |
267 |
+ sed -i \ |
268 |
+ -e "s/objdump/${CHOST}-objdump/" \ |
269 |
+ python/mozbuild/mozbuild/configure/check_debug_ranges.py \ |
270 |
+ || die "sed failed to set toolchain prefix" |
271 |
+ |
272 |
+ # use prefix shell in wrapper linker scripts, bug #789660 |
273 |
+ hprefixify "${S}"/../../build/cargo-{,host-}linker |
274 |
+ |
275 |
+ einfo "Removing pre-built binaries ..." |
276 |
+ find third_party -type f \( -name '*.so' -o -name '*.o' \) -print -delete || die |
277 |
+ |
278 |
+ MOZJS_BUILDDIR="${WORKDIR}/build" |
279 |
+ mkdir "${MOZJS_BUILDDIR}" || die |
280 |
+ |
281 |
+ popd &>/dev/null || die |
282 |
+ eautoconf |
283 |
+} |
284 |
+ |
285 |
+src_configure() { |
286 |
+ # Show flags set at the beginning |
287 |
+ einfo "Current CFLAGS: ${CFLAGS}" |
288 |
+ einfo "Current CXXFLAGS: ${CXXFLAGS}" |
289 |
+ einfo "Current LDFLAGS: ${LDFLAGS}" |
290 |
+ einfo "Current RUSTFLAGS: ${RUSTFLAGS}" |
291 |
+ |
292 |
+ local have_switched_compiler= |
293 |
+ if use clang && ! tc-is-clang ; then |
294 |
+ # Force clang |
295 |
+ einfo "Enforcing the use of clang due to USE=clang ..." |
296 |
+ have_switched_compiler=yes |
297 |
+ AR=llvm-ar |
298 |
+ CC=${CHOST}-clang |
299 |
+ CXX=${CHOST}-clang++ |
300 |
+ NM=llvm-nm |
301 |
+ RANLIB=llvm-ranlib |
302 |
+ elif ! use clang && ! tc-is-gcc ; then |
303 |
+ # Force gcc |
304 |
+ have_switched_compiler=yes |
305 |
+ einfo "Enforcing the use of gcc due to USE=-clang ..." |
306 |
+ AR=gcc-ar |
307 |
+ CC=${CHOST}-gcc |
308 |
+ CXX=${CHOST}-g++ |
309 |
+ NM=gcc-nm |
310 |
+ RANLIB=gcc-ranlib |
311 |
+ fi |
312 |
+ |
313 |
+ if [[ -n "${have_switched_compiler}" ]] ; then |
314 |
+ # Because we switched active compiler we have to ensure |
315 |
+ # that no unsupported flags are set |
316 |
+ strip-unsupported-flags |
317 |
+ fi |
318 |
+ |
319 |
+ # Ensure we use correct toolchain |
320 |
+ export HOST_CC="$(tc-getBUILD_CC)" |
321 |
+ export HOST_CXX="$(tc-getBUILD_CXX)" |
322 |
+ tc-export CC CXX LD AR NM OBJDUMP RANLIB PKG_CONFIG |
323 |
+ |
324 |
+ cd "${MOZJS_BUILDDIR}" || die |
325 |
+ |
326 |
+ # ../python/mach/mach/mixin/process.py fails to detect SHELL |
327 |
+ export SHELL="${EPREFIX}/bin/bash" |
328 |
+ |
329 |
+ local -a myeconfargs=( |
330 |
+ --host="${CBUILD:-${CHOST}}" |
331 |
+ --target="${CHOST}" |
332 |
+ --disable-jemalloc |
333 |
+ --disable-optimize |
334 |
+ --disable-strip |
335 |
+ --enable-readline |
336 |
+ --enable-shared-js |
337 |
+ --with-intl-api |
338 |
+ --with-system-icu |
339 |
+ --with-system-nspr |
340 |
+ --with-system-zlib |
341 |
+ --with-toolchain-prefix="${CHOST}-" |
342 |
+ $(use_enable debug) |
343 |
+ $(use_enable jit) |
344 |
+ $(use_enable test tests) |
345 |
+ ) |
346 |
+ |
347 |
+ if ! use x86 && [[ ${CHOST} != armv*h* ]] ; then |
348 |
+ myeconfargs+=( --enable-rust-simd ) |
349 |
+ fi |
350 |
+ |
351 |
+ # Modifications to better support ARM, bug 717344 |
352 |
+ if use cpu_flags_arm_neon ; then |
353 |
+ myeconfargs+=( --with-fpu=neon ) |
354 |
+ |
355 |
+ if ! tc-is-clang ; then |
356 |
+ # thumb options aren't supported when using clang, bug 666966 |
357 |
+ myeconfargs+=( --with-thumb=yes ) |
358 |
+ myeconfargs+=( --with-thumb-interwork=no ) |
359 |
+ fi |
360 |
+ fi |
361 |
+ |
362 |
+ # Tell build system that we want to use LTO |
363 |
+ if use lto ; then |
364 |
+ myeconfargs+=( --enable-lto ) |
365 |
+ |
366 |
+ if use clang ; then |
367 |
+ myeconfargs+=( --enable-linker=lld ) |
368 |
+ else |
369 |
+ myeconfargs+=( --enable-linker=gold ) |
370 |
+ fi |
371 |
+ fi |
372 |
+ |
373 |
+ # LTO flag was handled via configure |
374 |
+ filter-flags '-flto*' |
375 |
+ |
376 |
+ if tc-is-gcc ; then |
377 |
+ if ver_test $(gcc-fullversion) -ge 10 ; then |
378 |
+ einfo "Forcing -fno-tree-loop-vectorize to workaround GCC bug, see bug 758446 ..." |
379 |
+ append-cxxflags -fno-tree-loop-vectorize |
380 |
+ fi |
381 |
+ fi |
382 |
+ |
383 |
+ # Show flags we will use |
384 |
+ einfo "Build CFLAGS: ${CFLAGS}" |
385 |
+ einfo "Build CXXFLAGS: ${CXXFLAGS}" |
386 |
+ einfo "Build LDFLAGS: ${LDFLAGS}" |
387 |
+ einfo "Build RUSTFLAGS: ${RUSTFLAGS}" |
388 |
+ |
389 |
+ # Forcing system-icu allows us to skip patching bundled ICU for PPC |
390 |
+ # and other minor arches |
391 |
+ ECONF_SOURCE="${S}" \ |
392 |
+ econf \ |
393 |
+ ${myeconfargs[@]} \ |
394 |
+ XARGS="${EPREFIX}/usr/bin/xargs" |
395 |
+} |
396 |
+ |
397 |
+src_compile() { |
398 |
+ cd "${MOZJS_BUILDDIR}" || die |
399 |
+ default |
400 |
+} |
401 |
+ |
402 |
+src_test() { |
403 |
+ if "${MOZJS_BUILDDIR}/js/src/js" -e 'print("Hello world!")'; then |
404 |
+ einfo "Smoke-test successful, continuing with full test suite" |
405 |
+ else |
406 |
+ die "Smoke-test failed: did interpreter initialization fail?" |
407 |
+ fi |
408 |
+ |
409 |
+ local -a KNOWN_TESTFAILURES |
410 |
+ KNOWN_TESTFAILURES+=( non262/Date/reset-time-zone-cache-same-offset.js ) |
411 |
+ KNOWN_TESTFAILURES+=( non262/Date/time-zone-path.js ) |
412 |
+ KNOWN_TESTFAILURES+=( non262/Date/time-zones-historic.js ) |
413 |
+ KNOWN_TESTFAILURES+=( non262/Date/time-zones-imported.js ) |
414 |
+ KNOWN_TESTFAILURES+=( non262/Date/toString-localized.js ) |
415 |
+ KNOWN_TESTFAILURES+=( non262/Date/toString-localized-posix.js ) |
416 |
+ KNOWN_TESTFAILURES+=( non262/Intl/Date/toLocaleString_timeZone.js ) |
417 |
+ KNOWN_TESTFAILURES+=( non262/Intl/Date/toLocaleDateString_timeZone.js ) |
418 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/format.js ) |
419 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/format_timeZone.js ) |
420 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/timeZone_backward_links.js ) |
421 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/tz-environment-variable.js ) |
422 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DisplayNames/language.js ) |
423 |
+ KNOWN_TESTFAILURES+=( non262/Intl/DisplayNames/region.js ) |
424 |
+ KNOWN_TESTFAILURES+=( non262/Intl/Locale/likely-subtags.js ) |
425 |
+ KNOWN_TESTFAILURES+=( non262/Intl/Locale/likely-subtags-generated.js ) |
426 |
+ KNOWN_TESTFAILURES+=( test262/intl402/Locale/prototype/minimize/removing-likely-subtags-first-adds-likely-subtags.js ) |
427 |
+ |
428 |
+ if use x86 ; then |
429 |
+ KNOWN_TESTFAILURES+=( non262/Date/timeclip.js ) |
430 |
+ KNOWN_TESTFAILURES+=( test262/built-ins/Number/prototype/toPrecision/return-values.js ) |
431 |
+ KNOWN_TESTFAILURES+=( test262/language/types/number/S8.5_A2.1.js ) |
432 |
+ KNOWN_TESTFAILURES+=( test262/language/types/number/S8.5_A2.2.js ) |
433 |
+ fi |
434 |
+ |
435 |
+ if [[ $(tc-endian) == "big" ]] ; then |
436 |
+ KNOWN_TESTFAILURES+=( test262/built-ins/TypedArray/prototype/set/typedarray-arg-set-values-same-buffer-other-type.js ) |
437 |
+ fi |
438 |
+ |
439 |
+ echo "" > "${T}"/known_failures.list || die |
440 |
+ |
441 |
+ local KNOWN_TESTFAILURE |
442 |
+ for KNOWN_TESTFAILURE in ${KNOWN_TESTFAILURES[@]} ; do |
443 |
+ echo "${KNOWN_TESTFAILURE}" >> "${T}"/known_failures.list |
444 |
+ done |
445 |
+ |
446 |
+ PYTHONPATH="${S}/tests/lib" \ |
447 |
+ ${PYTHON} \ |
448 |
+ "${S}"/tests/jstests.py -d -s -t 1800 --wpt=disabled --no-progress \ |
449 |
+ --exclude-file="${T}"/known_failures.list \ |
450 |
+ "${MOZJS_BUILDDIR}"/js/src/js \ |
451 |
+ || die |
452 |
+ |
453 |
+ if use jit ; then |
454 |
+ KNOWN_TESTFAILURES=() |
455 |
+ |
456 |
+ echo "" > "${T}"/known_failures.list || die |
457 |
+ |
458 |
+ for KNOWN_TESTFAILURE in ${KNOWN_TESTFAILURES[@]} ; do |
459 |
+ echo "${KNOWN_TESTFAILURE}" >> "${T}"/known_failures.list |
460 |
+ done |
461 |
+ |
462 |
+ PYTHONPATH="${S}/tests/lib" \ |
463 |
+ ${PYTHON} \ |
464 |
+ "${S}"/tests/jstests.py -d -s -t 1800 --wpt=disabled --no-progress \ |
465 |
+ --exclude-file="${T}"/known_failures.list \ |
466 |
+ "${MOZJS_BUILDDIR}"/js/src/js basic \ |
467 |
+ || die |
468 |
+ fi |
469 |
+} |
470 |
+ |
471 |
+src_install() { |
472 |
+ cd "${MOZJS_BUILDDIR}" || die |
473 |
+ default |
474 |
+ |
475 |
+ # fix soname links |
476 |
+ pushd "${ED}"/usr/$(get_libdir) &>/dev/null || die |
477 |
+ mv lib${MY_PN}-${MY_MAJOR}.so lib${MY_PN}-${MY_MAJOR}.so.0.0.0 || die |
478 |
+ ln -s lib${MY_PN}-${MY_MAJOR}.so.0.0.0 lib${MY_PN}-${MY_MAJOR}.so.0 || die |
479 |
+ ln -s lib${MY_PN}-${MY_MAJOR}.so.0 lib${MY_PN}-${MY_MAJOR}.so || die |
480 |
+ popd &>/dev/null || die |
481 |
+ |
482 |
+ # remove unneeded files |
483 |
+ rm \ |
484 |
+ "${ED}"/usr/bin/js${MY_MAJOR}-config \ |
485 |
+ "${ED}"/usr/$(get_libdir)/libjs_static.ajs \ |
486 |
+ || die |
487 |
+ |
488 |
+ # fix permissions |
489 |
+ chmod -x \ |
490 |
+ "${ED}"/usr/$(get_libdir)/pkgconfig/*.pc \ |
491 |
+ "${ED}"/usr/include/mozjs-${MY_MAJOR}/js-config.h \ |
492 |
+ || die |
493 |
+} |