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