diff options
-rw-r--r-- | eclass/python.eclass | 41 |
1 files changed, 27 insertions, 14 deletions
diff --git a/eclass/python.eclass b/eclass/python.eclass index d0d5aaac913a..690a4efa057a 100644 --- a/eclass/python.eclass +++ b/eclass/python.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2009 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/python.eclass,v 1.67 2009/08/29 02:15:24 arfrever Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/python.eclass,v 1.68 2009/08/31 00:07:37 arfrever Exp $ # @ECLASS: python.eclass # @MAINTAINER: @@ -130,28 +130,41 @@ validate_PYTHON_ABIS() { if [[ -z "${PYTHON_ABIS}" ]] && has "${EAPI:-0}" 0 1 2 3; then local ABI support_ABI supported_PYTHON_ABIS= restricted_ABI PYTHON_ABI_SUPPORTED_VALUES="2.4 2.5 2.6 2.7 3.0 3.1 3.2" - for ABI in ${USE_PYTHON}; do - if ! has "${ABI}" ${PYTHON_ABI_SUPPORTED_VALUES}; then - ewarn "Ignoring unsupported Python ABI '${ABI}'" - continue + + if declare -p | grep "^declare -x USE_PYTHON=" > /dev/null; then + if [[ -z "${USE_PYTHON}" ]]; then + die "USE_PYTHON variable is empty" fi - support_ABI="1" - if [[ -z "${IGNORE_RESTRICT_PYTHON_ABIS}" ]]; then + + for ABI in ${USE_PYTHON}; do + if ! has "${ABI}" ${PYTHON_ABI_SUPPORTED_VALUES}; then + die "USE_PYTHON variable contains invalid value '${ABI}'" + fi + support_ABI="1" for restricted_ABI in ${RESTRICT_PYTHON_ABIS}; do if python -c "from fnmatch import fnmatch; exit(not fnmatch('${ABI}', '${restricted_ABI}'))"; then support_ABI="0" break fi done + [[ "${support_ABI}" == "1" ]] && supported_PYTHON_ABIS+=" ${ABI}" + done + export PYTHON_ABIS="${supported_PYTHON_ABIS# }" + + if [[ -z "${PYTHON_ABIS//[${IFS}]/}" ]]; then + die "USE_PYTHON variable doesn't enable any Python version supported by ${CATEGORY}/${PF}" fi - [[ "${support_ABI}" == "1" ]] && supported_PYTHON_ABIS+=" ${ABI}" - done - export PYTHON_ABIS="${supported_PYTHON_ABIS# }" - fi + else + local restricted_ABI + python_version - if [[ -z "${PYTHON_ABIS//[${IFS}]/}" ]]; then - python_version - export PYTHON_ABIS="${PYVER}" + for restricted_ABI in ${RESTRICT_PYTHON_ABIS}; do + if python -c "from fnmatch import fnmatch; exit(not fnmatch('${PYVER}', '${restricted_ABI}'))"; then + die "Active Python version isn't supported by ${CATEGORY}/${PF}" + fi + done + export PYTHON_ABIS="${PYVER}" + fi fi # Ensure that EPYTHON variable is respected. |