diff options
author | Michał Górny <mgorny@gentoo.org> | 2013-01-21 19:28:16 +0000 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2013-01-21 19:28:16 +0000 |
commit | e8c2b0b1c1eb4acda80e5afa6cb154acef775d20 (patch) | |
tree | e70747a29bc6d425ddc169f1e84e83df8bf29760 /eclass | |
parent | old (diff) | |
download | gentoo-2-e8c2b0b1c1eb4acda80e5afa6cb154acef775d20.tar.gz gentoo-2-e8c2b0b1c1eb4acda80e5afa6cb154acef775d20.tar.bz2 gentoo-2-e8c2b0b1c1eb4acda80e5afa6cb154acef775d20.zip |
Check PYTHON_COMPAT for validity, and support disabling implementations in the eclass.
Diffstat (limited to 'eclass')
-rw-r--r-- | eclass/ChangeLog | 7 | ||||
-rw-r--r-- | eclass/python-any-r1.eclass | 13 | ||||
-rw-r--r-- | eclass/python-r1.eclass | 52 | ||||
-rw-r--r-- | eclass/python-single-r1.eclass | 41 | ||||
-rw-r--r-- | eclass/python-utils-r1.eclass | 33 |
5 files changed, 112 insertions, 34 deletions
diff --git a/eclass/ChangeLog b/eclass/ChangeLog index 1d6a9a8fa56a..abe458b051fd 100644 --- a/eclass/ChangeLog +++ b/eclass/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for eclass directory # Copyright 1999-2013 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/ChangeLog,v 1.630 2013/01/21 19:22:25 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/ChangeLog,v 1.631 2013/01/21 19:28:16 mgorny Exp $ + + 21 Jan 2013; Michał Górny <mgorny@gentoo.org> python-any-r1.eclass, + python-r1.eclass, python-single-r1.eclass, python-utils-r1.eclass: + Check PYTHON_COMPAT for validity, and support disabling implementations in + the eclass. 21 Jan 2013; Michał Górny <mgorny@gentoo.org> multilib.eclass: Set PKG_CONFIG_{LIBDIR,PATH} for multilib builds. Approved by vapier in bug diff --git a/eclass/python-any-r1.eclass b/eclass/python-any-r1.eclass index 199602a2e00a..5d9a3d1e5955 100644 --- a/eclass/python-any-r1.eclass +++ b/eclass/python-any-r1.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/python-any-r1.eclass,v 1.5 2013/01/02 21:12:44 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/python-any-r1.eclass,v 1.6 2013/01/21 19:28:16 mgorny Exp $ # @ECLASS: python-any-r1 # @MAINTAINER: @@ -134,13 +134,13 @@ _python_build_set_globals() { } _python_build_set_globals -# @FUNCTION: _python_impl_supported +# @FUNCTION: _python_EPYTHON_supported # @USAGE: <epython> # @INTERNAL # @DESCRIPTION: # Check whether the specified implementation is supported by package # (specified in PYTHON_COMPAT). -_python_impl_supported() { +_python_EPYTHON_supported() { debug-print-function ${FUNCNAME} "${@}" local i=${1/./_} @@ -153,6 +153,7 @@ _python_impl_supported() { ;; *) ewarn "Invalid EPYTHON: ${EPYTHON}" + return 1 ;; esac @@ -173,7 +174,7 @@ python-any-r1_pkg_setup() { # first, try ${EPYTHON}... maybe it's good enough for us. if [[ ${EPYTHON} ]]; then - if _python_impl_supported "${EPYTHON}"; then + if _python_EPYTHON_supported "${EPYTHON}"; then python_export EPYTHON PYTHON return fi @@ -187,7 +188,7 @@ python-any-r1_pkg_setup() { if [[ ! ${i} ]]; then # no eselect-python? break - elif _python_impl_supported "${i}"; then + elif _python_EPYTHON_supported "${i}"; then python_export "${i}" EPYTHON PYTHON return fi @@ -206,8 +207,6 @@ python-any-r1_pkg_setup() { python_export "${i}" PYTHON_PKG_DEP EPYTHON PYTHON ROOT=/ has_version "${PYTHON_PKG_DEP}" && return done - - die $EPYTHON } _PYTHON_ANY_R1=1 diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass index 855772716c08..63dc556b3497 100644 --- a/eclass/python-r1.eclass +++ b/eclass/python-r1.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/python-r1.eclass,v 1.36 2013/01/08 16:36:16 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/python-r1.eclass,v 1.37 2013/01/21 19:28:16 mgorny Exp $ # @ECLASS: python-r1 # @MAINTAINER: @@ -132,7 +132,24 @@ fi # @CODE _python_set_globals() { - local flags=( "${PYTHON_COMPAT[@]/#/python_targets_}" ) + local impls=() + + PYTHON_DEPS= + local i PYTHON_PKG_DEP + for i in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${i}" || continue + + python_export "${i}" PYTHON_PKG_DEP + PYTHON_DEPS+="python_targets_${i}? ( ${PYTHON_PKG_DEP} ) " + + impls+=( "${i}" ) + done + + if [[ ${#impls[@]} -eq 0 ]]; then + die "No supported implementation in PYTHON_COMPAT." + fi + + local flags=( "${impls[@]/#/python_targets_}" ) local optflags=${flags[@]/%/?} # A nice QA trick here. Since a python-single-r1 package has to have @@ -141,7 +158,7 @@ _python_set_globals() { # it should prevent developers from mistakenly depending on packages # not supporting multiple Python implementations. - local flags_st=( "${PYTHON_COMPAT[@]/#/-python_single_target_}" ) + local flags_st=( "${impls[@]/#/-python_single_target_}" ) optflags+=,${flags_st[@]/%/(-)} IUSE=${flags[*]} @@ -152,12 +169,7 @@ _python_set_globals() { # but no point in making this overcomplex, BDEP doesn't hurt anyone # 2) python-exec should be built with all targets forced anyway # but if new targets were added, we may need to force a rebuild - PYTHON_DEPS="dev-python/python-exec[${PYTHON_USEDEP}]" - local i PYTHON_PKG_DEP - for i in "${PYTHON_COMPAT[@]}"; do - python_export "${i}" PYTHON_PKG_DEP - PYTHON_DEPS+=" python_targets_${i}? ( ${PYTHON_PKG_DEP} )" - done + PYTHON_DEPS+="dev-python/python-exec[${PYTHON_USEDEP}]" } _python_set_globals @@ -171,6 +183,8 @@ _python_validate_useflags() { local i for i in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${i}" || continue + use "python_targets_${i}" && return 0 done @@ -210,6 +224,8 @@ python_gen_usedep() { local matches=() for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + for pattern; do if [[ ${impl} == ${pattern} ]]; then matches+=( @@ -249,6 +265,8 @@ python_gen_useflags() { local matches=() for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + for pattern; do if [[ ${impl} == ${pattern} ]]; then matches+=( "python_targets_${impl}" ) @@ -292,6 +310,8 @@ python_gen_cond_dep() { shift for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + for pattern; do if [[ ${impl} == ${pattern} ]]; then matches+=( "python_targets_${impl}? ( ${dep} )" ) @@ -337,6 +357,8 @@ python_copy_sources() { einfo "Will copy sources from ${S}" # the order is irrelevant here for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + if use "python_targets_${impl}" then local BUILD_DIR=${bdir%%/}-${impl} @@ -369,6 +391,8 @@ _python_check_USE_PYTHON() { local impl py2 py3 dis_py2 dis_py3 for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + if use "python_targets_${impl}"; then case "${impl}" in python2_*) @@ -480,6 +504,8 @@ _python_check_USE_PYTHON() { local impl old=${USE_PYTHON} new=() removed=() for impl in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${impl}" || continue + local abi case "${impl}" in python*) @@ -573,7 +599,9 @@ python_foreach_impl() { debug-print "${FUNCNAME}: bdir = ${bdir}" for impl in "${_PYTHON_ALL_IMPLS[@]}"; do - if has "${impl}" "${PYTHON_COMPAT[@]}" && use "python_targets_${impl}" + if has "${impl}" "${PYTHON_COMPAT[@]}" \ + && _python_impl_supported "${impl}" \ + && use "python_targets_${impl}" then local EPYTHON PYTHON python_export "${impl}" EPYTHON PYTHON @@ -601,7 +629,9 @@ python_export_best() { local impl best for impl in "${_PYTHON_ALL_IMPLS[@]}"; do - if has "${impl}" "${PYTHON_COMPAT[@]}" && use "python_targets_${impl}" + if has "${impl}" "${PYTHON_COMPAT[@]}" \ + && _python_impl_supported "${impl}" \ + && use "python_targets_${impl}" then best=${impl} fi diff --git a/eclass/python-single-r1.eclass b/eclass/python-single-r1.eclass index fe2625169022..76dea7aa4d67 100644 --- a/eclass/python-single-r1.eclass +++ b/eclass/python-single-r1.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/python-single-r1.eclass,v 1.13 2013/01/08 20:18:38 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/python-single-r1.eclass,v 1.14 2013/01/21 19:28:16 mgorny Exp $ # @ECLASS: python-single-r1 # @MAINTAINER: @@ -134,8 +134,31 @@ fi # @CODE _python_single_set_globals() { - local flags_mt=( "${PYTHON_COMPAT[@]/#/python_targets_}" ) - local flags=( "${PYTHON_COMPAT[@]/#/python_single_target_}" ) + local impls=() + + PYTHON_DEPS= + local i PYTHON_PKG_DEP + for i in "${PYTHON_COMPAT[@]}"; do + _python_impl_supported "${i}" || continue + + # The chosen targets need to be in PYTHON_TARGETS as well. + # This is in order to enforce correct dependencies on packages + # supporting multiple implementations. + #REQUIRED_USE+=" python_single_target_${i}? ( python_targets_${i} )" + + python_export "${i}" PYTHON_PKG_DEP + PYTHON_DEPS+="python_single_target_${i}? ( ${PYTHON_PKG_DEP} ) " + + impls+=( "${i}" ) + done + + if [[ ${#impls[@]} -eq 0 ]]; then + die "No supported implementation in PYTHON_COMPAT." + fi + + local flags_mt=( "${impls[@]/#/python_targets_}" ) + local flags=( "${impls[@]/#/python_single_target_}" ) + local optflags=${flags_mt[@]/%/?} optflags+=,${flags[@]/%/(+)?} @@ -147,17 +170,7 @@ _python_single_set_globals() { # but no point in making this overcomplex, BDEP doesn't hurt anyone # 2) python-exec should be built with all targets forced anyway # but if new targets were added, we may need to force a rebuild - PYTHON_DEPS="dev-python/python-exec[${PYTHON_USEDEP}]" - local i PYTHON_PKG_DEP - for i in "${PYTHON_COMPAT[@]}"; do - # The chosen targets need to be in PYTHON_TARGETS as well. - # This is in order to enforce correct dependencies on packages - # supporting multiple implementations. - #REQUIRED_USE+=" python_single_target_${i}? ( python_targets_${i} )" - - python_export "${i}" PYTHON_PKG_DEP - PYTHON_DEPS+=" python_single_target_${i}? ( ${PYTHON_PKG_DEP} )" - done + PYTHON_DEPS+="dev-python/python-exec[${PYTHON_USEDEP}]" } _python_single_set_globals diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass index ba270b52d774..474ac08a9d21 100644 --- a/eclass/python-utils-r1.eclass +++ b/eclass/python-utils-r1.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/python-utils-r1.eclass,v 1.13 2013/01/05 10:01:20 mgorny Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/python-utils-r1.eclass,v 1.14 2013/01/21 19:28:16 mgorny Exp $ # @ECLASS: python-utils-r1 # @MAINTAINER: @@ -47,6 +47,37 @@ _PYTHON_ALL_IMPLS=( python2_5 python2_6 python2_7 ) +# @FUNCTION: _python_impl_supported +# @USAGE: <impl> +# @INTERNAL +# @DESCRIPTION: +# Check whether the implementation <impl> (PYTHON_COMPAT-form) +# is still supported. +# +# Returns 0 if the implementation is valid and supported. If it is +# unsupported, returns 1 -- and the caller should ignore the entry. +# If it is invalid, dies with an appopriate error messages. +_python_impl_supported() { + debug-print-function ${FUNCNAME} "${@}" + + [[ ${#} -eq 1 ]] || die "${FUNCNAME}: takes exactly 1 argument (impl)." + + local impl=${1} + + # keep in sync with _PYTHON_ALL_IMPLS! + # (not using that list because inline patterns shall be faster) + case "${impl}" in + python2_[567]|python3_[123]|pypy1_[89]|pypy2_0|jython2_5) + return 0 + ;; +# pypy1_8) +# return 1 +# ;; + *) + die "Invalid implementation in PYTHON_COMPAT: ${impl}" + esac +} + # @ECLASS-VARIABLE: PYTHON # @DESCRIPTION: # The absolute path to the current Python interpreter. |