dev-python/pipenv-2025.0.4

This commit is contained in:
TheK0tYaRa 2025-10-15 10:51:19 +03:00
parent 6a93218149
commit c1fcc5107c
5 changed files with 193 additions and 0 deletions

View file

@ -0,0 +1 @@
DIST pipenv-2025.0.4.gh.tar.gz 10528059 BLAKE2B 648aab748af7b3147c5a2c940e2965799e1cb1f7a1b52cec81a5f7be4d955d6ddf57b2ed28c067077a39d48038b0348d060f4296f787c6e5b60ac90e132b8edb SHA512 34a282b313cfe551b0ffaa2c05f70bc077e487dc516e901ff98db8d6873dfec4e4109185b9477fbd3cf2eff271ea63e381d3969871381e08ba7f3ab9295d3a8a

View file

@ -0,0 +1,34 @@
From 8ee76835b2d615156bb6d329417d6ce8d19bfa3a Mon Sep 17 00:00:00 2001
From: Oz Tiram <oz.tiram@gmail.com>
Date: Wed, 20 Sep 2023 23:11:27 +0200
Subject: [PATCH 2/4] Append always install to pip extra args
---
pipenv/routines/install.py | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/pipenv/routines/install.py b/pipenv/routines/install.py
index 2f135b435..e30f2da52 100644
--- a/pipenv/routines/install.py
+++ b/pipenv/routines/install.py
@@ -459,6 +459,17 @@ def batch_install_iteration(
allow_global=False,
extra_pip_args=None,
):
+ # 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")
+
+ # End of Gentoo patch
+
with temp_environ():
if not allow_global:
os.environ["PIP_USER"] = "0"
--
2.41.0

View file

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
<pkgmetadata>
<maintainer type="person" proxied="yes">
<email>oz.tiram@gmail.com</email>
<name>Oz Tiram</name>
</maintainer>
<maintainer type="project" proxied="proxy">
<email>proxy-maint@gentoo.org</email>
<name>Proxy Maintainers</name>
</maintainer>
<upstream>
<maintainer status="active">
<email>distutils-sig@python.org</email>
<name>Python Packaging Authority</name>
</maintainer>
<remote-id type="pypi">pipenv</remote-id>
<remote-id type="github">pypa/pipenv</remote-id>
</upstream>
</pkgmetadata>

View file

@ -0,0 +1,122 @@
# Copyright 1999-2025 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
DISTUTILS_USE_PEP517=setuptools
PYTHON_COMPAT=( pypy3 python3_{11..13} )
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 ~arm64 ~riscv"
PATCHES=(
"${FILESDIR}/pipenv-2023.9.8-append-always-install-to-pip-extra-args.patch"
)
RDEPEND="
dev-python/click[${PYTHON_USEDEP}]
dev-python/click-didyoumean[${PYTHON_USEDEP}]
>=dev-python/colorama-0.4.4[${PYTHON_USEDEP}]
dev-python/dparse[${PYTHON_USEDEP}]
>=dev-python/pexpect-4.8.0[${PYTHON_USEDEP}]
~dev-python/pipdeptree-2.23.4[${PYTHON_USEDEP}]
~dev-python/plette-2.1.0[${PYTHON_USEDEP}]
>=dev-python/ptyprocess-0.7.0[${PYTHON_USEDEP}]
dev-python/pyparsing[${PYTHON_USEDEP}]
~dev-python/pythonfinder-2.1.0[${PYTHON_USEDEP}]
$(python_gen_cond_dep ' dev-python/tomli[${PYTHON_USEDEP}] ' python3_{9..10})
>=dev-python/python-dateutil-2.8.2[${PYTHON_USEDEP}]
>=dev-python/python-dotenv-0.21.0[${PYTHON_USEDEP}]
>=dev-python/importlib-metadata-8.4.0[${PYTHON_USEDEP}]
<dev-python/importlib-metadata-9.0.0[${PYTHON_USEDEP}]
>=dev-python/virtualenv-20.0.35[${PYTHON_USEDEP}]
dev-python/ruamel-yaml[${PYTHON_USEDEP}]
dev-python/shellingham[${PYTHON_USEDEP}]
dev-python/tomli[${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() {
sed --in-place -e "s/import click, plette, tomlkit/import click\n\import tomlkit\nfrom pipenv.vendor import plette/g" pipenv/project.py || die "Failed patching pipenv/project.py"
local pkgName
local jobs=$(makeopts_jobs)
local packages=( cerberus colorama click click_didyoumean dotenv dparse markupsafe \
pexpect pep517 pipdeptree plette ptyprocess pydantic pyparsing pythonfinder \
requests urllib3 shellingham tomli tomlkit importlib_metadata )
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" \
-e "s/from .vendor.${pkgName}/from ${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 python ruaml yaml
# sed --in-place -e \
# "s/from pipenv\.vendor\.ruamel\.yaml import YAML/from ruamel\.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 ruamel\.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 vendor.txt; do
rm -v pipenv/vendor/$fname || die "Failed removing pipenv/vendor/${fname}"
done
sed --in-place -e "s/pipenv.vendor.pythonfinder.utils.get_python_version/pythonfinder.utils.get_python_version/g" tests/unit/test_utils.py || die "Failed patching tests"
rm -Rfv pipenv/vendor || die "Could not remove vendor"
rm -Rfv examples || die "Could not remove examples"
rm -Rfv docs || die "Could not remove docs"
}
python_test() {
epytest -m "not cli and not needs_internet" tests/unit/
}

File diff suppressed because one or more lines are too long