commit:     1e72e92290879e1caf8e516bfa57fc086a5e5406
Author:     Oz Tiram <oz.tiram <AT> gmail <DOT> com>
AuthorDate: Wed Jan 11 13:02:33 2023 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Fri Jan 20 14:01:19 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1e72e922

dev-python/pipenv: add 2022.12.19

Closes: https://github.com/gentoo/gentoo/pull/29062
Signed-off-by: Oz Tiram <oz.tiram <AT> gmail.com>
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>

 dev-python/pipenv/Manifest                         |   1 +
 .../pipenv-2022.12.19-append-always-install.patch  |  17 ++++
 dev-python/pipenv/pipenv-2022.12.19.ebuild         | 112 +++++++++++++++++++++
 3 files changed, 130 insertions(+)

diff --git a/dev-python/pipenv/Manifest b/dev-python/pipenv/Manifest
index 31007319ee35..741296050027 100644
--- a/dev-python/pipenv/Manifest
+++ b/dev-python/pipenv/Manifest
@@ -1,2 +1,3 @@
 DIST pipenv-2022.11.30.gh.tar.gz 11120234 BLAKE2B 
3d33475932a59dfb862869becb792aea420b8c9fffd9179866dc01eb5e0b2ba77a23c5de8be5570f9ed2e46f098bc000173d74766d42953f93ab2439c20d7f2c
 SHA512 
a44409d41196388b05f2b9620b9d0f45f4af7f244f8243143278b62560e54063574670356e141e07807b56b1181ad27f701f84b91bc045bf47b5701455b36c66
+DIST pipenv-2022.12.19.gh.tar.gz 11118843 BLAKE2B 
812aa7eacd2b1eaa42a586e64b73e7a13d2ac3ed4c2abf834e190ed5a8a4398d3d17999c1e196de6b01eb755f6771493967b8497710ac3fe20d73408f6251f80
 SHA512 
edd1e43cb3e91ed0001aff0a590f72e510f9b4c5f436a1c81d1e8a815d22f5bcf199254e5faf78dbdfec3ee0d4b51709b6de28163cf01e58d6f0de044ae99fdc
 DIST pipenv-2022.9.24.gh.tar.gz 11543711 BLAKE2B 
e875068383c8ca55864bfcb53288ae9a02adc578c09ad7392bf50a7ebe07e2eb5944bc225cfefad2ca8265d8dcbb17af96b34e8c0fd51a709921148207021f2b
 SHA512 
d29a728d914d8c762469fd2d72de7be41050165b4587c3304ebc03235a1946967f78473651e1834e5a69a35395d0cf9087e1515fd746450057774fc22e61e092

diff --git 
a/dev-python/pipenv/files/pipenv-2022.12.19-append-always-install.patch 
b/dev-python/pipenv/files/pipenv-2022.12.19-append-always-install.patch
new file mode 100644
index 000000000000..a5746fdb8ebe
--- /dev/null
+++ b/dev-python/pipenv/files/pipenv-2022.12.19-append-always-install.patch
@@ -0,0 +1,17 @@
+diff --git a/pipenv/core.py b/pipenv/core.py
+index e42f184d1..02f8994de 100644
+--- a/pipenv/core.py
++++ b/pipenv/core.py
+@@ -791,6 +791,12 @@ def batch_install_iteration(
+         strip_extras_markers_from_requirement,
+     )
+ 
++    # Gentoo patch: install dependencies into the venv even if they exist in 
the system
++    # This is needed because pipenv imports the system packages to run.
++    # It does not change your system's packages.
++    if (extra_pip_args is not None) and ("-I" not in extra_pip_args):
++        extra_pip_args.append("-I")
++
+     is_artifact = False
+     for dep in deps_to_install:
+         if dep.req.req:

diff --git a/dev-python/pipenv/pipenv-2022.12.19.ebuild 
b/dev-python/pipenv/pipenv-2022.12.19.ebuild
new file mode 100644
index 000000000000..1f9dabc494e4
--- /dev/null
+++ b/dev-python/pipenv/pipenv-2022.12.19.ebuild
@@ -0,0 +1,112 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_USE_PEP517=setuptools
+PYTHON_COMPAT=( python3_{8..11} )
+
+inherit distutils-r1 multiprocessing
+
+MY_PV=${PV/_beta/b}
+DESCRIPTION="Python Development Workflow for Humans"
+HOMEPAGE="https://github.com/pypa/pipenv https://pypi.org/project/pipenv/";
+SRC_URI="https://github.com/pypa/pipenv/archive/v${MY_PV}.tar.gz -> 
${P}.gh.tar.gz"
+S="${WORKDIR}"/${PN}-${MY_PV}
+
+LICENSE="MIT"
+SLOT="0"
+KEYWORDS="~amd64 ~riscv ~x86"
+
+PATCHES=(
+       "${FILESDIR}/pipenv-2022.9.24-inject-site-packages.patch"
+       "${FILESDIR}/pipenv-2022.12.19-append-always-install.patch"
+)
+
+RDEPEND="
+       dev-python/attrs[${PYTHON_USEDEP}]
+       >=dev-python/cerberus-1.3.2[${PYTHON_USEDEP}]
+       dev-python/click[${PYTHON_USEDEP}]
+       >=dev-python/colorama-0.4.4[${PYTHON_USEDEP}]
+       >=dev-python/markupsafe-2.0.1[${PYTHON_USEDEP}]
+       >=dev-python/pexpect-4.8.0[${PYTHON_USEDEP}]
+       >=dev-python/ptyprocess-0.7.0[${PYTHON_USEDEP}]
+       dev-python/pyparsing[${PYTHON_USEDEP}]
+       >=dev-python/python-dateutil-2.8.2[${PYTHON_USEDEP}]
+       >=dev-python/python-dotenv-0.21.0[${PYTHON_USEDEP}]
+       >=dev-python/virtualenv-20.0.35[${PYTHON_USEDEP}]
+       dev-python/virtualenv-clone[${PYTHON_USEDEP}]
+       >=dev-python/requests-2.26.0[${PYTHON_USEDEP}]
+       dev-python/ruamel-yaml[${PYTHON_USEDEP}]
+       dev-python/tomlkit[${PYTHON_USEDEP}]
+"
+
+BDEPEND="
+       ${RDEPEND}
+       test? (
+               dev-python/flaky[${PYTHON_USEDEP}]
+               dev-python/mock[${PYTHON_USEDEP}]
+               dev-python/pytz[${PYTHON_USEDEP}]
+       )
+"
+
+distutils_enable_tests pytest
+
+# IMPORTANT: The following sed command patches the vendor direcotry
+# in the pipenv source. Attempts to simply bump the version of the
+# package without checking that it works is likely to fail
+# The vendored packages should eventually all be removed
+# see: https://bugs.gentoo.org/717666
+src_prepare() {
+       local pkgName
+       local jobs=$(makeopts_jobs)
+       local packages=( attr attrs cerberus click colorama dotenv markupsafe \
+                                        pexpect ptyprocess pyparsing requests 
urllib3 tomlkit )
+       for pkgName in ${packages[@]}; do
+               find ./ -type f -print0 | \
+                       xargs --max-procs="${jobs}" --null \
+                       sed --in-place \
+                               -e "s/from pipenv.vendor import 
${pkgName}/import ${pkgName}/g" \
+                               -e "s/from pipenv.vendor.${pkgName}\(.*\) 
import \(\w*\)/from ${pkgName}\1 import \2/g"\
+                               -e "s/import pipenv.vendor.${pkgName} as 
${pkgName}/import ${pkgName}/g" \
+                               -e "s/from .vendor import ${pkgName}/import 
${pkgName}/g" || die "Failed to sed for ${pkgName}"
+       done
+
+       distutils-r1_src_prepare
+
+       # remove vendored versions
+       for pkgName in ${packages[@]}; do
+               find  ./pipenv/vendor -regextype posix-extended -regex 
".*${pkgName}$" -prune -exec rm -rvf {} + || die
+               # package names can be foo-bar, their module will be however 
foo_bar
+               find  ./pipenv/vendor -regextype posix-extended -regex 
".*${pkgName/_/-}" -prune -exec rm -rvf {} + || die
+       done
+
+       find  ./pipenv/vendor -regextype posix-extended -regex 
'.*cached[_-]property.*' -prune -exec rm -rvf {} + || die
+
+       find ./ -type f -print0 | \
+               xargs --max-procs="${jobs}" --null \
+               sed --in-place \
+                       -e "s/from pipenv\.vendor import plette, toml, tomlkit, 
vistir/from pipenv\.vendor import plette, toml, vistir\\nimport tomlkit/g"
+
+       # remove tomlkit from vendoring
+       for fname in pipenv/utils/toml.py tests/integration/conftest.py; do
+               sed --in-place -e "s/from pipenv\.vendor import toml, 
tomlkit/from pipenv\.vendor import toml\\nimport tomlkit/g" $fname || die 
"Failed sed in $fname"
+       done
+       #for fname in "tests/unit/test_vendor.py "; do
+       #       sed --in-place -e "s/from pipenv\.vendor import tomlkit/import 
tomlkit/g" $fname || die "Failed sed in tomlkit"
+       #done
+       # remove python ruaml yaml
+       sed --in-place -e "s/from pipenv\.vendor\.ruamel\.yaml import YAML/from 
ruaml\.yaml import YAML/g" pipenv/patched/safety/util.py || die "Failed sed in 
ruaml-yaml"
+       sed --in-place -e "s/from pipenv\.vendor\.ruamel\.yaml\.error import 
MarkedYAMLError/from ruaml\.yaml\.error import MarkedYAMLError/g" 
pipenv/patched/safety/util.py || die "Failed sed in ruamel-yaml"
+
+       rm -vR pipenv/vendor/ruamel || die "Failed removing ruamel-yaml from 
vendor"
+
+       for fname in Makefile README.md README.rst ruamel.*.LICENSE vendor.txt; 
do
+               rm -v pipenv/vendor/$fname || die "Failed removing 
pipenv/vendor/$fname"
+       done
+
+}
+
+python_test() {
+       epytest -m "not cli and not needs_internet" tests/unit/
+}

Reply via email to