commit:     555d549025e9803bdfba3ca2d75ee35ed75d6776
Author:     Ian Stakenvicius <axs <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 19 19:26:48 2017 +0000
Commit:     Ian Stakenvicius <axs <AT> gentoo <DOT> org>
CommitDate: Wed Jul 19 19:29:34 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=555d5490

dev-lang/spidermonkey: add development pre-release of 52.x

Requested by gnome project to support gjs for gnome-3.26

Package-Manager: Portage-2.3.6, Repoman-2.3.1

 dev-lang/spidermonkey/Manifest                     |   2 +
 .../spidermonkey-52.2.0_pre20170719.ebuild         | 138 +++++++++++++++++++++
 profiles/package.mask                              |   7 ++
 3 files changed, 147 insertions(+)

diff --git a/dev-lang/spidermonkey/Manifest b/dev-lang/spidermonkey/Manifest
index e6125e93b19..312f1709f4d 100644
--- a/dev-lang/spidermonkey/Manifest
+++ b/dev-lang/spidermonkey/Manifest
@@ -3,4 +3,6 @@ DIST js185-1.0.0.tar.gz 6164605 SHA256 
5d12f7e1f5b4a99436685d97b9b7b75f094d33580
 DIST mozjs-24.2.0.tar.bz2 15624530 SHA256 
e62f3f331ddd90df1e238c09d61a505c516fe9fd8c5c95336611d191d18437d8 SHA512 
49805e256f6fa797505c01b7596d5bb941ed7a2454862c52ed42ad48b5ae4540b777e77ed8da1b98c89f8622ed2c76052187983687008a4ff53594addb328df4
 WHIRLPOOL 
ea74d19c79b1a0fe407e2803900c49c23e8b76444fb4e20995072c3c59427e8df1895df04f2f4de779a1c58cd1166dd97aeaf7564350832011efe89dbcf9583e
 DIST mozjs-38.2.1.rc0.tar.bz2 25012381 SHA256 
01994c758174bc173bcf4960f05ecb4da21014f09641a63b2952bbf9eeaa8b5c SHA512 
60262c7619cc418569aec81775a671105acbc5bf372273828868f2fbbbc4ea33f78380f7455710816bfcdae828fb4115a08234d599cb30d0db859fcba17f019d
 WHIRLPOOL 
b1661859dc41a61317a48a8ee34cab53a369f37067c6565db2c890c596411e51981e0e64f81c5f5bd2bc2ff943493d972b00a5984b99de6e07ce16c07f784cb7
 DIST mozjs-45.0.2.tar.bz2 97508152 SHA256 
570530b1e551bf4a459d7cae875f33f99d5ef0c29ccc7742a1b6f588e5eadbee SHA512 
84a3cf12e2603e00bcfe518a1a5000f53b21758c1c6b32a0410e63ab7db8d4452028195b0ba3e56144054b06e90f8e5195b4db94dba711f7c75d11da99c6c61d
 WHIRLPOOL 
dba2f7d4778f47f6476c3dd2e658a5b39ff9e571d4e71fe2508d58910a0989c24f892cbc7cc64aa7c94692cf947eb1a545fd0752bb5d8aace12c2dc96404c114
+DIST mozjs-52.2.0_pre20170719.tar.bz2 30630133 SHA256 
2bab92b432ecbe665616440594463abfb21ce3aff573f360f19ef0cce8ce4c77 SHA512 
9657006e071bdf0b6006ab806949eb8371f4d749989d95a3a46da0baedfe669727ccd6430c2022a4ec5ce2bb9cd9a231aba85605de1319a5c678633f0001a78c
 WHIRLPOOL 
14db035ad690b416b793df34a065ddf5096e43346f5a0462cf79605f1745fa18f7f578ae46b0eadeeef3fb7369e76f812c4cdfe227b1442d277fd80625998c52
 DIST mozjs17.0.0.tar.gz 6778934 SHA256 
321e964fe9386785d3bf80870640f2fa1c683e32fe988eeb201b04471c172fba SHA512 
39b68aeb9f712f146778d8b68ee795709a1372c8ab893a222af4eb34882427d6f5cf877e743d6cb2f1b4348c194d8f3774f00cb775b03515b34b49560b748be4
 WHIRLPOOL 
4df7b51577787194065162b09d2c3dda849c13fa901305f9925d4ca5d38bb7f8e2daa943099e003fb9d11f9264ae2d77ccf04e5eea11e3ddcb624b504b99d52f
+DIST spidermonkey-52.0-patches-0.tar.xz 5172 SHA256 
20165c0fbf5d441cea6217a7a6dca8b8623b5dbba2496eb769aaef3ca93647bf SHA512 
88ad640fb0efa4972f1b7782bd0abee1751b73914ee51faade93b25c4d8eec64e7693898842a406c49fc2ab43733404efeccb138afb64d2193b9a5eb612578e3
 WHIRLPOOL 
bd9f264d54bfd14ad9f339229a29a66f873d2ae66fbbc55edd4ae80135f08c6cd4a5e9c5ab65254749ecbafb7c8fdaa5c5936275e263e53ce47ab606d143114c

diff --git a/dev-lang/spidermonkey/spidermonkey-52.2.0_pre20170719.ebuild 
b/dev-lang/spidermonkey/spidermonkey-52.2.0_pre20170719.ebuild
new file mode 100644
index 00000000000..68a046e61da
--- /dev/null
+++ b/dev-lang/spidermonkey/spidermonkey-52.2.0_pre20170719.ebuild
@@ -0,0 +1,138 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+WANT_AUTOCONF="2.1"
+inherit autotools toolchain-funcs pax-utils mozcoreconf-v5
+
+MY_PN="mozjs"
+MY_P="${MY_PN}-${PV/_rc/.rc}"
+DESCRIPTION="Stand-alone JavaScript C++ library"
+HOMEPAGE="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey";
+#SRC_URI="https://people.mozilla.org/~sfink/${MY_P}.tar.bz2";
+SRC_URI="https://dev.gentoo.org/~axs/distfiles/${MY_P}.tar.bz2
+       https://dev.gentoo.org/~axs/distfiles/${PN}-52.0-patches-0.tar.xz";
+
+LICENSE="NPL-1.1"
+SLOT="52"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc 
~x86 ~x86-fbsd"
+IUSE="debug +jit minimal +system-icu test"
+
+RESTRICT="ia64? ( test )"
+
+S="${WORKDIR}/${MY_P%.rc*}"
+S="${S%_pre*}"
+BUILDDIR="${S}/js/src"
+
+RDEPEND=">=dev-libs/nspr-4.13.1
+       virtual/libffi
+       sys-libs/readline:0=
+       >=sys-libs/zlib-1.2.3
+       system-icu? ( >=dev-libs/icu-58.1:= )"
+DEPEND="${RDEPEND}"
+
+pkg_setup(){
+       [[ ${MERGE_TYPE} == "binary" ]] || \
+               moz_pkgsetup
+}
+
+src_prepare() {
+       eapply "${WORKDIR}/${PN}"
+
+       eapply_user
+
+       if [[ ${CHOST} == *-freebsd* ]]; then
+               # Don't try to be smart, this does not work in cross-compile 
anyway
+               ln -sfn "${BUILDDIR}/config/Linux_All.mk" "${S}/config/$(uname 
-s)$(uname -r).mk" || die
+       fi
+
+       cd "${BUILDDIR}" || die
+       eautoconf old-configure.in
+       eautoconf
+
+       # there is a default config.cache that messes everything up
+       rm -f "${BUILDDIR}"/config.cache || die
+}
+
+src_configure() {
+       cd "${BUILDDIR}" || die
+
+       econf \
+               --enable-jemalloc \
+               --enable-readline \
+               --with-system-nspr \
+               --disable-optimize \
+               --with-intl-api \
+               $(use_with system-icu) \
+               $(use_enable debug) \
+               $(use_enable jit ion) \
+               $(use_enable test tests) \
+               XARGS="/usr/bin/xargs" \
+               SHELL="${SHELL:-${EPREFIX}/bin/bash}" \
+               CC="${CC}" CXX="${CXX}" LD="${LD}" AR="${AR}" RANLIB="${RANLIB}"
+}
+
+cross_make() {
+       emake \
+               CFLAGS="${BUILD_CFLAGS}" \
+               CXXFLAGS="${BUILD_CXXFLAGS}" \
+               AR="${BUILD_AR}" \
+               CC="${BUILD_CC}" \
+               CXX="${BUILD_CXX}" \
+               RANLIB="${BUILD_RANLIB}" \
+               "$@"
+}
+src_compile() {
+       cd "${BUILDDIR}" || die
+       if tc-is-cross-compiler; then
+               tc-export_build_env BUILD_{AR,CC,CXX,RANLIB}
+               cross_make \
+                       MOZ_OPTIMIZE_FLAGS="" MOZ_DEBUG_FLAGS="" \
+                       HOST_OPTIMIZE_FLAGS="" MODULE_OPTIMIZE_FLAGS="" \
+                       MOZ_PGO_OPTIMIZE_FLAGS="" \
+                       host_jsoplengen host_jskwgen
+               cross_make \
+                       MOZ_OPTIMIZE_FLAGS="" MOZ_DEBUG_FLAGS="" 
HOST_OPTIMIZE_FLAGS="" \
+                       -C config nsinstall
+               mv {,native-}host_jskwgen || die
+               mv {,native-}host_jsoplengen || die
+               mv config/{,native-}nsinstall || die
+               sed -i \
+                       -e 's@./host_jskwgen@./native-host_jskwgen@' \
+                       -e 's@./host_jsoplengen@./native-host_jsoplengen@' \
+                       Makefile || die
+               sed -i -e 's@/nsinstall@/native-nsinstall@' config/config.mk || 
die
+               rm -f config/host_nsinstall.o \
+                       config/host_pathsub.o \
+                       host_jskwgen.o \
+                       host_jsoplengen.o || die
+       fi
+
+       MOZ_MAKE_FLAGS="${MAKEOPTS}" \
+       emake \
+               MOZ_OPTIMIZE_FLAGS="" MOZ_DEBUG_FLAGS="" \
+               HOST_OPTIMIZE_FLAGS="" MODULE_OPTIMIZE_FLAGS="" \
+               MOZ_PGO_OPTIMIZE_FLAGS=""
+}
+
+src_test() {
+       cd "${BUILDDIR}/js/src/jsapi-tests" || die
+       ./jsapi-tests || die
+}
+
+src_install() {
+       cd "${BUILDDIR}" || die
+       emake DESTDIR="${D}" install
+
+       if ! use minimal; then
+               if use jit; then
+                       pax-mark m "${ED}"usr/bin/js${SLOT}
+               fi
+       else
+               rm -f "${ED}"usr/bin/js${SLOT}
+       fi
+
+       # We can't actually disable building of static libraries
+       # They're used by the tests and in a few other places
+       find "${D}" -iname '*.a' -o -iname '*.ajs' -delete || die
+}

diff --git a/profiles/package.mask b/profiles/package.mask
index 72e70751743..ebc1d58dccc 100644
--- a/profiles/package.mask
+++ b/profiles/package.mask
@@ -29,6 +29,13 @@
 
 #--- END OF EXAMPLES ---
 
+# Ian Stakenvicius <[email protected]> (19 Jul 2017)
+# Mask spidermonkey:52 as it is a self-rolled release, no official
+# release has been rolled.  Is only committed to support development
+# versions of gjs.  Will unmask when gnome-3.26 is ready for testing
+# or when upstream releases an official tarball.
+dev-lang/spidermonkey:52
+
 # Matt Turner <[email protected]> (16 Jul 2017)
 # Header package for removed x11-libs/libXevie. No dependencies. Removal in a
 # month (#615314)

Reply via email to