From: "Michał Górny" <mgorny@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: metadata/install-qa-check.d/
Date: Sun, 16 Jan 2022 09:40:53 +0000 (UTC) [thread overview]
Message-ID: <1642326049.f344326fa3c3653d85acf12bf053bfd98f354c56.mgorny@gentoo> (raw)
commit: f344326fa3c3653d85acf12bf053bfd98f354c56
Author: Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 16 09:39:03 2022 +0000
Commit: Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Jan 16 09:40:49 2022 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f344326f
install-qa-check.d: Remove 60distutils-use-setuptools
Remove the DISTUTILS_USE_SETUPTOOLS correctness check that is misfiring
once again (with setuptools-60+). All the special cases it was supposed
to detect are no longer relevant, and the upcoming PEP 517 mode
deprecates DUS entirely.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
.../install-qa-check.d/60distutils-use-setuptools | 97 ----------------------
1 file changed, 97 deletions(-)
diff --git a/metadata/install-qa-check.d/60distutils-use-setuptools b/metadata/install-qa-check.d/60distutils-use-setuptools
deleted file mode 100644
index a7905c3f0b2f..000000000000
--- a/metadata/install-qa-check.d/60distutils-use-setuptools
+++ /dev/null
@@ -1,97 +0,0 @@
-# Copyright 2020-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# QA check: verify correctness of DISTUTILS_USE_SETUPTOOLS
-# Maintainer: Python project <python@gentoo.org>
-
-distutils_use_setuptools_check() {
- # applicable only to ebuilds inheriting distutils-r1
- [[ ${_DISTUTILS_R1} ]] || return
- # 'manual' means no checking
- [[ ${DISTUTILS_USE_SETUPTOOLS} == manual ]] && return
- # pyproject.toml is verified by using it
- [[ ${DISTUTILS_USE_SETUPTOOLS} == pyproject.toml ]] && return
-
- # setuptools dep is not set if distutils is optional
- if [[ ${DISTUTILS_OPTIONAL} ]]; then
- if [[ ${DISTUTILS_USE_SETUPTOOLS} != bdepend ]]; then
- eerror "QA Notice: DISTUTILS_USE_SETUPTOOLS is not used when DISTUTILS_OPTIONAL"
- eerror "is enabled."
- fi
- return
- fi
-
- local expected=()
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do
- local EPYTHON PYTHON
- _python_export "${impl}" EPYTHON PYTHON
- [[ -x ${PYTHON} ]] || continue
- local sitedir=${D}$(python_get_sitedir)
- if [[ -d ${sitedir} ]]; then
- local egg new_expected
- while read -d $'\0' -r egg; do
- if [[ -f ${egg} ]]; then
- # if .egg-info is a file, it's plain distutils
- new_expected=no
- elif [[ -f ${egg}/requires.txt ]] &&
- grep -q -s '^setuptools' \
- <(sed -e '/^\[/,$d' "${egg}"/requires.txt)
- then
- # explicit *unconditional* rdepend in package metadata
- new_expected=rdepend
- elif grep -q -s '\[\(console\|gui\)_scripts\]' \
- "${egg}"/entry_points.txt
- then
- new_expected=entry-point
- else
- new_expected=bdepend
- fi
-
- if ! has "${new_expected}" "${expected[@]}"; then
- expected+=( "${new_expected[@]}" )
- fi
- done < <(find "${sitedir}" -name '*.egg-info' -print0)
- fi
- done
-
- if [[ ${#expected[@]} -gt 1 ]] && has no "${expected[@]}"; then
- # 'no' and '[rb]depend' are mutually exclusive
- eerror "QA Notice: The package seems to have used distutils and setuptools"
- eerror "simultaneously"
- eerror ""
- eerror "This could mean the package has bad conditions:"
- eerror "https://dev.gentoo.org/~mgorny/python-guide/distutils.html#conditional-distutils-setuptools-use-in-packages"
- eerror "Please report a bug about this and CC python@"
- else
- # if we did not find anything, also assume 'no' is desired,
- # we do not want the setuptools dep
- [[ ${#expected[@]} -eq 0 ]] && expected=( no )
- # *+rdepend=rdepend
- has rdepend "${expected[@]}" && expected=( rdepend )
- # NB: note that expected is overwritten above, so this implies !rdepend
- # if the package is using entry points, modern versions of setuptools
- # use built-in importlib.metadata module, so no rdep needed anymore
- # NB2: this is incorrect for pypy3.7 but we ignore this for the time
- # being
- has entry-point "${expected[@]}" && expected=( bdepend )
-
- if ! has ${DISTUTILS_USE_SETUPTOOLS} "${expected[@]}"; then
- local def=
- [[ ${DISTUTILS_USE_SETUPTOOLS} == bdepend ]] && def=' (or unset)'
-
- eqawarn "QA Notice: DISTUTILS_USE_SETUPTOOLS value is probably incorrect"
- eqawarn " have: DISTUTILS_USE_SETUPTOOLS=${DISTUTILS_USE_SETUPTOOLS}${def}"
- if [[ ${expected[0]} == bdepend ]]; then
- eqawarn " expected: (unset)"
- else
- eqawarn " expected: DISTUTILS_USE_SETUPTOOLS=${expected[0]}"
- fi
- fi
- fi
-}
-
-distutils_use_setuptools_check
-
-: # guarantee successful exit
-
-# vim:ft=ebuild
next reply other threads:[~2022-01-16 9:40 UTC|newest]
Thread overview: 77+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-01-16 9:40 Michał Górny [this message]
-- strict thread matches above, loose matches on Subject: below --
2024-10-21 15:12 [gentoo-commits] repo/gentoo:master commit in: metadata/install-qa-check.d/ Michał Górny
2024-09-05 8:43 Michał Górny
2024-03-29 18:47 Sam James
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2024-01-08 14:48 Michał Górny
2023-08-17 22:08 Ulrich Müller
2023-05-17 3:40 Michał Górny
2022-09-19 3:52 Sam James
2022-08-21 2:31 Sam James
2022-08-04 23:49 Sam James
2022-08-03 18:56 Sam James
2022-08-03 4:27 Sam James
2022-08-03 1:53 Sam James
2022-08-02 4:08 Michał Górny
2022-07-16 11:26 Michał Górny
2022-06-08 0:25 Mike Gilbert
2022-05-06 12:48 Ionen Wolkens
2022-05-05 23:38 Sam James
2022-05-02 6:01 Agostino Sarubbo
2022-04-30 19:13 Sam James
2022-04-28 3:06 Sam James
2022-04-27 0:13 Sam James
2022-04-26 23:45 Sam James
2022-04-26 15:32 Sam James
2022-04-19 18:31 Sam James
2022-04-19 18:31 Sam James
2022-04-17 14:21 Sam James
2022-04-17 14:18 Sam James
2022-03-04 1:26 Sam James
2022-03-04 1:26 Sam James
2022-02-01 18:19 Mike Gilbert
2022-02-01 1:37 Mike Gilbert
2021-08-19 1:35 Sam James
2021-08-16 2:12 Sam James
2021-08-16 2:12 Sam James
2021-08-16 2:12 Sam James
2021-08-16 2:12 Sam James
2021-08-02 8:17 Michał Górny
2021-07-03 8:16 Michał Górny
2021-07-01 8:57 Georgy Yakovlev
2021-06-28 18:47 Georgy Yakovlev
2021-06-28 8:56 Georgy Yakovlev
2021-06-28 0:12 Georgy Yakovlev
2021-06-27 2:08 Sam James
2021-06-26 23:25 Georgy Yakovlev
2021-06-26 23:09 Georgy Yakovlev
2021-05-29 15:15 Michał Górny
2021-05-25 5:13 Michał Górny
2021-04-29 11:42 Michał Górny
2021-04-29 11:42 Michał Górny
2021-04-29 11:42 Michał Górny
2021-04-29 11:42 Michał Górny
2021-04-09 23:17 Sam James
2020-10-17 19:01 Michał Górny
2020-10-16 7:42 Michał Górny
2020-09-22 11:12 Michał Górny
2020-09-22 7:33 Michał Górny
2020-09-22 7:00 Michał Górny
2020-09-22 7:00 Michał Górny
2020-09-21 17:48 Michał Górny
2020-09-21 15:30 Michał Górny
2020-02-13 18:59 Georgy Yakovlev
2020-01-20 20:45 Michael Orlitzky
2019-12-30 16:10 Michał Górny
2019-11-12 7:53 Sergei Trofimovich
2019-11-11 23:05 Zac Medico
2019-11-11 22:25 Sergei Trofimovich
2019-11-01 13:16 Michał Górny
2018-10-06 8:35 Michał Górny
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1642326049.f344326fa3c3653d85acf12bf053bfd98f354c56.mgorny@gentoo \
--to=mgorny@gentoo.org \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox