commit:     e0bf67256d74d3731fa7ffe782f625f975f1fcb5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 12 14:00:24 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Oct 12 15:17:49 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e0bf6725

dev-python/pypy3: Bump to 7.3.6_rc3

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

 dev-python/pypy3/Manifest               |   2 +
 dev-python/pypy3/pypy3-7.3.6_rc3.ebuild | 188 ++++++++++++++++++++++++++++++++
 2 files changed, 190 insertions(+)

diff --git a/dev-python/pypy3/Manifest b/dev-python/pypy3/Manifest
index ca2d22a6969..1e49ad20227 100644
--- a/dev-python/pypy3/Manifest
+++ b/dev-python/pypy3/Manifest
@@ -2,5 +2,7 @@ DIST pypy3.7-gentoo-patches-7.3.5_p1.tar.xz 9792 BLAKE2B 
c82869393c8a63462fa03c5
 DIST pypy3.7-v7.3.5-src.tar.bz2 25350766 BLAKE2B 
34d5c83284271b184f71492dbd65b8760cc0fcdec71e41ef48b9561280dd67ef4c37fdd70759d0b95114d127446fc0ea5d04feb99022c1a725233862b2028834
 SHA512 
253d2efc81d55fb392ab810741e3a633f664e1908b2c26db7a8830c971655cca6be1b8d34581d13aa2d738a4a4c8ba23c2c90333b6e03d4608372e8013ea723b
 DIST pypy3.8-gentoo-patches-7.3.6rc1.tar.xz 4660 BLAKE2B 
2a1fff331707a29dfb232ce4c2c6d3cada127b4452036172c3aac7579d89b8e0d4ea41300ffcadf0ec04b9cde32044371d55d225a477f2178dddb03642aa569b
 SHA512 
bb781369d4e0dd387659fc474c7a23d8c54ab88477fdd007d3552c95e870a1896a0628dbba876e870956c5a1efeb52efbfd343a08f8a70a4515f41b1dc8ed60d
 DIST pypy3.8-gentoo-patches-7.3.6rc2.tar.xz 4380 BLAKE2B 
1ad68c088d4888d3579c0b48789be3a95413ab8f11d971f9f616a1701ceed2b8eba595612e28dbbdbc1732e4f8a7cd08cbbb89cdc413d1a3e9eabbcd78fdde76
 SHA512 
c2d68610b78ed33aaa67ce5244d289409256f66f2505ac19f0a679c0c10e6024993bbc7d37a59547daac38d321653b8b1a63c55e3f52d1409969f0961842fdd7
+DIST pypy3.8-gentoo-patches-7.3.6rc3.tar.xz 4380 BLAKE2B 
03159baf9fb33b65406df47272940cf6adfe2891994787b057d6925edd74063c4f1e4ac115b17d7a41a5d220e9ba27a68f4138792624cc50c2c6aee3a6d385ff
 SHA512 
d88b3f97880735d84746970ef6ac05babde9d88ae6740411a646cec8618816d982a99ccf0628b73690cacc5a4ac9485160242c85756adad75ab7e3ad860b4e42
 DIST pypy3.8-v7.3.6rc1-src.tar.bz2 24320127 BLAKE2B 
920738d1d9a346dca8e76602fc5a1502ff6f610897e1f5b841b5207a32f82c52770684ba4ea076209e18b664cb9ba5df555a21f838ae581b436cbff9e2adb506
 SHA512 
334baf973397f8068137382c29632afd1288b76b57f21047bef59397d2718d8c420ba68acc2f1082501aadf7fbf8ee6a9fa86405c2a54d720a9a02dd7a7371aa
 DIST pypy3.8-v7.3.6rc2-src.tar.bz2 24350986 BLAKE2B 
fe167b7e1f4f81e1737220bb679874a1e0faa8605b0ec7d10db275c08226e12f8fcff5b958a5a2c42efba5125d88dea150b707441af13bd9b7ef0c9ef36d9c1b
 SHA512 
98715c4053d995a442877f93b32ecb976ffc4160df869d35843718bacfd97d2bbd697f85b5961c420f8130d22e64d740d8d180a4f9ff802250897b4b8c216a6a
+DIST pypy3.8-v7.3.6rc3-src.tar.bz2 24374611 BLAKE2B 
5b04bf5fa2f3f2f25a837add74ad716146681e1203ccdb915eed6d1f7f70cd9cb73426f63d310fd76fef2daf6537137d99fa14483886b2cf9946e979243de26f
 SHA512 
872252ff8f090523d79c8d9acec07390587ab38075f35d25f2010ed5ea85537aaa9acb14d049a0a8059757f6c2c1411e9b5e23fec0b1ec2cfcca70e82e6e1c8f

diff --git a/dev-python/pypy3/pypy3-7.3.6_rc3.ebuild 
b/dev-python/pypy3/pypy3-7.3.6_rc3.ebuild
new file mode 100644
index 00000000000..35693dd577f
--- /dev/null
+++ b/dev-python/pypy3/pypy3-7.3.6_rc3.ebuild
@@ -0,0 +1,188 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+PYTHON_COMPAT=( python2_7 )
+inherit pax-utils python-any-r1 toolchain-funcs
+
+PYPY_PV=${PV%_p*}
+MY_P=pypy3.8-v${PYPY_PV/_rc/rc}
+PATCHSET="pypy3.8-gentoo-patches-${PV/_rc/rc}"
+
+DESCRIPTION="A fast, compliant alternative implementation of the Python (3.8) 
language"
+HOMEPAGE="https://www.pypy.org/";
+SRC_URI="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"
+# pypy3 -c 'import sysconfig; print(sysconfig.get_config_var("SOABI"))'
+# also check pypy/interpreter/pycode.py -> pypy_incremental_magic
+SLOT="0/pypy38-pp73"
+KEYWORDS=""
+IUSE="bzip2 gdbm +jit ncurses sqlite test tk"
+# pypy3.8 is in alpha state and many tests are failing
+RESTRICT="test"
+
+RDEPEND="
+       || (
+               >=dev-python/pypy3-exe-${PYPY_PV}:${PYPY_PV}[bzip2?,ncurses?]
+               >=dev-python/pypy3-exe-bin-${PYPY_PV}:${PYPY_PV}
+       )
+       dev-libs/openssl:0=
+       gdbm? ( sys-libs/gdbm:0= )
+       sqlite? ( dev-db/sqlite:3= )
+       tk? (
+               dev-lang/tk:0=
+               dev-tcltk/tix:0=
+       )
+       !<dev-python/pypy3-bin-7.3.0:0"
+DEPEND="${RDEPEND}
+       test? (
+               ${PYTHON_DEPS}
+               !!dev-python/pytest-forked
+       )"
+
+pkg_setup() {
+       use test && python-any-r1_pkg_setup
+}
+
+src_prepare() {
+       local PATCHES=(
+               "${WORKDIR}/${PATCHSET}"
+       )
+       default
+
+       eapply_user
+}
+
+src_configure() {
+       tc-export CC
+}
+
+src_compile() {
+       mkdir bin || die
+       # switch to the layout expected for cffi module builds
+       mkdir include/pypy3.8 || die
+       cp include/*.h include/pypy3.8/ || die
+       # copy over to make sys.prefix happy
+       cp -p "${BROOT}"/usr/bin/pypy3-c-${PYPY_PV} pypy3-c || die
+       cp -p "${BROOT}"/usr/include/pypy3.8/${PYPY_PV}/* include/pypy3.8/ || 
die
+       # (not installed by pypy-exe)
+       rm pypy/module/cpyext/include/_numpypy/numpy/README || die
+       mv pypy/module/cpyext/include/* include/pypy3.8/ || die
+       mv pypy/module/cpyext/parse/*.h include/pypy3.8/ || die
+       pax-mark m pypy3-c
+
+       # verify the subslot
+       local soabi=$(./pypy3-c -c 'import sysconfig; 
print(sysconfig.get_config_var("SOABI"))')
+       [[ ${soabi} == ${SLOT#*/} ]] || die "update subslot to ${soabi}"
+
+       einfo "Generating caches and CFFI modules ..."
+
+       # Generate Grammar and PatternGrammar pickles.
+       ./pypy3-c -c "import lib2to3.pygram, lib2to3.patcomp; 
lib2to3.patcomp.PatternCompiler()" \
+               || die "Generation of Grammar and PatternGrammar pickles failed"
+
+       # Generate cffi modules
+       # Please keep in sync with pypy/tool/build_cffi_imports.py!
+       #cffi_build_scripts = collections.OrderedDict([
+       #    ("_ctypes._ctypes_cffi",
+       #     "_ctypes/_ctypes_build.py" if sys.platform == 'darwin' else None),
+       #    ("_blake2", "_blake2/_blake2_build.py"),
+       #    ("_ssl", "_ssl_build.py"),
+       #    ("sqlite3", "_sqlite3_build.py"),
+       #    ("audioop", "_audioop_build.py"),
+       #    ("_tkinter", "_tkinter/tklib_build.py"),
+       #    ("curses", "_curses_build.py" if sys.platform != "win32" else 
None),
+       #    ("syslog", "_syslog_build.py" if sys.platform != "win32" else 
None),
+       #    ("_gdbm", "_gdbm_build.py"  if sys.platform != "win32" else None),
+       #    ("grp", "_pwdgrp_build.py" if sys.platform != "win32" else None),
+       #    ("resource", "_resource_build.py" if sys.platform != "win32" else 
None),
+       #    ("lzma", "_lzma_build.py"),
+       #    # ("_decimal", "_decimal_build.py"),  # issue 3024
+       #    ("_sha3", "_sha3/_sha3_build.py"),
+       #    ("xx", None),    # for testing: 'None' should be completely ignored
+       #    ("_posixshmem", "_posixshmem_build.py" if sys.platform != "win32" 
else None),
+       #    ])
+       cffi_targets=( pypy_util blake2/_blake2 sha3/_sha3 ssl
+               audioop syslog pwdgrp resource lzma posixshmem )
+       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
+               ../pypy3-c "_${t}_build.py" || die "Failed to build CFFI 
bindings for ${t}"
+       done
+
+       # Cleanup temporary objects
+       find -name "*_cffi.[co]" -delete || die
+       find -type d -empty -delete || die
+}
+
+src_test() {
+       # (unset)
+       local -x PYTHONDONTWRITEBYTECODE=
+       local -x COLUMNS=80
+
+       # Test runner requires Python 2 too. However, it spawns PyPy3
+       # internally so that we end up testing the correct interpreter.
+       # (--deselect for failing doctests)
+       "${EPYTHON}" ./pypy/test_all.py --pypy=./pypy3-c -vv lib-python || die
+}
+
+src_install() {
+       einfo "Installing PyPy ..."
+       dodir /usr/bin
+       dosym pypy3-c-${PYPY_PV} /usr/bin/pypy3
+       insinto /usr/lib/pypy3.8
+       # preserve mtimes to avoid obsoleting caches
+       insopts -p
+       doins -r lib-python/3/. lib_pypy/.
+       insinto /usr/include
+       doins -r include/pypy3.8
+
+       # replace copied headers with symlinks
+       for x in "${BROOT}"/usr/include/pypy3.8/${PYPY_PV}/*; do
+               dosym "${PYPY_PV}/${x##*/}" "/usr/include/pypy3.8/${x##*/}"
+       done
+
+       dodoc README.rst
+
+       local dest=/usr/lib/pypy3.8
+       if ! use gdbm; then
+               rm -r "${ED}${dest}"/_gdbm* || die
+       fi
+       if ! use sqlite; then
+               rm -r "${ED}${dest}"/sqlite3 \
+                       "${ED}${dest}"/_sqlite3* \
+                       "${ED}${dest}"/test/test_sqlite.py || die
+       fi
+       if ! use tk; then
+               rm -r "${ED}${dest}"/{idlelib,tkinter} \
+                       "${ED}${dest}"/_tkinter \
+                       "${ED}${dest}"/test/test_{tcl,tk,ttk*}.py || die
+       fi
+
+       local -x EPYTHON=pypy3
+       local -x PYTHON=${ED}/usr/bin/pypy3-c-${PYPY_PV}
+       # temporarily copy to build tree to facilitate module builds
+       cp -p "${BROOT}/usr/bin/pypy3-c-${PYPY_PV}" "${PYTHON}" || die
+
+       echo "EPYTHON='${EPYTHON}'" > epython.py || die
+       python_moduleinto "${dest}"/site-packages
+       python_domodule epython.py
+
+       einfo "Byte-compiling Python standard library..."
+       python_optimize "${ED}${dest}"
+
+       # remove to avoid collisions
+       rm "${PYTHON}" || die
+}

Reply via email to