Gentoo Archives: gentoo-commits

From: Thomas Deutschmann <whissi@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-lang/spidermonkey/
Date: Wed, 07 Oct 2020 01:03:42
Message-Id: 1602032611.5533d1d37ba15705b6b1ca7d747c2676911a032d.whissi@gentoo
1 commit: 5533d1d37ba15705b6b1ca7d747c2676911a032d
2 Author: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
3 AuthorDate: Wed Oct 7 00:59:21 2020 +0000
4 Commit: Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
5 CommitDate: Wed Oct 7 01:03:31 2020 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5533d1d3
7
8 dev-lang/spidermonkey: bump to v78.3.1
9
10 Package-Manager: Portage-3.0.8, Repoman-3.0.1
11 Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>
12
13 dev-lang/spidermonkey/Manifest | 1 +
14 dev-lang/spidermonkey/spidermonkey-78.3.1.ebuild | 267 +++++++++++++++++++++++
15 2 files changed, 268 insertions(+)
16
17 diff --git a/dev-lang/spidermonkey/Manifest b/dev-lang/spidermonkey/Manifest
18 index 540d0dd4f2a..3130949053d 100644
19 --- a/dev-lang/spidermonkey/Manifest
20 +++ b/dev-lang/spidermonkey/Manifest
21 @@ -2,6 +2,7 @@ DIST firefox-68.0-patches-15.tar.xz 16060 BLAKE2B f9e6cd58ea51bed1af90a9d30fd551
22 DIST firefox-68.12.0esr.source.tar.xz 313856956 BLAKE2B eeaa4acc9fabf15ec1b313170a30cee8e1fc10a8b08512b915b83b7d6a81c09b365733ed94638bd434864fd7b0cb8cbf1bc2e43441be69e31117e8e6a099234c SHA512 839b02422e4c87bdb12e0995cd35ca8c1996f3fba00bbb46b419e46b67df5ec48a264cb14632db777ce29166ee4fdcb06e2ee3ce847e64328c58c9a2f9129f4c
23 DIST firefox-78.2.0esr.source.tar.xz 331996944 BLAKE2B bd16877d078de66a418ae114c534b26313f112b9e40ad5cf112fb07a4d7335dc47071ee6e959e3e4c179b95afbdc5ab9cda7cdefa96355dbbaf6b75c7805d171 SHA512 38f91a24634ce5d0c10340c9ac762071f8488f4bd7649bff9ed9cb1cbecda23e207b593118d38488810540e63be39d9c1c45c3b9a6acb477b6b2edf636e56d5b
24 DIST firefox-78.3.0esr.source.tar.xz 331073228 BLAKE2B 01f3d3c0b8b963dedfa89631c518225104c739637a8bf22c121e3a942fa0b1d1f8cf1c4c2edad2e823e0e3922f865cc8d3430c6fc9246deea855295eaff84a0e SHA512 89e12797429d99760b294e302d803432f533b7c2c10f1fcd3781b89b27ec9698173d4fbf1bfe7506186602daf6666c09152407ce5668fb5b7391e38b5566f2f2
25 +DIST firefox-78.3.1esr.source.tar.xz 339088596 BLAKE2B 27e594a23b111b937ed277ddafa99c07fa9ee003cbd6b7c6cbdc4428e54769ec9ec1961653c1ec127d7adf159ff8b3be08ebbdefb0d11f1ac21717ffde9461b3 SHA512 162860df8e4ef7322e91924bd4aae731a49dbd9829f02b306e4e5acc69c611f4a1e5727c3857b2f98e951745a3b1d8f550966105badc095205644d1ad7f5a340
26 DIST firefox-esr-78-patches-01.tar.xz 30808 BLAKE2B c3005a04233462c800ff0da7ba5e4f1e4d350c21e2642a93aa48637fcc19b8c0e97222669629a152ad6403652f83d4fdf3191b3c2741dca5327b101ef491d962 SHA512 7b2aba8dd4ff2f8ac3236ae95eec73aff3560e8f11f170f09b28ae2c7681dc0220ac63724a331dcc792c86e73145acee173a19bce5fcf995ba40ed5d067e1eff
27 DIST firefox-esr-78-patches-02.tar.xz 36288 BLAKE2B f177027ea550b4f41616c104865a4d1a99fa0a84ca431176b5191107f23b2fcdd8361ad97493d3182d01dfeb7f2805caf16725b8a81bf1f7847cf400f87018d6 SHA512 7eff0a4f5d2b4abcb0293877b3fe562b5fa2581f46b4905ff8ad839559049e4d903dcca4aad6a7196720cc7b3cd93ae88ca0093da51f70e56609faaadf646c78
28 DIST js185-1.0.0.tar.gz 6164605 BLAKE2B 76a37f0ceae05d3475853875bd0ce4be6e525e4114816f8f281ea6fc6b60a71060975a0fa1cb843f57ad1e2f842dfb26b24244fa0fd6c20f6ae2ebbe430f70be SHA512 2af7122a7c7007fd7b6668776fe1222515a810b3e43bbf0f76b8f94e1ef406ffd3fb5ccec393021b00274c05b38a77235bc8d6886994c56762fcaf0aa7cf6718
29
30 diff --git a/dev-lang/spidermonkey/spidermonkey-78.3.1.ebuild b/dev-lang/spidermonkey/spidermonkey-78.3.1.ebuild
31 new file mode 100644
32 index 00000000000..beec6244426
33 --- /dev/null
34 +++ b/dev-lang/spidermonkey/spidermonkey-78.3.1.ebuild
35 @@ -0,0 +1,267 @@
36 +# Copyright 1999-2020 Gentoo Authors
37 +# Distributed under the terms of the GNU General Public License v2
38 +
39 +EAPI="7"
40 +
41 +PYTHON_COMPAT=( python3_{6..9} )
42 +
43 +WANT_AUTOCONF="2.1"
44 +
45 +inherit autotools check-reqs multiprocessing python-any-r1 toolchain-funcs
46 +
47 +MY_PN="mozjs"
48 +MY_PV="${PV/_pre*}" # Handle Gentoo pre-releases
49 +
50 +MY_MAJOR=$(ver_cut 1)
51 +
52 +MOZ_ESR="1"
53 +
54 +# Convert the ebuild version to the upstream mozilla version
55 +MOZ_PV="${MY_PV/_alpha/a}" # Handle alpha for SRC_URI
56 +MOZ_PV="${MOZ_PV/_beta/b}" # Handle beta for SRC_URI
57 +MOZ_PV="${MOZ_PV%%_rc*}" # Handle rc for SRC_URI
58 +
59 +if [[ ${MOZ_ESR} == 1 ]] ; then
60 + # ESR releases have slightly different version numbers
61 + MOZ_PV="${MOZ_PV}esr"
62 +fi
63 +
64 +# Patch version
65 +FIREFOX_PATCHSET="firefox-esr-78-patches-02.tar.xz"
66 +SPIDERMONKEY_PATCHSET="spidermonkey-78-patches-01.tar.xz"
67 +
68 +MOZ_HTTP_URI="https://archive.mozilla.org/pub/firefox/releases"
69 +MOZ_SRC_URI="${MOZ_HTTP_URI}/${MOZ_PV}/source/firefox-${MOZ_PV}.source.tar.xz"
70 +
71 +if [[ "${PV}" == *_rc* ]]; then
72 + MOZ_HTTP_URI="https://archive.mozilla.org/pub/firefox/candidates/${MOZ_PV}-candidates/build${PV##*_rc}"
73 + MOZ_SRC_URI="${MOZ_HTTP_URI}/source/firefox-${MOZ_PV}.source.tar.xz"
74 +fi
75 +
76 +PATCH_URIS=(
77 + https://dev.gentoo.org/~{whissi,polynomial-c,axs}/mozilla/patchsets/${FIREFOX_PATCHSET}
78 + https://dev.gentoo.org/~{whissi,polynomial-c,axs}/mozilla/patchsets/${SPIDERMONKEY_PATCHSET}
79 +)
80 +
81 +SRC_URI="${MOZ_SRC_URI}
82 + ${PATCH_URIS[@]}"
83 +
84 +DESCRIPTION="SpiderMonkey is Mozilla's JavaScript engine written in C and C++"
85 +HOMEPAGE="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey"
86 +
87 +KEYWORDS="~amd64 ~arm ~arm64 ~mips ~ppc64 ~s390 ~x86"
88 +
89 +SLOT="78"
90 +LICENSE="MPL-2.0"
91 +IUSE="cpu_flags_arm_neon debug +jit test"
92 +
93 +RESTRICT="!test? ( test )"
94 +
95 +BDEPEND="${PYTHON_DEPS}
96 + sys-devel/llvm
97 + >=virtual/rust-1.41.0
98 + virtual/pkgconfig"
99 +
100 +CDEPEND=">=dev-libs/icu-67.1:=
101 + >=dev-libs/nspr-4.25
102 + sys-libs/readline:0=
103 + >=sys-libs/zlib-1.2.3"
104 +
105 +DEPEND="${CDEPEND}
106 + test? (
107 + $(python_gen_any_dep 'dev-python/six[${PYTHON_USEDEP}]')
108 + )"
109 +
110 +RDEPEND="${CDEPEND}"
111 +
112 +S="${WORKDIR}/firefox-${MY_PV}/js/src"
113 +
114 +python_check_deps() {
115 + if use test ; then
116 + has_version "dev-python/six[${PYTHON_USEDEP}]"
117 + fi
118 +}
119 +
120 +pkg_pretend() {
121 + if use test ; then
122 + CHECKREQS_DISK_BUILD="6400M"
123 + else
124 + CHECKREQS_DISK_BUILD="5600M"
125 + fi
126 +
127 + check-reqs_pkg_pretend
128 +}
129 +
130 +pkg_setup() {
131 + if use test ; then
132 + CHECKREQS_DISK_BUILD="6400M"
133 + else
134 + CHECKREQS_DISK_BUILD="5600M"
135 + fi
136 +
137 + check-reqs_pkg_setup
138 +
139 + python-any-r1_pkg_setup
140 +}
141 +
142 +src_prepare() {
143 + pushd ../.. &>/dev/null || die
144 +
145 + eapply "${WORKDIR}"/firefox-patches
146 + eapply "${WORKDIR}"/spidermonkey-patches
147 +
148 + default
149 +
150 + # Make LTO respect MAKEOPTS
151 + sed -i \
152 + -e "s/multiprocessing.cpu_count()/$(makeopts_jobs)/" \
153 + build/moz.configure/lto-pgo.configure \
154 + || die "sed failed to set num_cores"
155 +
156 + # sed-in toolchain prefix
157 + sed -i \
158 + -e "s/objdump/${CHOST}-objdump/" \
159 + python/mozbuild/mozbuild/configure/check_debug_ranges.py \
160 + || die "sed failed to set toolchain prefix"
161 +
162 + einfo "Removing pre-built binaries ..."
163 + find third_party -type f \( -name '*.so' -o -name '*.o' \) -print -delete || die
164 +
165 + MOZJS_BUILDDIR="${WORKDIR}/build"
166 + mkdir "${MOZJS_BUILDDIR}" || die
167 +
168 + popd &>/dev/null || die
169 + eautoconf
170 +}
171 +
172 +src_configure() {
173 + tc-export CC CXX LD AR RANLIB
174 +
175 + cd "${MOZJS_BUILDDIR}" || die
176 +
177 + # ../python/mach/mach/mixin/process.py fails to detect SHELL
178 + export SHELL="${EPREFIX}/bin/bash"
179 +
180 + local -a myeconfargs=(
181 + --host="${CBUILD:-${CHOST}}"
182 + --target="${CHOST}"
183 + --disable-jemalloc
184 + --disable-optimize
185 + --disable-strip
186 + --enable-readline
187 + --enable-shared-js
188 + --with-intl-api
189 + --with-system-icu
190 + --with-system-nspr
191 + --with-system-zlib
192 + --with-toolchain-prefix="${CHOST}-"
193 + $(use_enable debug)
194 + $(use_enable jit)
195 + $(use_enable test tests)
196 + )
197 +
198 + # Modifications to better support ARM, bug 717344
199 + if use cpu_flags_arm_neon ; then
200 + myeconfargs+=( --with-fpu=neon )
201 +
202 + if ! tc-is-clang ; then
203 + # thumb options aren't supported when using clang, bug 666966
204 + myeconfargs+=( --with-thumb=yes )
205 + myeconfargs+=( --with-thumb-interwork=no )
206 + fi
207 + fi
208 +
209 + # Forcing system-icu allows us to skip patching bundled ICU for PPC
210 + # and other minor arches
211 + ECONF_SOURCE="${S}" \
212 + econf \
213 + ${myeconfargs[@]} \
214 + XARGS="${EPREFIX}/usr/bin/xargs"
215 +}
216 +
217 +src_compile() {
218 + cd "${MOZJS_BUILDDIR}" || die
219 + default
220 +}
221 +
222 +src_test() {
223 + if "${MOZJS_BUILDDIR}/js/src/js" -e 'print("Hello world!")'; then
224 + einfo "Smoke-test successful, continuing with full test suite"
225 + else
226 + die "Smoke-test failed: did interpreter initialization fail?"
227 + fi
228 +
229 + local -a KNOWN_TESTFAILURES
230 + KNOWN_TESTFAILURES+=( non262/Date/reset-time-zone-cache-same-offset.js )
231 + KNOWN_TESTFAILURES+=( non262/Date/time-zone-path.js )
232 + KNOWN_TESTFAILURES+=( non262/Date/time-zones-historic.js )
233 + KNOWN_TESTFAILURES+=( non262/Date/time-zones-imported.js )
234 + KNOWN_TESTFAILURES+=( non262/Date/toString-localized.js )
235 + KNOWN_TESTFAILURES+=( non262/Date/toString-localized-posix.js )
236 + KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/timeZone_backward_links.js )
237 + KNOWN_TESTFAILURES+=( non262/Intl/DateTimeFormat/tz-environment-variable.js )
238 + KNOWN_TESTFAILURES+=( non262/Intl/Locale/likely-subtags.js )
239 + KNOWN_TESTFAILURES+=( test262/intl402/Locale/prototype/minimize/removing-likely-subtags-first-adds-likely-subtags.js )
240 +
241 + if use x86 ; then
242 + KNOWN_TESTFAILURES+=( non262/Date/timeclip.js )
243 + KNOWN_TESTFAILURES+=( test262/built-ins/Number/prototype/toPrecision/return-values.js )
244 + KNOWN_TESTFAILURES+=( test262/language/types/number/S8.5_A2.1.js )
245 + KNOWN_TESTFAILURES+=( test262/language/types/number/S8.5_A2.2.js )
246 + fi
247 +
248 + echo "" > "${T}"/known_failures.list || die
249 +
250 + local KNOWN_TESTFAILURE
251 + for KNOWN_TESTFAILURE in ${KNOWN_TESTFAILURES[@]} ; do
252 + echo "${KNOWN_TESTFAILURE}" >> "${T}"/known_failures.list
253 + done
254 +
255 + PYTHONPATH="${S}/tests/lib" \
256 + ${PYTHON} \
257 + "${S}"/tests/jstests.py -d -s -t 1800 --wpt=disabled --no-progress \
258 + --exclude-file="${T}"/known_failures.list \
259 + "${MOZJS_BUILDDIR}"/js/src/js \
260 + || die
261 +
262 + if use jit ; then
263 + KNOWN_TESTFAILURES=()
264 +
265 + echo "" > "${T}"/known_failures.list || die
266 +
267 + for KNOWN_TESTFAILURE in ${KNOWN_TESTFAILURES[@]} ; do
268 + echo "${KNOWN_TESTFAILURE}" >> "${T}"/known_failures.list
269 + done
270 +
271 + PYTHONPATH="${S}/tests/lib" \
272 + ${PYTHON} \
273 + "${S}"/tests/jstests.py -d -s -t 1800 --wpt=disabled --no-progress \
274 + --exclude-file="${T}"/known_failures.list \
275 + "${MOZJS_BUILDDIR}"/js/src/js basic \
276 + || die
277 + fi
278 +}
279 +
280 +src_install() {
281 + cd "${MOZJS_BUILDDIR}" || die
282 + default
283 +
284 + # fix soname links
285 + pushd "${ED}"/usr/$(get_libdir) &>/dev/null || die
286 + mv lib${MY_PN}-${MY_MAJOR}.so lib${MY_PN}-${MY_MAJOR}.so.0.0.0 || die
287 + ln -s lib${MY_PN}-${MY_MAJOR}.so.0.0.0 lib${MY_PN}-${MY_MAJOR}.so.0 || die
288 + ln -s lib${MY_PN}-${MY_MAJOR}.so.0 lib${MY_PN}-${MY_MAJOR}.so || die
289 + popd &>/dev/null || die
290 +
291 + # remove unneeded files
292 + rm \
293 + "${ED}"/usr/bin/js${MY_MAJOR}-config \
294 + "${ED}"/usr/$(get_libdir)/libjs_static.ajs \
295 + || die
296 +
297 + # fix permissions
298 + chmod -x \
299 + "${ED}"/usr/$(get_libdir)/pkgconfig/*.pc \
300 + "${ED}"/usr/include/mozjs-${MY_MAJOR}/js-config.h \
301 + || die
302 +}