nah fuck packaging pipenv, it's easier to just install to pipx
This commit is contained in:
parent
aeff44ee47
commit
07b8eb4892
5 changed files with 3 additions and 180 deletions
|
|
@ -1 +0,0 @@
|
|||
DIST pipenv-2025.0.4.gh.tar.gz 10528059 BLAKE2B 648aab748af7b3147c5a2c940e2965799e1cb1f7a1b52cec81a5f7be4d955d6ddf57b2ed28c067077a39d48038b0348d060f4296f787c6e5b60ac90e132b8edb SHA512 34a282b313cfe551b0ffaa2c05f70bc077e487dc516e901ff98db8d6873dfec4e4109185b9477fbd3cf2eff271ea63e381d3969871381e08ba7f3ab9295d3a8a
|
||||
|
|
@ -1,34 +0,0 @@
|
|||
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
|
||||
|
||||
|
|
@ -1,20 +0,0 @@
|
|||
<?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>
|
||||
|
|
@ -1,122 +0,0 @@
|
|||
# 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
Loading…
Add table
Add a link
Reference in a new issue