[arch-commits] Commit in python-setuptools/repos (3 files)
Felix Yan
felixonmars at gemini.archlinux.org
Sat Jul 16 23:58:56 UTC 2022
Date: Saturday, July 16, 2022 @ 23:58:55
Author: felixonmars
Revision: 451156
archrelease: copy trunk to testing-any
Added:
python-setuptools/repos/testing-any/
python-setuptools/repos/testing-any/PKGBUILD
(from rev 451155, python-setuptools/trunk/PKGBUILD)
python-setuptools/repos/testing-any/system-validate-pyproject.patch
(from rev 451155, python-setuptools/trunk/system-validate-pyproject.patch)
---------------------------------+
PKGBUILD | 95 ++++++++++++++++++++++++++++++++++++++
system-validate-pyproject.patch | 31 ++++++++++++
2 files changed, 126 insertions(+)
Copied: python-setuptools/repos/testing-any/PKGBUILD (from rev 451155, python-setuptools/trunk/PKGBUILD)
===================================================================
--- testing-any/PKGBUILD (rev 0)
+++ testing-any/PKGBUILD 2022-07-16 23:58:55 UTC (rev 451156)
@@ -0,0 +1,95 @@
+# Maintainer: Angel Velasquez <angvp at archlinux.org>
+# Maintainer: Felix Yan <felixonmars at archlinux.org>
+# Contributor: Eli Schwartz <eschwartz at archlinux.org>
+
+pkgname=python-setuptools
+pkgver=62.0.0
+pkgrel=1
+epoch=1
+pkgdesc="Easily download, build, install, upgrade, and uninstall Python packages"
+arch=('any')
+license=('PSF')
+url="https://pypi.org/project/setuptools/"
+depends=('python-appdirs' 'python-jaraco.text' 'python-more-itertools' 'python-nspektr'
+ 'python-ordered-set' 'python-packaging' 'python-pyparsing' 'python-tomli'
+ 'python-validate-pyproject')
+makedepends=('git' 'python-setuptools')
+checkdepends=('python-jaraco.envs' 'python-jaraco.path' 'python-mock' 'python-pip' 'python-pip-run'
+ 'python-pytest-fixture-config' 'python-pytest-flake8' 'python-pytest-virtualenv'
+ 'python-wheel' 'python-paver' 'python-pytest-cov' 'python-sphinx' 'python-build'
+ 'python-ini2toml' 'python-tomli-w')
+provides=('python-distribute')
+replaces=('python-distribute')
+source=("$pkgname-$pkgver.tar.gz::https://github.com/pypa/setuptools/archive/v$pkgver.tar.gz"
+ system-validate-pyproject.patch)
+sha512sums=('23be86aa5074350877be264738c354882345bcd0528628cce9afe31fb174416eac1f7cca3a06b37fc7e1a926aa0a74c2408fe082e8d02c015229b4c28aadc407'
+ '50495062093b1b6902484c384abe073896e4f45c5768741582e178014367f186831711a72a8a987e7bacafe96d871161fc07c686dd92c6886de19302f6a10b56')
+
+export SETUPTOOLS_INSTALL_WINDOWS_SPECIFIC_FILES=0
+
+prepare() {
+ cd setuptools-$pkgver
+
+ patch -p1 -i ../system-validate-pyproject.patch
+
+ rm -r {pkg_resources,setuptools}/{extern,_vendor} setuptools/config/_validate_pyproject
+
+ # Upstream devendoring logic is badly broken, see:
+ # https://bugs.archlinux.org/task/58670
+ # https://github.com/pypa/pip/issues/5429
+ # https://github.com/pypa/setuptools/issues/1383
+ # The simplest fix is to simply rewrite import paths to use the canonical
+ # location in the first place
+ for _module in setuptools pkg_resources '' ; do
+ find . -name \*.py -exec sed -i \
+ -e 's/from '$_module.extern' import/import/' \
+ -e 's/from '$_module.extern'\./from /' \
+ -e 's/import '$_module.extern'\./import /' \
+ -e "s/__import__('$_module.extern./__import__('/" \
+ -e 's/from \.\.extern\./from /' \
+ {} +
+ done
+
+ # Remove post-release tag since we are using stable tags
+ sed -e '/tag_build = .post/d' \
+ -e '/tag_date = 1/d' \
+ -i setup.cfg
+
+ # Fix shebang
+ sed -i -e "s|^#\!.*/usr/bin/env python|#!/usr/bin/env python3|" setuptools/command/easy_install.py
+}
+
+build() {
+ cd setuptools-$pkgver
+ python setup.py build
+}
+
+check() { (
+ # Workaround UTF-8 tests by setting LC_CTYPE
+ export LC_CTYPE=en_US.UTF-8
+
+ # https://github.com/pypa/setuptools/pull/810
+ export PYTHONDONTWRITEBYTECODE=1
+
+ cd setuptools-$pkgver
+ # 1-7: skipping all tests using "setuptools_sdist", "setuptools_wheel" (or "venv" which uses the latter)
+ # 8-9: subtle difference introduced by devendoring
+ # 10-11: TODO
+ PRE_BUILT_SETUPTOOLS_SDIST="$PWD"/build/lib python -m pytest \
+ --deselect setuptools/tests/integration/test_pip_install_sdist.py \
+ --deselect setuptools/tests/test_distutils_adoption.py \
+ --deselect setuptools/tests/test_setuptools.py::test_its_own_wheel_does_not_contain_tests \
+ --deselect setuptools/tests/test_virtualenv.py \
+ --deselect setuptools/tests/test_editable_install.py::test_editable_with_pyproject \
+ --deselect setuptools/tests/config/test_apply_pyprojecttoml.py::TestMeta::test_example_file_in_sdist \
+ --deselect setuptools/tests/config/test_apply_pyprojecttoml.py::TestMeta::test_example_file_not_in_wheel \
+ --deselect setuptools/tests/config/test_apply_pyprojecttoml.py::test_apply_pyproject_equivalent_to_setupcfg \
+ --deselect setuptools/tests/config/test_pyprojecttoml.py::test_invalid_example \
+ --deselect setuptools/tests/test_dist_info.py::TestWheelCompatibility \
+ --deselect setuptools/tests/test_dist_info.py::TestDistInfo::test_invalid_version
+)}
+
+package() {
+ cd setuptools-$pkgver
+ python setup.py install --prefix=/usr --root="$pkgdir" --optimize=1 --skip-build
+}
Copied: python-setuptools/repos/testing-any/system-validate-pyproject.patch (from rev 451155, python-setuptools/trunk/system-validate-pyproject.patch)
===================================================================
--- testing-any/system-validate-pyproject.patch (rev 0)
+++ testing-any/system-validate-pyproject.patch 2022-07-16 23:58:55 UTC (rev 451156)
@@ -0,0 +1,31 @@
+diff --git a/setuptools/config/pyprojecttoml.py b/setuptools/config/pyprojecttoml.py
+index d4024956..2c3bd6bf 100644
+--- a/setuptools/config/pyprojecttoml.py
++++ b/setuptools/config/pyprojecttoml.py
+@@ -27,16 +27,22 @@ def load_file(filepath: _Path) -> dict:
+
+
+ def validate(config: dict, filepath: _Path) -> bool:
+- from . import _validate_pyproject as validator
++ import validate_pyproject.api, validate_pyproject.errors, validate_pyproject.cli, validate_pyproject.plugins
+
+- trove_classifier = validator.FORMAT_FUNCTIONS.get("trove-classifier")
++ trove_classifier = validate_pyproject.api.FORMAT_FUNCTIONS.get("trove-classifier")
+ if hasattr(trove_classifier, "_disable_download"):
+ # Improve reproducibility by default. See issue 31 for validate-pyproject.
+ trove_classifier._disable_download() # type: ignore
+
++ plugins = validate_pyproject.plugins.list_from_entry_points()
++ validator = validate_pyproject.api.Validator(
++ validate_pyproject.cli.select_plugins(plugins, ('setuptools', 'distutils'), ()),
++ validate_pyproject.api.FORMAT_FUNCTIONS,
++ )
++
+ try:
+- return validator.validate(config)
+- except validator.ValidationError as ex:
++ return validator(config)
++ except validate_pyproject.errors.ValidationError as ex:
+ _logger.error(f"configuration error: {ex.summary}") # type: ignore
+ _logger.debug(ex.details) # type: ignore
+ error = ValueError(f"invalid pyproject.toml config: {ex.name}") # type: ignore
More information about the arch-commits
mailing list