diff options
Diffstat (limited to 'meta/classes/python_pep517.bbclass')
| -rw-r--r-- | meta/classes/python_pep517.bbclass | 27 |
1 files changed, 4 insertions, 23 deletions
diff --git a/meta/classes/python_pep517.bbclass b/meta/classes/python_pep517.bbclass index 756333bcf2..ac7c1e44c6 100644 --- a/meta/classes/python_pep517.bbclass +++ b/meta/classes/python_pep517.bbclass | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # Common infrastructure for Python packages that use PEP-517 compliant packaging. | 1 | # Common infrastructure for Python packages that use PEP-517 compliant packaging. |
| 2 | # https://www.python.org/dev/peps/pep-0517/ | 2 | # https://www.python.org/dev/peps/pep-0517/ |
| 3 | 3 | ||
| 4 | DEPENDS:append = " python3-pip-native" | 4 | DEPENDS:append = " python3-installer-native" |
| 5 | 5 | ||
| 6 | # Where to execute the build process from | 6 | # Where to execute the build process from |
| 7 | PEP517_SOURCE_PATH ?= "${S}" | 7 | PEP517_SOURCE_PATH ?= "${S}" |
| @@ -11,19 +11,11 @@ PEP517_SOURCE_PATH ?= "${S}" | |||
| 11 | # a recipe wants to install prebuilt wheels. | 11 | # a recipe wants to install prebuilt wheels. |
| 12 | PEP517_WHEEL_PATH ?= "${WORKDIR}/dist" | 12 | PEP517_WHEEL_PATH ?= "${WORKDIR}/dist" |
| 13 | 13 | ||
| 14 | PIP_INSTALL_ARGS = "\ | ||
| 15 | -vvvv \ | ||
| 16 | --ignore-installed \ | ||
| 17 | --no-cache \ | ||
| 18 | --no-deps \ | ||
| 19 | --no-index \ | ||
| 20 | --root=${D} \ | ||
| 21 | --prefix=${prefix} \ | ||
| 22 | " | ||
| 23 | |||
| 24 | PEP517_INSTALL_PYTHON = "python3" | 14 | PEP517_INSTALL_PYTHON = "python3" |
| 25 | PEP517_INSTALL_PYTHON:class-native = "nativepython3" | 15 | PEP517_INSTALL_PYTHON:class-native = "nativepython3" |
| 26 | 16 | ||
| 17 | INSTALL_WHEEL_COMPILE_BYTECODE ?= "--compile-bytecode=0" | ||
| 18 | |||
| 27 | python_pep517_do_install () { | 19 | python_pep517_do_install () { |
| 28 | COUNT=$(find ${PEP517_WHEEL_PATH} -name '*.whl' | wc -l) | 20 | COUNT=$(find ${PEP517_WHEEL_PATH} -name '*.whl' | wc -l) |
| 29 | if test $COUNT -eq 0; then | 21 | if test $COUNT -eq 0; then |
| @@ -32,18 +24,7 @@ python_pep517_do_install () { | |||
| 32 | bbfatal More than one wheel found in ${PEP517_WHEEL_PATH}, this should not happen | 24 | bbfatal More than one wheel found in ${PEP517_WHEEL_PATH}, this should not happen |
| 33 | fi | 25 | fi |
| 34 | 26 | ||
| 35 | nativepython3 -m pip install ${PIP_INSTALL_ARGS} ${PEP517_WHEEL_PATH}/*.whl | 27 | nativepython3 -m installer ${INSTALL_WHEEL_COMPILE_BYTECODE} --interpreter "${USRBINPATH}/env ${PEP517_INSTALL_PYTHON}" --destdir=${D} ${PEP517_WHEEL_PATH}/*.whl |
| 36 | |||
| 37 | cd ${D} | ||
| 38 | for i in ${D}${bindir}/* ${D}${sbindir}/*; do | ||
| 39 | if [ -f "$i" ]; then | ||
| 40 | sed -i -e "1s,#!.*nativepython3,#!${USRBINPATH}/env ${PEP517_INSTALL_PYTHON}," $i | ||
| 41 | sed -i -e "s:${PYTHON}:${USRBINPATH}/env\ ${PEP517_INSTALL_PYTHON}:g" $i | ||
| 42 | sed -i -e "s:${STAGING_BINDIR_NATIVE}:${bindir}:g" $i | ||
| 43 | # Not everything we find may be Python, so ignore errors | ||
| 44 | nativepython3 -mpy_compile $(realpath --relative-to=${D} $i) || true | ||
| 45 | fi | ||
| 46 | done | ||
| 47 | } | 28 | } |
| 48 | 29 | ||
| 49 | # A manual do_install that just uses unzip for bootstrapping purposes. Callers should DEPEND on unzip-native. | 30 | # A manual do_install that just uses unzip for bootstrapping purposes. Callers should DEPEND on unzip-native. |
