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