commit:     e49a378b7f9858486f11805646d450aa22730f7e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  6 11:36:35 2016 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Jun  6 11:36:35 2016 +0000
URL:        https://gitweb.gentoo.org/dev/mgorny.git/commit/?id=e49a378b

dev-binpkg/pypy: Bump to 5.1.1

 dev-binpkg/pypy/Manifest          |   1 +
 dev-binpkg/pypy/pypy-5.1.1.ebuild | 191 ++++++++++++++++++++++++++++++++++++++
 2 files changed, 192 insertions(+)

diff --git a/dev-binpkg/pypy/Manifest b/dev-binpkg/pypy/Manifest
index c920f8c..15d699e 100644
--- a/dev-binpkg/pypy/Manifest
+++ b/dev-binpkg/pypy/Manifest
@@ -2,3 +2,4 @@ DIST pypy-2.6.0-src.tar.bz2 16858400 SHA256 
9bf353f22d25e97a85a6d3766619966055ed
 DIST pypy-4.0.0-src.tar.bz2 17244624 SHA256 
acff480e44ce92acd057f2e786775af36dc3c2cd12e9efc60a1ac6a562ad7b4d SHA512 
2bbdc2536a32b0aa28f7b12ec3d879ed28afe984fad38635bc3e1d950a9fe198cfbaf9b554f0fa245e7fd512ec7a76297f05a1d3e17f73fb49e8506561190f5b
 WHIRLPOOL 
e94bdf5e8ea2cbab8e25d37bb7cb36b9bae773ec051d603cfce784e0fd8e591ed16e6896f49d14d9ae094c5f613a0ba871380c8adc2a1cf0023157e3e2a51f52
 DIST pypy-4.0.1-src.tar.bz2 17172844 SHA256 
29f5aa6ba17b34fd980e85172dfeb4086fdc373ad392b1feff2677d2d8aea23c SHA512 
66358cc3fe9ccb402b717379c48731aca8f9f85a1a754a54e3a060113398955b87a3f3048ba731a93be4b49c0f5c7e3bac49dc4523263e1bf4f4b5149d5db5c4
 WHIRLPOOL 
656a6c60aeb26cb6355db121a92bafcf2b744a7f09dccf21b4a16052c0117d239891ccf6762fcb4fee7f913862263c589becd5984498edc4a8b6d55784957994
 DIST pypy-5.0.0-src.tar.bz2 17223494 SHA256 
89027b1b33553b53ff7733dc4838f0a76af23552c0d915d9f6de5875b8d7d4ab SHA512 
2af686cdad13a1083114a03a7361f58c4dd482e3a83a63b43f8d40922a11120383f91deb6f1607510c4bbd22fd8c59dcf1b58406c2e5cf5548a48542e1b20f89
 WHIRLPOOL 
61c9ada98e710019832cb6468e68c8b17e429e48f2ea0480371b2f04521bc77ab774a21dba2280bb40b97e528ad391a83d139bb839461899f9dc214d60683716
+DIST pypy-5.1.1-src.tar.bz2 17328934 SHA256 
ca3d943d7fbd78bb957ee9e5833ada4bb8506ac99a41b7628790e286a65ed2be SHA512 
2d81b62747ac02980c275fe24fff689e93b4b352e6279c55ca570fd76b8477a55f819e81fab4c6ffdb6991f29536c606d75e238d5bbe04518357509020f23ca9
 WHIRLPOOL 
17f78c8c7df9e07af3fce15392061652284606fbd872706888094ec01d222957c8ee43d2667369377ceb1a9720692d130e4a540bcaff269b4c7d8896b14d708d

diff --git a/dev-binpkg/pypy/pypy-5.1.1.ebuild 
b/dev-binpkg/pypy/pypy-5.1.1.ebuild
new file mode 100644
index 0000000..cff3eb2
--- /dev/null
+++ b/dev-binpkg/pypy/pypy-5.1.1.ebuild
@@ -0,0 +1,191 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+PYTHON_COMPAT=( python2_7 pypy )
+inherit check-reqs eutils multilib multiprocessing pax-utils python-any-r1 
toolchain-funcs versionator
+
+DESCRIPTION="A fast, compliant alternative implementation of the Python 
language"
+HOMEPAGE="http://pypy.org/";
+SRC_URI="https://bitbucket.org/pypy/pypy/downloads/${P}-src.tar.bz2";
+
+LICENSE="MIT"
+SLOT="0/$(get_version_component_range 1-2 ${PV})"
+KEYWORDS="~amd64 ~x86 ~amd64-linux ~x86-linux"
+IUSE="bzip2 +jit low-memory ncurses sandbox shadowstack sqlite 
cpu_flags_x86_sse2"
+
+DEPEND=">=sys-libs/zlib-1.1.3:0=
+       virtual/libffi:0=
+       virtual/libintl:0=
+       dev-libs/expat:0=
+       dev-libs/openssl:0=[-bindist]
+       bzip2? ( app-arch/bzip2:0= )
+       ncurses? ( sys-libs/ncurses:0= )
+       app-arch/xz-utils
+       ${PYTHON_DEPS}"
+
+S="${WORKDIR}/${P}-src"
+
+pkg_pretend() {
+       if use low-memory; then
+               if ! python_is_installed pypy; then
+                       eerror "USE=low-memory requires a (possibly old) 
version of dev-python/pypy"
+                       eerror "or dev-python/pypy-bin being installed. Please 
install it using e.g.:"
+                       eerror
+                       eerror "  $ emerge -1v dev-python/pypy-bin"
+                       eerror
+                       eerror "before attempting to build 
dev-python/pypy[low-memory]."
+                       die "dev-python/pypy-bin (or dev-python/pypy) needs to 
be installed for USE=low-memory"
+               fi
+
+               CHECKREQS_MEMORY="1750M"
+               use amd64 && CHECKREQS_MEMORY="3500M"
+       else
+               CHECKREQS_MEMORY="3G"
+               use amd64 && CHECKREQS_MEMORY="6G"
+       fi
+
+       check-reqs_pkg_pretend
+
+       [[ ${PYPY_BINPKG_STORE} ]] || die 'PYPY_BINPKG_STORE unset, wtf?!'
+}
+
+pkg_setup() {
+       pkg_pretend
+
+       if python_is_installed pypy; then
+               if [[ ! ${EPYTHON} || ${EPYTHON} == pypy ]] || use low-memory; 
then
+                       einfo "Using already-installed PyPy to perform the 
translation."
+                       local EPYTHON=pypy
+               else
+                       einfo "Using ${EPYTHON} to perform the translation. 
Please note that upstream"
+                       einfo "recommends using PyPy for that. If you wish to 
do so, please unset"
+                       einfo "the EPYTHON variable."
+               fi
+       fi
+
+       python-any-r1_pkg_setup
+
+       local cpu
+       if use amd64; then
+               # common denominator between Intel & AMD
+               cpu='x86-64'
+       elif use x86; then
+               if use cpu_flags_x86_sse2; then
+                       # lowest with SSE2
+                       cpu='pentium-m'
+               else
+                       # lowest with SSE, compat. with athlon-xp
+                       # TODO: do we want to support something older?
+                       cpu='pentium3'
+               fi
+       else
+               die "Unsupported arch ${ARCH}"
+       fi
+
+       export CFLAGS="-march=${cpu} -mtune=generic -O2 -pipe"
+       export CXXFLAGS=${CFLAGS}
+
+       elog "CFLAGS: ${CFLAGS}"
+}
+
+src_prepare() {
+       epatch "${FILESDIR}"/2.5.0-shared-lib.patch     # 517002
+
+       epatch_user
+}
+
+src_compile() {
+       tc-export CC
+
+       local jit_backend
+       if use jit; then
+               jit_backend='--jit-backend='
+
+               # We only need the explicit sse2 switch for x86.
+               # On other arches we can rely on autodetection which uses
+               # compiler macros. Plus, --jit-backend= doesn't accept all
+               # the modern values...
+
+               if use x86; then
+                       if use cpu_flags_x86_sse2; then
+                               jit_backend+=x86
+                       else
+                               jit_backend+=x86-without-sse2
+                       fi
+               else
+                       jit_backend+=auto
+               fi
+       fi
+
+       local args=(
+               --shared
+               $(usex jit -Ojit -O2)
+               $(usex shadowstack --gcrootfinder=shadowstack '')
+               $(usex sandbox --sandbox '')
+
+               ${jit_backend}
+               --make-jobs=$(makeopts_jobs)
+
+               pypy/goal/targetpypystandalone
+       )
+
+       # Avoid linking against libraries disabled by use flags
+       local opts=(
+               bzip2:bz2
+               ncurses:_minimal_curses
+       )
+
+       local opt
+       for opt in "${opts[@]}"; do
+               local flag=${opt%:*}
+               local mod=${opt#*:}
+
+               args+=(
+                       $(usex ${flag} --withmod --withoutmod)-${mod}
+               )
+       done
+
+       local interp=( "${PYTHON}" )
+       if use low-memory; then
+               interp=( env PYPY_GC_MAX_DELTA=200MB
+                       "${PYTHON}" --jit loop_longevity=300 )
+       fi
+
+       set -- "${interp[@]}" rpython/bin/rpython --batch "${args[@]}"
+       echo -e "\033[1m${@}\033[0m"
+       "${@}" || die "compile error"
+
+       pax-mark m "${ED%/}${INSDESTTREE}/pypy-c"
+}
+
+src_install() {
+       local flags=( bzip2 jit ncurses sandbox shadowstack )
+       use x86 && flags+=( cpu_flags_x86_sse2 )
+       local f suffix="-${ARCH}"
+
+       for f in ${flags[@]}; do
+               use ${f} && suffix+="+${f#cpu_flags_x86_}"
+       done
+
+       local BIN_P=pypy-bin-${PV}
+
+       einfo "Zipping PyPy ..."
+       mkdir "${BIN_P}${suffix}"{,/include} || die
+       mv pypy-c libpypy-c.so "${BIN_P}${suffix}"/ || die
+       mv include/pypy_* "${BIN_P}${suffix}"/include/ || die
+       chmod +x "${BIN_P}${suffix}"/pypy-c || die
+
+       tar -cf "${BIN_P}${suffix}.tar" "${BIN_P}${suffix}" || die
+       xz -vz9e "${BIN_P}${suffix}.tar" || die
+}
+
+# Yup, very hacky.
+pkg_preinst() {
+       # integrity check.
+       [[ ${PYPY_BINPKG_STORE} ]] || die 'PYPY_BINPKG_STORE unset, wtf?!'
+       mkdir -p "${ROOT%/}${PYPY_BINPKG_STORE}" || die
+       mv "${S}"/*.tar.xz "${ROOT%/}${PYPY_BINPKG_STORE}" || die
+}

Reply via email to