Files
poky/meta/classes-recipe/setuptools3.bbclass
Philip Lorenz 03f7151e01 setuptools3: Add missing call to exit_if_errors
`exit_if_errors` must be called explicitly at the end of the task
execution to ensure that QA issues categorized as errors fail the task.

(From OE-Core rev: acc0c57e455670501433ba4514a977e16dc88c34)

Signed-off-by: Philip Lorenz <philip.lorenz@bmw.de>
Signed-off-by: Mathieu Dubois-Briand <mathieu.dubois-briand@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2025-07-31 10:48:35 +01:00

53 lines
1.6 KiB
Plaintext

#
# Copyright OpenEmbedded Contributors
#
# SPDX-License-Identifier: MIT
#
inherit setuptools3-base python_pep517
DEPENDS += "python3-setuptools-native python3-wheel-native"
SETUPTOOLS_BUILD_ARGS ?= ""
SETUPTOOLS_SETUP_PATH ?= "${S}"
python do_check_backend() {
import re
filename = d.expand("${SETUPTOOLS_SETUP_PATH}/pyproject.toml")
if os.path.exists(filename):
for line in open(filename):
match = re.match(r"build-backend\s*=\s*\W([\w.]+)\W", line)
if not match: continue
msg = f"inherits setuptools3 but has pyproject.toml with {match[1]}, use the correct class"
if "pep517-backend" not in (d.getVar("INSANE_SKIP") or "").split():
oe.qa.handle_error("pep517-backend", msg, d)
oe.qa.exit_if_errors(d)
}
addtask check_backend after do_patch before do_configure
setuptools3_do_configure() {
:
}
setuptools3_do_compile() {
cd ${SETUPTOOLS_SETUP_PATH}
STAGING_INCDIR=${STAGING_INCDIR} \
STAGING_LIBDIR=${STAGING_LIBDIR} \
${STAGING_BINDIR_NATIVE}/python3-native/python3 setup.py \
bdist_wheel --verbose --dist-dir ${PEP517_WHEEL_PATH} ${SETUPTOOLS_BUILD_ARGS} || \
bbfatal_log "'python3 setup.py bdist_wheel ${SETUPTOOLS_BUILD_ARGS}' execution failed."
}
setuptools3_do_compile[vardepsexclude] = "MACHINE"
do_compile[cleandirs] += "${PEP517_WHEEL_PATH}"
# This could be removed in the future but some recipes in meta-oe still use it
setuptools3_do_install() {
python_pep517_do_install
}
EXPORT_FUNCTIONS do_configure do_compile do_install
export LDSHARED = "${CCLD} -shared"