Moved: python_export, getters, python_domodule, python_doscript and the necessary internal functions. No global-scope variables, no phase functions. --- gx86/eclass/python-r1.eclass | 409 +--------------------------------- gx86/eclass/python-utils-r1.eclass | 434 +++++++++++++++++++++++++++++++++++++ 2 files changed, 440 insertions(+), 403 deletions(-) create mode 100644 gx86/eclass/python-utils-r1.eclass
diff --git a/gx86/eclass/python-r1.eclass b/gx86/eclass/python-r1.eclass index 84dc50f..6cf4200 100644 --- a/gx86/eclass/python-r1.eclass +++ b/gx86/eclass/python-r1.eclass @@ -23,6 +23,11 @@ # Please note that this eclass is mostly intended to be extended # on-request. If you find something you used in other eclasses missing, # please don't hack it around and request an enhancement instead. +# +# Also, please note that python-r1 will always inherit python-utils-r1 +# as well. Thus, all the functions defined and documented there +# can be used in the packages using python-r1, and there is no need ever +# to inherit both. case "${EAPI}" in 0|1|2|3) @@ -36,7 +41,7 @@ case "${EAPI}" in ;; esac -inherit multilib +inherit python-utils-r1 # @ECLASS-VARIABLE: _PYTHON_ALL_IMPLS # @INTERNAL @@ -181,160 +186,6 @@ _python_set_globals # ${WORKDIR}/foo-1.3-python2_6 # @CODE -# @ECLASS-VARIABLE: PYTHON -# @DESCRIPTION: -# The absolute path to the current Python interpreter. -# -# Set and exported only in commands run by python_foreach_impl(). -# -# Example value: -# @CODE -# /usr/bin/python2.6 -# @CODE - -# @ECLASS-VARIABLE: EPYTHON -# @DESCRIPTION: -# The executable name of the current Python interpreter. -# -# This variable is used consistently with python.eclass. -# -# Set and exported only in commands run by python_foreach_impl(). -# -# Example value: -# @CODE -# python2.6 -# @CODE - -# @ECLASS-VARIABLE: PYTHON_SITEDIR -# @DESCRIPTION: -# The path to Python site-packages directory. -# -# Set and exported on request using python_export(). -# -# Example value: -# @CODE -# /usr/lib64/python2.6/site-packages -# @CODE - -# @FUNCTION: python_export -# @USAGE: [<impl>] <variables>... -# @DESCRIPTION: -# Set and export the Python implementation-relevant variables passed -# as parameters. -# -# The optional first parameter may specify the requested Python -# implementation (either as PYTHON_TARGETS value, e.g. python2_7, -# or an EPYTHON one, e.g. python2.7). If no implementation passed, -# the current one will be obtained from ${EPYTHON}. -# -# The variables which can be exported are: PYTHON, EPYTHON, -# PYTHON_SITEDIR. They are described more completely in the eclass -# variable documentation. -python_export() { - debug-print-function ${FUNCNAME} "${@}" - - local impl var - - case "${1}" in - python*|jython*) - impl=${1/_/.} - shift - ;; - pypy-c*) - impl=${1} - shift - ;; - pypy*) - local v=${1#pypy} - impl=pypy-c${v/_/.} - shift - ;; - *) - impl=${EPYTHON} - [[ ${impl} ]] || die "python_export: no impl nor EPYTHON" - ;; - esac - debug-print "${FUNCNAME}: implementation: ${impl}" - - for var; do - case "${var}" in - EPYTHON) - export EPYTHON=${impl} - debug-print "${FUNCNAME}: EPYTHON = ${EPYTHON}" - ;; - PYTHON) - export PYTHON=${EPREFIX}/usr/bin/${impl} - debug-print "${FUNCNAME}: PYTHON = ${PYTHON}" - ;; - PYTHON_SITEDIR) - local dir - case "${impl}" in - python*) - dir=/usr/$(get_libdir)/${impl} - ;; - jython*) - dir=/usr/share/${impl}/Lib - ;; - pypy*) - dir=/usr/$(get_libdir)/${impl/-c/} - ;; - esac - - export PYTHON_SITEDIR=${EPREFIX}${dir}/site-packages - debug-print "${FUNCNAME}: PYTHON_SITEDIR = ${PYTHON_SITEDIR}" - ;; - *) - die "python_export: unknown variable ${var}" - esac - done -} - -# @FUNCTION: python_get_PYTHON -# @USAGE: [<impl>] -# @DESCRIPTION: -# Obtain and print the path to the Python interpreter for the given -# implementation. If no implementation is provided, ${EPYTHON} will -# be used. -# -# If you just need to have PYTHON set (and exported), then it is better -# to use python_export() directly instead. -python_get_PYTHON() { - debug-print-function ${FUNCNAME} "${@}" - - python_export "${@}" PYTHON - echo "${PYTHON}" -} - -# @FUNCTION: python_get_EPYTHON -# @USAGE: <impl> -# @DESCRIPTION: -# Obtain and print the EPYTHON value for the given implementation. -# -# If you just need to have EPYTHON set (and exported), then it is better -# to use python_export() directly instead. -python_get_EPYTHON() { - debug-print-function ${FUNCNAME} "${@}" - - python_export "${@}" EPYTHON - echo "${EPYTHON}" -} - -# @FUNCTION: python_get_sitedir -# @USAGE: [<impl>] -# @DESCRIPTION: -# Obtain and print the 'site-packages' path for the given -# implementation. If no implementation is provided, ${EPYTHON} will -# be used. -# -# If you just need to have PYTHON_SITEDIR set (and exported), then it is -# better to use python_export() directly instead. -python_get_sitedir() { - debug-print-function ${FUNCNAME} "${@}" - - python_export "${@}" PYTHON_SITEDIR - echo "${PYTHON_SITEDIR}" -} - # @FUNCTION: python_copy_sources # @DESCRIPTION: # Create a single copy of the package sources (${S}) for each enabled @@ -617,97 +468,6 @@ python_export_best() { python_export "${impl}" "${@}" } -# @FUNCTION: _python_rewrite_shebang -# @INTERNAL -# @USAGE: [<EPYTHON>] <path>... -# @DESCRIPTION: -# Replaces 'python' executable in the shebang with the executable name -# of the specified interpreter. If no EPYTHON value (implementation) is -# used, the current ${EPYTHON} will be used. -# -# All specified files must start with a 'python' shebang. A file not -# having a matching shebang will be refused. The exact shebang style -# will be preserved in order not to break anything. -# -# Example conversions: -# @CODE -# From: #!/usr/bin/python -R -# To: #!/usr/bin/python2.7 -R -# -# From: #!/usr/bin/env FOO=bar python -# To: #!/usr/bin/env FOO=bar python2.7 -# @CODE -_python_rewrite_shebang() { - debug-print-function ${FUNCNAME} "${@}" - - local impl - case "${1}" in - python*|jython*|pypy-c*) - impl=${1} - shift - ;; - *) - impl=${EPYTHON} - [[ ${impl} ]] || die "${FUNCNAME}: no impl nor EPYTHON" - ;; - esac - debug-print "${FUNCNAME}: implementation: ${impl}" - - local f - for f; do - local shebang=$(head -n 1 "${f}") - debug-print "${FUNCNAME}: path = ${f}" - debug-print "${FUNCNAME}: shebang = ${shebang}" - - if [[ "${shebang} " != *'python '* ]]; then - eerror "A file does not seem to have a supported shebang:" - eerror " file: ${f}" - eerror " shebang: ${shebang}" - die "${FUNCNAME}: ${f} does not seem to have a valid shebang" - fi - - sed -i -e "1s:python:${impl}:" "${f}" || die - done -} - -# @FUNCTION: _python_ln_rel -# @INTERNAL -# @USAGE: <from> <to> -# @DESCRIPTION: -# Create a relative symlink. -_python_ln_rel() { - debug-print-function ${FUNCNAME} "${@}" - - local from=${1} - local to=${2} - - local frpath=${from%/*}/ - local topath=${to%/*}/ - local rel_path= - - # remove double slashes - frpath=${frpath/\/\///} - topath=${topath/\/\///} - - while [[ ${topath} ]]; do - local frseg=${frpath%%/*} - local toseg=${topath%%/*} - - if [[ ${frseg} != ${toseg} ]]; then - rel_path=../${rel_path}${frseg:+${frseg}/} - fi - - frpath=${frpath#${frseg}/} - topath=${topath#${toseg}/} - done - rel_path+=${frpath}${1##*/} - - debug-print "${FUNCNAME}: ${from} -> ${to}" - debug-print "${FUNCNAME}: rel_path = ${rel_path}" - - ln -fs "${rel_path}" "${to}" -} - # @FUNCTION: python_replicate_script # @USAGE: <path>... # @DESCRIPTION: @@ -743,160 +503,3 @@ python_replicate_script() { _python_ln_rel "${ED}"/usr/bin/python-exec "${f}" || die done } - -# @ECLASS-VARIABLE: python_scriptroot -# @DEFAULT_UNSET -# @DESCRIPTION: -# The current script destination for python_doscript(). The path -# is relative to the installation root (${ED}). -# -# When unset, ${DESTTREE}/bin (/usr/bin by default) will be used. -# -# Can be set indirectly through the python_scriptinto() function. -# -# Example: -# @CODE -# src_install() { -# local python_scriptroot=${GAMES_BINDIR} -# python_foreach_impl python_doscript foo -# } -# @CODE - -# @FUNCTION: python_scriptinto -# @USAGE: <new-path> -# @DESCRIPTION: -# Set the current scriptroot. The new value will be stored -# in the 'python_scriptroot' environment variable. The new value need -# be relative to the installation root (${ED}). -# -# Alternatively, you can set the variable directly. -python_scriptinto() { - debug-print-function ${FUNCNAME} "${@}" - - python_scriptroot=${1} -} - -# @FUNCTION: python_doscript -# @USAGE: <files>... -# @DESCRIPTION: -# Install the given scripts into current python_scriptroot, -# for the current Python implementation (${EPYTHON}). -# -# All specified files must start with a 'python' shebang. The shebang -# will be converted, the file will be renamed to be EPYTHON-suffixed -# and a wrapper will be installed in place of the original name. -# -# Example: -# @CODE -# src_install() { -# python_foreach_impl python_doscript ${PN} -# } -# @CODE -python_doscript() { - debug-print-function ${FUNCNAME} "${@}" - - [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' - - local d=${python_scriptroot:-${DESTTREE}/bin} - local INSDESTTREE INSOPTIONS - - insinto "${d}" - insopts -m755 - - local f - for f; do - local oldfn=${f##*/} - local newfn=${oldfn}-${EPYTHON} - - debug-print "${FUNCNAME}: ${oldfn} -> ${newfn}" - newins "${f}" "${newfn}" - _python_rewrite_shebang "${D}/${d}/${newfn}" - - # install the wrapper - _python_ln_rel "${ED}"/usr/bin/python-exec "${D}/${d}/${oldfn}" || die - done -} - -# @ECLASS-VARIABLE: python_moduleroot -# @DEFAULT_UNSET -# @DESCRIPTION: -# The current module root for python_domodule(). The path can be either -# an absolute system path (it must start with a slash, and ${D} will be -# prepended to it) or relative to the implementation's site-packages directory -# (then it must start with a non-slash character). -# -# When unset, the modules will be installed in the site-packages root. -# -# Can be set indirectly through the python_moduleinto() function. -# -# Example: -# @CODE -# src_install() { -# local python_moduleroot=bar -# # installs ${PYTHON_SITEDIR}/bar/baz.py -# python_foreach_impl python_domodule baz.py -# } -# @CODE - -# @FUNCTION: python_moduleinto -# @USAGE: <new-path> -# @DESCRIPTION: -# Set the current module root. The new value will be stored -# in the 'python_moduleroot' environment variable. The new value need -# be relative to the site-packages root. -# -# Alternatively, you can set the variable directly. -python_moduleinto() { - debug-print-function ${FUNCNAME} "${@}" - - python_moduleroot=${1} -} - -# @FUNCTION: python_domodule -# @USAGE: <files>... -# @DESCRIPTION: -# Install the given modules (or packages) into the current -# python_moduleroot. The list can mention both modules (files) -# and packages (directories). All listed files will be installed -# for all enabled implementations, and compiled afterwards. -# -# Example: -# @CODE -# src_install() { -# # (${PN} being a directory) -# python_foreach_impl python_domodule ${PN} -# } -# @CODE -python_domodule() { - debug-print-function ${FUNCNAME} "${@}" - - [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' - - local d - if [[ ${python_moduleroot} == /* ]]; then - # absolute path - d=${python_moduleroot} - else - # relative to site-packages - local PYTHON_SITEDIR=${PYTHON_SITEDIR} - [[ ${PYTHON_SITEDIR} ]] || python_export PYTHON_SITEDIR - - d=${PYTHON_SITEDIR}/${python_moduleroot} - fi - - local INSDESTTREE - - insinto "${d}" - doins -r "${@}" - - # erm, python2.6 can't handle passing files to compileall... - case "${EPYTHON}" in - python*) - "${PYTHON}" -m compileall -q "${D}/${d}" - "${PYTHON}" -OO -m compileall -q -f "${D}/${d}" - ;; - *) - "${PYTHON}" -m compileall -q "${D}/${d}" - ;; - esac -} diff --git a/gx86/eclass/python-utils-r1.eclass b/gx86/eclass/python-utils-r1.eclass new file mode 100644 index 0000000..d80b729 --- /dev/null +++ b/gx86/eclass/python-utils-r1.eclass @@ -0,0 +1,434 @@ +# Copyright 1999-2012 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: $ + +# @ECLASS: python-utils-r1 +# @MAINTAINER: +# Michał Górny <mgo...@gentoo.org> +# Python herd <pyt...@gentoo.org> +# @AUTHOR: +# Author: Michał Górny <mgo...@gentoo.org> +# Based on work of: Krzysztof Pawlik <nelch...@gentoo.org> +# @BLURB: Utility functions for packages with Python parts. +# @DESCRIPTION: +# An utility eclass providing functions to query Python implementations, +# install Python modules and scripts. +# +# This eclass does not set any metadata variables nor export any phase +# functions. It can be inherited safely. + +case "${EAPI}" in + 0|1|2|3) + die "Unsupported EAPI=${EAPI} (too old) for ${ECLASS}" + ;; + 4|5) + # EAPI=4 makes die behavior clear + ;; + *) + die "Unsupported EAPI=${EAPI} (unknown) for ${ECLASS}" + ;; +esac + +inherit multilib + +# @ECLASS-VARIABLE: PYTHON +# @DESCRIPTION: +# The absolute path to the current Python interpreter. +# +# Set and exported only in commands run by python_foreach_impl(). +# +# Example value: +# @CODE +# /usr/bin/python2.6 +# @CODE + +# @ECLASS-VARIABLE: EPYTHON +# @DESCRIPTION: +# The executable name of the current Python interpreter. +# +# This variable is used consistently with python.eclass. +# +# Set and exported only in commands run by python_foreach_impl(). +# +# Example value: +# @CODE +# python2.6 +# @CODE + +# @ECLASS-VARIABLE: PYTHON_SITEDIR +# @DESCRIPTION: +# The path to Python site-packages directory. +# +# Set and exported on request using python_export(). +# +# Example value: +# @CODE +# /usr/lib64/python2.6/site-packages +# @CODE + +# @FUNCTION: python_export +# @USAGE: [<impl>] <variables>... +# @DESCRIPTION: +# Set and export the Python implementation-relevant variables passed +# as parameters. +# +# The optional first parameter may specify the requested Python +# implementation (either as PYTHON_TARGETS value, e.g. python2_7, +# or an EPYTHON one, e.g. python2.7). If no implementation passed, +# the current one will be obtained from ${EPYTHON}. +# +# The variables which can be exported are: PYTHON, EPYTHON, +# PYTHON_SITEDIR. They are described more completely in the eclass +# variable documentation. +python_export() { + debug-print-function ${FUNCNAME} "${@}" + + local impl var + + case "${1}" in + python*|jython*) + impl=${1/_/.} + shift + ;; + pypy-c*) + impl=${1} + shift + ;; + pypy*) + local v=${1#pypy} + impl=pypy-c${v/_/.} + shift + ;; + *) + impl=${EPYTHON} + [[ ${impl} ]] || die "python_export: no impl nor EPYTHON" + ;; + esac + debug-print "${FUNCNAME}: implementation: ${impl}" + + for var; do + case "${var}" in + EPYTHON) + export EPYTHON=${impl} + debug-print "${FUNCNAME}: EPYTHON = ${EPYTHON}" + ;; + PYTHON) + export PYTHON=${EPREFIX}/usr/bin/${impl} + debug-print "${FUNCNAME}: PYTHON = ${PYTHON}" + ;; + PYTHON_SITEDIR) + local dir + case "${impl}" in + python*) + dir=/usr/$(get_libdir)/${impl} + ;; + jython*) + dir=/usr/share/${impl}/Lib + ;; + pypy*) + dir=/usr/$(get_libdir)/${impl/-c/} + ;; + esac + + export PYTHON_SITEDIR=${EPREFIX}${dir}/site-packages + debug-print "${FUNCNAME}: PYTHON_SITEDIR = ${PYTHON_SITEDIR}" + ;; + *) + die "python_export: unknown variable ${var}" + esac + done +} + +# @FUNCTION: python_get_PYTHON +# @USAGE: [<impl>] +# @DESCRIPTION: +# Obtain and print the path to the Python interpreter for the given +# implementation. If no implementation is provided, ${EPYTHON} will +# be used. +# +# If you just need to have PYTHON set (and exported), then it is better +# to use python_export() directly instead. +python_get_PYTHON() { + debug-print-function ${FUNCNAME} "${@}" + + python_export "${@}" PYTHON + echo "${PYTHON}" +} + +# @FUNCTION: python_get_EPYTHON +# @USAGE: <impl> +# @DESCRIPTION: +# Obtain and print the EPYTHON value for the given implementation. +# +# If you just need to have EPYTHON set (and exported), then it is better +# to use python_export() directly instead. +python_get_EPYTHON() { + debug-print-function ${FUNCNAME} "${@}" + + python_export "${@}" EPYTHON + echo "${EPYTHON}" +} + +# @FUNCTION: python_get_sitedir +# @USAGE: [<impl>] +# @DESCRIPTION: +# Obtain and print the 'site-packages' path for the given +# implementation. If no implementation is provided, ${EPYTHON} will +# be used. +# +# If you just need to have PYTHON_SITEDIR set (and exported), then it is +# better to use python_export() directly instead. +python_get_sitedir() { + debug-print-function ${FUNCNAME} "${@}" + + python_export "${@}" PYTHON_SITEDIR + echo "${PYTHON_SITEDIR}" +} + +# @FUNCTION: _python_rewrite_shebang +# @INTERNAL +# @USAGE: [<EPYTHON>] <path>... +# @DESCRIPTION: +# Replaces 'python' executable in the shebang with the executable name +# of the specified interpreter. If no EPYTHON value (implementation) is +# used, the current ${EPYTHON} will be used. +# +# All specified files must start with a 'python' shebang. A file not +# having a matching shebang will be refused. The exact shebang style +# will be preserved in order not to break anything. +# +# Example conversions: +# @CODE +# From: #!/usr/bin/python -R +# To: #!/usr/bin/python2.7 -R +# +# From: #!/usr/bin/env FOO=bar python +# To: #!/usr/bin/env FOO=bar python2.7 +# @CODE +_python_rewrite_shebang() { + debug-print-function ${FUNCNAME} "${@}" + + local impl + case "${1}" in + python*|jython*|pypy-c*) + impl=${1} + shift + ;; + *) + impl=${EPYTHON} + [[ ${impl} ]] || die "${FUNCNAME}: no impl nor EPYTHON" + ;; + esac + debug-print "${FUNCNAME}: implementation: ${impl}" + + local f + for f; do + local shebang=$(head -n 1 "${f}") + debug-print "${FUNCNAME}: path = ${f}" + debug-print "${FUNCNAME}: shebang = ${shebang}" + + if [[ "${shebang} " != *'python '* ]]; then + eerror "A file does not seem to have a supported shebang:" + eerror " file: ${f}" + eerror " shebang: ${shebang}" + die "${FUNCNAME}: ${f} does not seem to have a valid shebang" + fi + + sed -i -e "1s:python:${impl}:" "${f}" || die + done +} + +# @FUNCTION: _python_ln_rel +# @INTERNAL +# @USAGE: <from> <to> +# @DESCRIPTION: +# Create a relative symlink. +_python_ln_rel() { + debug-print-function ${FUNCNAME} "${@}" + + local from=${1} + local to=${2} + + local frpath=${from%/*}/ + local topath=${to%/*}/ + local rel_path= + + # remove double slashes + frpath=${frpath/\/\///} + topath=${topath/\/\///} + + while [[ ${topath} ]]; do + local frseg=${frpath%%/*} + local toseg=${topath%%/*} + + if [[ ${frseg} != ${toseg} ]]; then + rel_path=../${rel_path}${frseg:+${frseg}/} + fi + + frpath=${frpath#${frseg}/} + topath=${topath#${toseg}/} + done + rel_path+=${frpath}${1##*/} + + debug-print "${FUNCNAME}: ${from} -> ${to}" + debug-print "${FUNCNAME}: rel_path = ${rel_path}" + + ln -fs "${rel_path}" "${to}" +} + +# @ECLASS-VARIABLE: python_scriptroot +# @DEFAULT_UNSET +# @DESCRIPTION: +# The current script destination for python_doscript(). The path +# is relative to the installation root (${ED}). +# +# When unset, ${DESTTREE}/bin (/usr/bin by default) will be used. +# +# Can be set indirectly through the python_scriptinto() function. +# +# Example: +# @CODE +# src_install() { +# local python_scriptroot=${GAMES_BINDIR} +# python_foreach_impl python_doscript foo +# } +# @CODE + +# @FUNCTION: python_scriptinto +# @USAGE: <new-path> +# @DESCRIPTION: +# Set the current scriptroot. The new value will be stored +# in the 'python_scriptroot' environment variable. The new value need +# be relative to the installation root (${ED}). +# +# Alternatively, you can set the variable directly. +python_scriptinto() { + debug-print-function ${FUNCNAME} "${@}" + + python_scriptroot=${1} +} + +# @FUNCTION: python_doscript +# @USAGE: <files>... +# @DESCRIPTION: +# Install the given scripts into current python_scriptroot, +# for the current Python implementation (${EPYTHON}). +# +# All specified files must start with a 'python' shebang. The shebang +# will be converted, the file will be renamed to be EPYTHON-suffixed +# and a wrapper will be installed in place of the original name. +# +# Example: +# @CODE +# src_install() { +# python_foreach_impl python_doscript ${PN} +# } +# @CODE +python_doscript() { + debug-print-function ${FUNCNAME} "${@}" + + [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' + + local d=${python_scriptroot:-${DESTTREE}/bin} + local INSDESTTREE INSOPTIONS + + insinto "${d}" + insopts -m755 + + local f + for f; do + local oldfn=${f##*/} + local newfn=${oldfn}-${EPYTHON} + + debug-print "${FUNCNAME}: ${oldfn} -> ${newfn}" + newins "${f}" "${newfn}" + _python_rewrite_shebang "${D}/${d}/${newfn}" + + # install the wrapper + _python_ln_rel "${ED}"/usr/bin/python-exec "${D}/${d}/${oldfn}" || die + done +} + +# @ECLASS-VARIABLE: python_moduleroot +# @DEFAULT_UNSET +# @DESCRIPTION: +# The current module root for python_domodule(). The path can be either +# an absolute system path (it must start with a slash, and ${D} will be +# prepended to it) or relative to the implementation's site-packages directory +# (then it must start with a non-slash character). +# +# When unset, the modules will be installed in the site-packages root. +# +# Can be set indirectly through the python_moduleinto() function. +# +# Example: +# @CODE +# src_install() { +# local python_moduleroot=bar +# # installs ${PYTHON_SITEDIR}/bar/baz.py +# python_foreach_impl python_domodule baz.py +# } +# @CODE + +# @FUNCTION: python_moduleinto +# @USAGE: <new-path> +# @DESCRIPTION: +# Set the current module root. The new value will be stored +# in the 'python_moduleroot' environment variable. The new value need +# be relative to the site-packages root. +# +# Alternatively, you can set the variable directly. +python_moduleinto() { + debug-print-function ${FUNCNAME} "${@}" + + python_moduleroot=${1} +} + +# @FUNCTION: python_domodule +# @USAGE: <files>... +# @DESCRIPTION: +# Install the given modules (or packages) into the current +# python_moduleroot. The list can mention both modules (files) +# and packages (directories). All listed files will be installed +# for all enabled implementations, and compiled afterwards. +# +# Example: +# @CODE +# src_install() { +# # (${PN} being a directory) +# python_foreach_impl python_domodule ${PN} +# } +# @CODE +python_domodule() { + debug-print-function ${FUNCNAME} "${@}" + + [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' + + local d + if [[ ${python_moduleroot} == /* ]]; then + # absolute path + d=${python_moduleroot} + else + # relative to site-packages + local PYTHON_SITEDIR=${PYTHON_SITEDIR} + [[ ${PYTHON_SITEDIR} ]] || python_export PYTHON_SITEDIR + + d=${PYTHON_SITEDIR}/${python_moduleroot} + fi + + local INSDESTTREE + + insinto "${d}" + doins -r "${@}" + + # erm, python2.6 can't handle passing files to compileall... + case "${EPYTHON}" in + python*) + "${PYTHON}" -m compileall -q "${D}/${d}" + "${PYTHON}" -OO -m compileall -q -f "${D}/${d}" + ;; + *) + "${PYTHON}" -m compileall -q "${D}/${d}" + ;; + esac +} -- 1.8.0