commit:     aa1f3f3c914c8e896b782bfacf756a1d848e3e07
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 24 11:12:49 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr 24 15:08:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aa1f3f3c

dev-python/pypy: Bump to 7.3.16

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 dev-python/pypy/Manifest           |   2 +
 dev-python/pypy/pypy-7.3.16.ebuild | 306 +++++++++++++++++++++++++++++++++++++
 2 files changed, 308 insertions(+)

diff --git a/dev-python/pypy/Manifest b/dev-python/pypy/Manifest
index ba35d88e52ad..8c8a2bb8fff0 100644
--- a/dev-python/pypy/Manifest
+++ b/dev-python/pypy/Manifest
@@ -1,2 +1,4 @@
 DIST pypy2.7-gentoo-patches-7.3.15.tar.xz 5324 BLAKE2B 
395b1292b59cc9b2147fd488726d7cb2c18e7240d604d0bb19f172654c87b453a27f33f29bd2c1cb230d35b660457a317247c3b2eb73e8f3247c7d01fd35aa6a
 SHA512 
698a58b30f5a4785e2d94c38cb0e7ce2666b6b621ee0ae4e9fd51862efce13449342afe6408edc9f4ba68497f2138d653617fa4a31cd925a51a048dd79467913
+DIST pypy2.7-gentoo-patches-7.3.16.tar.xz 5312 BLAKE2B 
b265dd7afee097ad66bacd9df01514eed6bb30afe19410b2594ee7c2d61ababc67e11c0dd0392a0b1f81e0bc609963cde044834ab24e67d007d101b8aa8052cb
 SHA512 
0d0309f3ed7314f6d310b0e34eedbbfdcc5a75d9bbd59b9071e567968bb10925549435776fab5bc7ec97e2b3422921dc282619427f930d89df6c7bc98ea701c1
 DIST pypy2.7-v7.3.15-src.tar.bz2 19834343 BLAKE2B 
4e1145cac007223de0616029dfe763a8d2b3e25a6d867c98da0e8e0431d775c6aa7e50834c761e19f96b96309dbb415a39d7811c68b1b3a26c16cd222911205d
 SHA512 
40448c7c94878bcb88402de8719a4a6a4ffe3f68d7e70500f04fe77a460b1605c83dace360988d2dae70fa2c9bb31a20c22003f70a3a2fde988f6d60507edefe
+DIST pypy2.7-v7.3.16-src.tar.bz2 19843601 BLAKE2B 
9c37a03561fcdf742eccde760f6cadcbc2e1b140dd6d3e67856cc072e0c3db85759c398f590ed44fb4e4ed2f5f7745d5589cb9a95cefcbec79f3b1be6c4956e1
 SHA512 
131635433e53d4d86730a3daf1ad81799a7dd1117511618cc2607ac7234ce3aa5c833400df09cbd3376a391e125d6d2ec3471f120f81a6d53700f5c3d087793c

diff --git a/dev-python/pypy/pypy-7.3.16.ebuild 
b/dev-python/pypy/pypy-7.3.16.ebuild
new file mode 100644
index 000000000000..1f54095e77c1
--- /dev/null
+++ b/dev-python/pypy/pypy-7.3.16.ebuild
@@ -0,0 +1,306 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit pax-utils
+
+PYPY_PV=${PV%_p*}
+MY_P=pypy2.7-v${PYPY_PV/_}
+PATCHSET="pypy2.7-gentoo-patches-${PV/_rc/rc}"
+
+DESCRIPTION="A fast, compliant alternative implementation of the Python 
language"
+HOMEPAGE="
+       https://www.pypy.org/
+       https://github.com/pypy/pypy/
+"
+SRC_URI="
+       https://downloads.python.org/pypy/${MY_P}-src.tar.bz2
+       https://buildbot.pypy.org/pypy/${MY_P}-src.tar.bz2
+       https://dev.gentoo.org/~mgorny/dist/python/${PATCHSET}.tar.xz
+"
+S="${WORKDIR}/${MY_P}-src"
+
+LICENSE="MIT"
+# pypy -c 'import sysconfig; print sysconfig.get_config_var("SOABI")'
+SLOT="0/73"
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86 ~amd64-linux ~x86-linux"
+IUSE="bzip2 full-stdlib gdbm +jit ncurses sqlite tk"
+RESTRICT="test"
+
+RDEPEND="
+       || (
+               >=dev-python/pypy-exe-bin-${PYPY_PV}:${PYPY_PV}
+               >=dev-python/pypy-exe-${PYPY_PV}:${PYPY_PV}[bzip2?,ncurses?]
+       )
+       dev-libs/openssl:0=
+       gdbm? ( sys-libs/gdbm:0= )
+       sqlite? ( dev-db/sqlite:3= )
+       tk? (
+               dev-lang/tk:0=
+               dev-tcltk/tix:0=
+       )
+"
+DEPEND="
+       ${RDEPEND}
+"
+
+src_prepare() {
+       local PATCHES=(
+               "${WORKDIR}/${PATCHSET}"
+       )
+       default
+}
+
+src_compile() {
+       # copy over to make sys.prefix happy
+       cp -p "${BROOT}"/usr/lib/pypy2.7/pypy-c-${PYPY_PV} pypy-c || die
+       cp -p "${BROOT}"/usr/lib/pypy2.7/include/${PYPY_PV}/* include/ || die
+       # (not installed by pypy)
+       rm pypy/module/cpyext/include/_numpypy/numpy/README || die
+       mv pypy/module/cpyext/include/* include/ || die
+       mv pypy/module/cpyext/parse/*.h include/ || die
+       pax-mark m pypy-c
+
+       # verify the subslot
+       local soabi=$(
+               ./pypy-c - <<-EOF
+                       import sysconfig
+                       print sysconfig.get_config_var("SOABI")
+               EOF
+       )
+       [[ ${soabi#pypy-} == ${SLOT#*/} ]] || die "update subslot to ${soabi}"
+
+       einfo "Generating caches and CFFI modules ..."
+
+       if use full-stdlib; then
+               # Generate Grammar and PatternGrammar pickles.
+               ./pypy-c - <<-EOF || die "Generation of Grammar and 
PatternGrammar pickles failed"
+                       import lib2to3.pygram
+                       import lib2to3.patcomp
+                       lib2to3.patcomp.PatternCompiler()
+               EOF
+
+               # Generate cffi modules
+               # Please keep in sync with pypy/tool/build_cffi_imports.py!
+               cffi_targets=( pypy_util ssl audioop syslog pwdgrp resource )
+               use gdbm && cffi_targets+=( gdbm )
+               use ncurses && cffi_targets+=( curses )
+               use sqlite && cffi_targets+=( sqlite3 )
+               use tk && cffi_targets+=( tkinter/tklib )
+
+               local t
+               # all modules except tkinter output to .
+               # tkinter outputs to the correct dir ...
+               cd lib_pypy || die
+               for t in "${cffi_targets[@]}"; do
+                       # tkinter doesn't work via -m
+                       ../pypy-c "_${t}_build.py" || die "Failed to build CFFI 
bindings for ${t}"
+               done
+
+               # Verify that CFFI module list is up-to-date
+               local expected_cksum=-7df4eab0
+               local local_cksum=$(
+                       ../pypy-c - <<-EOF
+                               import binascii
+                               import json
+                               from pypy_tools.build_cffi_imports import 
cffi_build_scripts as x
+                               print("%08x" % (binascii.crc32(json.dumps(x)),))
+                       EOF
+               )
+               if [[ ${local_cksum} != ${expected_cksum} ]]; then
+                       die "Please verify cffi_targets and update checksum to 
${local_cksum}"
+               fi
+
+               # Cleanup temporary objects
+               find -name "_cffi_*.[co]" -delete || die
+               find -type d -empty -delete || die
+       fi
+}
+
+src_test() {
+       # (unset)
+       local -x PYTHONDONTWRITEBYTECODE=
+       local -x COLUMNS=80
+
+       local ignored_tests=(
+               # network
+               --ignore=lib-python/2.7/test/test_urllibnet.py
+               --ignore=lib-python/2.7/test/test_urllib2net.py
+               # lots of free space
+               --ignore=lib-python/2.7/test/test_zipfile64.py
+
+               # broken by expat-2.4.5
+               --ignore=lib-python/2.7/test/test_minidom.py
+               --ignore=lib-python/2.7/test/test_xml_etree.py
+               --ignore=lib-python/2.7/test/test_xml_etree_c.py
+       )
+
+       ./pypy-c ./pypy/test_all.py --pypy=./pypy-c -vv \
+               "${ignored_tests[@]}" lib-python || die
+}
+
+src_install() {
+       local dest=/usr/lib/pypy2.7
+       einfo "Installing PyPy ..."
+       dosym pypy-c-${PYPY_PV} "${dest}/pypy-c"
+       insinto "${dest}"
+       # preserve mtimes to avoid obsoleting caches
+       insopts -p
+       if use full-stdlib; then
+               doins -r include lib_pypy lib-python
+
+               # replace copied headers with symlinks
+               for x in "${BROOT}"/usr/lib/pypy2.7/include/${PYPY_PV}/*; do
+                       dosym "${PYPY_PV}/${x##*/}" "${dest}/include/${x##*/}"
+               done
+
+               if ! use gdbm; then
+                       rm -r "${ED}${dest}"/lib_pypy/gdbm.py \
+                               
"${ED}${dest}"/lib-python/*2.7/test/test_gdbm.py || die
+               fi
+               if ! use sqlite; then
+                       rm -r "${ED}${dest}"/lib-python/*2.7/sqlite3 \
+                               "${ED}${dest}"/lib_pypy/_sqlite3.py \
+                               
"${ED}${dest}"/lib-python/*2.7/test/test_sqlite.py || die
+               fi
+               if ! use tk; then
+                       rm -r "${ED}${dest}"/lib-python/*2.7/{idlelib,lib-tk} \
+                               "${ED}${dest}"/lib_pypy/_tkinter \
+                               
"${ED}${dest}"/lib-python/*2.7/test/test_{tcl,tk,ttk*}.py || die
+               fi
+       else
+               # install only the absolutely minimal subset of modules needed
+               # for pypy3 build
+               local lib_py_modules=(
+                       # base modules needed to even start pypy (and import 
site)
+                       codecs.py
+                       copy_reg.py
+                       encodings
+                       genericpath.py
+                       linecache.py
+                       os.py
+                       pkgutil.py
+                       posixpath.py
+                       re.py
+                       runpy.py
+                       site.py
+                       sre_compile.py
+                       sre_constants.py
+                       sre_parse.py
+                       stat.py
+                       string.py
+                       sysconfig.py
+                       traceback.py
+                       warnings.py
+                       UserDict.py
+
+                       # needed for python_optimize
+                       compileall.py
+                       getopt.py
+                       py_compile.py
+                       struct.py
+
+                       # needed for rpython
+                       argparse.py
+                       atexit.py
+                       base64.py
+                       bdb.py
+                       bisect.py
+                       cmd.py
+                       code.py
+                       codeop.py
+                       collections.py
+                       colorsys.py
+                       contextlib.py
+                       copy.py
+                       ctypes
+                       dis.py
+                       fnmatch.py
+                       functools.py
+                       gettext.py
+                       hashlib.py
+                       heapq.py
+                       inspect.py
+                       io.py
+                       json
+                       keyword.py
+                       locale.py
+                       logging
+                       new.py
+                       opcode.py
+                       optparse.py
+                       pdb.py
+                       pickle.py
+                       platform.py
+                       pprint.py
+                       random.py
+                       repr.py
+                       shlex.py
+                       shutil.py
+                       StringIO.py
+                       subprocess.py
+                       tempfile.py
+                       textwrap.py
+                       threading.py
+                       tokenize.py
+                       weakref.py
+                       zipfile.py
+               )
+
+               local distutils_modules=(
+                       # needed by site
+                       __init__.py
+                       errors.py
+                       sysconfig.py
+                       sysconfig_cpython.py
+                       sysconfig_pypy.py
+               )
+
+               local lib_pypy_modules=(
+                       # needed by site
+                       _sysconfigdata.py
+
+                       # needed by rpython
+                       cffi
+                       _ctypes
+                       _ffi.py
+                       _functools.py
+                       _sha.py
+                       _sha256.py
+                       _sha512.py
+
+                       # NB: we're deliberately skipping _hashlib to avoid 
some deps
+               )
+
+               cd lib-python/2.7 || die
+               insinto "${dest}/lib-python/2.7"
+               doins -r "${lib_py_modules[@]}"
+               cd - >/dev/null || die
+
+               cd lib-python/2.7/distutils || die
+               insinto "${dest}/lib-python/2.7/distutils"
+               doins -r "${distutils_modules[@]}"
+               cd - >/dev/null || die
+
+               cd lib_pypy || die
+               insinto "${dest}/lib_pypy"
+               doins -r "${lib_pypy_modules[@]}"
+               cd - >/dev/null || die
+       fi
+
+       dosym ../lib/pypy2.7/pypy-c /usr/bin/pypy
+       dodoc README.rst
+
+       local -x PYTHON=${ED}${dest}/pypy-c-${PYPY_PV}
+       # temporarily copy to build tree to facilitate module builds
+       cp -p "${BROOT}${dest}/pypy-c-${PYPY_PV}" "${PYTHON}" || die
+
+       einfo "Byte-compiling Python standard library..."
+       "${PYTHON}" -m compileall \
+               -x 'bad_coding|badsyntax|make_ssl_data|lib2to3/tests/data' \
+               -q -f -d "${dest}" "${ED}/${dest}" || die
+
+       # remove to avoid collisions
+       rm "${PYTHON}" || die
+}

Reply via email to