/[gentoo-x86]/eclass/distutils.eclass
Gentoo

Diff of /eclass/distutils.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.72 Revision 1.79
1# Copyright 1999-2010 Gentoo Foundation 1# Copyright 1999-2010 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/distutils.eclass,v 1.72 2010/02/08 09:35:38 pva Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/distutils.eclass,v 1.79 2010/12/24 15:05:24 arfrever Exp $
4 4
5# @ECLASS: distutils.eclass 5# @ECLASS: distutils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Gentoo Python Project <python@gentoo.org> 7# Gentoo Python Project <python@gentoo.org>
8# 8#
9# Original author: Jon Nelson <jnelson@gentoo.org> 9# Original author: Jon Nelson <jnelson@gentoo.org>
10# @BLURB: Eclass for packages with build systems using Distutils 10# @BLURB: Eclass for packages with build systems using Distutils
11# @DESCRIPTION: 11# @DESCRIPTION:
12# The distutils eclass defines phase functions for packages with build systems using Distutils 12# The distutils eclass defines phase functions for packages with build systems using Distutils.
13 13
14inherit multilib python 14inherit multilib python
15 15
16case "${EAPI:-0}" in 16case "${EAPI:-0}" in
17 0|1) 17 0|1)
18 EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_postinst pkg_postrm 18 EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_postinst pkg_postrm
19 ;; 19 ;;
20 *) 20 *)
21 EXPORT_FUNCTIONS src_unpack src_prepare src_compile src_install pkg_postinst pkg_postrm 21 EXPORT_FUNCTIONS src_prepare src_compile src_install pkg_postinst pkg_postrm
22 ;; 22 ;;
23esac 23esac
24 24
25if [[ -z "${PYTHON_DEPEND}" ]]; then 25if [[ -z "$(declare -p PYTHON_DEPEND 2> /dev/null)" ]]; then
26 DEPEND="virtual/python" 26 DEPEND="dev-lang/python"
27 RDEPEND="${DEPEND}" 27 RDEPEND="${DEPEND}"
28fi 28fi
29 29
30if has "${EAPI:-0}" 0 1 2; then 30if [[ -n "${PYTHON_DEPRECATION_WARNINGS}" ]]; then
31 if has "${EAPI:-0}" 0 1 && [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
32 ewarn
33 ewarn "\"${EBUILD}\":"
34 ewarn "Deprecation Warning: Usage of distutils.eclass in packages supporting installation"
35 ewarn "for multiple Python ABIs in EAPI <=1 is deprecated and will be banned on 2011-06-01."
36 ewarn "The ebuild needs to be fixed. Please report a bug, if it has not been already reported."
37 ewarn
38 elif has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then
39 ewarn
40 ewarn "\"${EBUILD}\":"
41 ewarn "Deprecation Warning: Usage of distutils.eclass in packages not supporting installation"
42 ewarn "for multiple Python ABIs in EAPI <=2 is deprecated and will be banned on 2011-06-01."
43 ewarn "The ebuild needs to be fixed. Please report a bug, if it has not been already reported."
44 ewarn
45 fi
46fi
47
48# 'python' variable is deprecated. Use PYTHON() instead.
49if has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then
31 python="python" 50 python="python"
32else 51else
33 # Use "$(PYTHON)" or "$(PYTHON -A)" instead of "${python}".
34 python="die" 52 python="die"
35fi 53fi
36 54
37# @ECLASS-VARIABLE: DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES 55# @ECLASS-VARIABLE: DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES
38# @DESCRIPTION: 56# @DESCRIPTION:
39# Set this to use separate source directories for each enabled version of Python. 57# Set this to use separate source directories for each enabled version of Python.
40 58
59# @ECLASS-VARIABLE: DISTUTILS_SETUP_FILES
60# @DESCRIPTION:
61# Paths to setup files.
62
41# @ECLASS-VARIABLE: DISTUTILS_GLOBAL_OPTIONS 63# @ECLASS-VARIABLE: DISTUTILS_GLOBAL_OPTIONS
42# @DESCRIPTION: 64# @DESCRIPTION:
43# Global options passed to setup.py. 65# Global options passed to setup files.
44 66
45# @ECLASS-VARIABLE: DISTUTILS_SRC_TEST 67# @ECLASS-VARIABLE: DISTUTILS_SRC_TEST
46# @DESCRIPTION: 68# @DESCRIPTION:
47# Type of test command used by distutils_src_test(). 69# Type of test command used by distutils_src_test().
48# IUSE and DEPEND are automatically adjusted, unless DISTUTILS_DISABLE_TEST_DEPENDENCY is set. 70# IUSE and DEPEND are automatically adjusted, unless DISTUTILS_DISABLE_TEST_DEPENDENCY is set.
64 if [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then 86 if [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then
65 IUSE="test" 87 IUSE="test"
66 DEPEND+="${DEPEND:+ }test? ( dev-python/nose )" 88 DEPEND+="${DEPEND:+ }test? ( dev-python/nose )"
67 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then 89 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then
68 IUSE="test" 90 IUSE="test"
69 DEPEND+="${DEPEND:+ }test? ( dev-python/py )" 91 DEPEND+="${DEPEND:+ }test? ( dev-python/pytest )"
70 # trial requires an argument, which is usually equal to "${PN}". 92 # trial requires an argument, which is usually equal to "${PN}".
71 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then 93 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then
72 IUSE="test" 94 IUSE="test"
73 DEPEND+="${DEPEND:+ }test? ( dev-python/twisted )" 95 DEPEND+="${DEPEND:+ }test? ( dev-python/twisted )"
74 fi 96 fi
80 102
81# @ECLASS-VARIABLE: DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS 103# @ECLASS-VARIABLE: DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS
82# @DESCRIPTION: 104# @DESCRIPTION:
83# Set this to disable renaming of Python scripts containing versioned shebangs 105# Set this to disable renaming of Python scripts containing versioned shebangs
84# and generation of wrapper scripts. 106# and generation of wrapper scripts.
107if [[ -n "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" ]]; then
108 ewarn
109 ewarn "\"${EBUILD}\":"
110 ewarn "Deprecation Warning: DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS is deprecated"
111 ewarn "and will be banned on 2011-02-01. Use PYTHON_NONVERSIONED_EXECUTABLES=(\".*\")."
112 ewarn "The ebuild needs to be fixed. Please report a bug, if it has not been already reported."
113 ewarn
114
115 PYTHON_NONVERSIONED_EXECUTABLES=(".*")
116fi
85 117
86# @ECLASS-VARIABLE: DOCS 118# @ECLASS-VARIABLE: DOCS
87# @DESCRIPTION: 119# @DESCRIPTION:
88# Additional documentation files installed by distutils_src_install(). 120# Additional documentation files installed by distutils_src_install().
89 121
90_distutils_get_build_dir() { 122_distutils_get_build_dir() {
91 if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then 123 if _python_package_supporting_installation_for_multiple_python_abis && [[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then
92 echo "build-${PYTHON_ABI}" 124 echo "build-${PYTHON_ABI}"
93 else 125 else
94 echo "build" 126 echo "build"
95 fi 127 fi
96} 128}
97 129
98_distutils_get_PYTHONPATH() { 130_distutils_get_PYTHONPATH() {
99 if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then 131 if _python_package_supporting_installation_for_multiple_python_abis && [[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then
100 ls -d build-${PYTHON_ABI}/lib* 2> /dev/null 132 ls -d build-${PYTHON_ABI}/lib* 2> /dev/null
101 else 133 else
102 ls -d build/lib* 2> /dev/null 134 ls -d build/lib* 2> /dev/null
103 fi 135 fi
104} 136}
114 146
115# @FUNCTION: distutils_src_unpack 147# @FUNCTION: distutils_src_unpack
116# @DESCRIPTION: 148# @DESCRIPTION:
117# The distutils src_unpack function. This function is exported. 149# The distutils src_unpack function. This function is exported.
118distutils_src_unpack() { 150distutils_src_unpack() {
151 if ! has "${EAPI:-0}" 0 1; then
152 die "${FUNCNAME}() cannot be used in this EAPI"
153 fi
154
119 if [[ "${EBUILD_PHASE}" != "unpack" ]]; then 155 if [[ "${EBUILD_PHASE}" != "unpack" ]]; then
120 die "${FUNCNAME}() can be used only in src_unpack() phase" 156 die "${FUNCNAME}() can be used only in src_unpack() phase"
121 fi 157 fi
122 158
123 unpack ${A} 159 unpack ${A}
124 cd "${S}" 160 cd "${S}"
125 161
126 has "${EAPI:-0}" 0 1 && distutils_src_prepare 162 distutils_src_prepare
127} 163}
128 164
129# @FUNCTION: distutils_src_prepare 165# @FUNCTION: distutils_src_prepare
130# @DESCRIPTION: 166# @DESCRIPTION:
131# The distutils src_prepare function. This function is exported. 167# The distutils src_prepare function. This function is exported.
163distutils_src_compile() { 199distutils_src_compile() {
164 if [[ "${EBUILD_PHASE}" != "compile" ]]; then 200 if [[ "${EBUILD_PHASE}" != "compile" ]]; then
165 die "${FUNCNAME}() can be used only in src_compile() phase" 201 die "${FUNCNAME}() can be used only in src_compile() phase"
166 fi 202 fi
167 203
168 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 204 _python_set_color_variables
205
206 if _python_package_supporting_installation_for_multiple_python_abis; then
169 distutils_building() { 207 distutils_building() {
170 _distutils_hook pre 208 _distutils_hook pre
171 209
210 local setup_file
211 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
172 echo "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" 212 echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@"${_NORMAL}
173 "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" || return "$?" 213 "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" || return "$?"
214 done
174 215
175 _distutils_hook post 216 _distutils_hook post
176 } 217 }
177 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_building "$@" 218 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_building "$@"
178 else 219 else
220 local setup_file
221 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
179 echo "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" 222 echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@"${_NORMAL}
180 "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" || die "Building failed" 223 "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" || die "Building failed"
224 done
225 fi
226}
227
228_distutils_src_test_hook() {
229 if [[ "$#" -ne 1 ]]; then
230 die "${FUNCNAME}() requires 1 arguments"
231 fi
232
233 if ! _python_package_supporting_installation_for_multiple_python_abis; then
234 return
235 fi
236
237 if [[ "$(type -t "distutils_src_test_pre_hook")" == "function" ]]; then
238 eval "python_execute_$1_pre_hook() {
239 distutils_src_test_pre_hook
240 }"
241 fi
242
243 if [[ "$(type -t "distutils_src_test_post_hook")" == "function" ]]; then
244 eval "python_execute_$1_post_hook() {
245 distutils_src_test_post_hook
246 }"
181 fi 247 fi
182} 248}
183 249
184# @FUNCTION: distutils_src_test 250# @FUNCTION: distutils_src_test
185# @DESCRIPTION: 251# @DESCRIPTION:
186# The distutils src_test function. This function is exported, when DISTUTILS_SRC_TEST variable is set. 252# The distutils src_test function. This function is exported, when DISTUTILS_SRC_TEST variable is set.
253# In ebuilds of packages supporting installation for multiple versions of Python, this function
254# calls distutils_src_test_pre_hook() and distutils_src_test_post_hook(), if they are defined.
187distutils_src_test() { 255distutils_src_test() {
256 if [[ "${EBUILD_PHASE}" != "test" ]]; then
257 die "${FUNCNAME}() can be used only in src_test() phase"
258 fi
259
260 _python_set_color_variables
261
188 if [[ "${DISTUTILS_SRC_TEST}" == "setup.py" ]]; then 262 if [[ "${DISTUTILS_SRC_TEST}" == "setup.py" ]]; then
189 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 263 if _python_package_supporting_installation_for_multiple_python_abis; then
190 distutils_testing() { 264 distutils_testing() {
265 _distutils_hook pre
266
267 local setup_file
268 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
191 echo PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@" 269 echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@"${_NORMAL}
192 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@" 270 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@" || return "$?"
271 done
272
273 _distutils_hook post
193 } 274 }
194 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_testing "$@" 275 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_testing "$@"
195 else 276 else
277 local setup_file
278 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
196 echo PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed" 279 echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@"${_NORMAL}
197 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed" 280 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed"
281 done
198 fi 282 fi
199 elif [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then 283 elif [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then
284 _distutils_src_test_hook nosetests
285
200 python_execute_nosetests -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@" 286 python_execute_nosetests -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@"
201 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then 287 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then
288 _distutils_src_test_hook py.test
289
202 python_execute_py.test -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@" 290 python_execute_py.test -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@"
203 # trial requires an argument, which is usually equal to "${PN}". 291 # trial requires an argument, which is usually equal to "${PN}".
204 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then 292 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then
205 local trial_arguments 293 local trial_arguments
206 if [[ "${DISTUTILS_SRC_TEST}" == "trial "* ]]; then 294 if [[ "${DISTUTILS_SRC_TEST}" == "trial "* ]]; then
207 trial_arguments="${DISTUTILS_SRC_TEST#trial }" 295 trial_arguments="${DISTUTILS_SRC_TEST#trial }"
208 else 296 else
209 trial_arguments="${PN}" 297 trial_arguments="${PN}"
210 fi 298 fi
211 299
300 _distutils_src_test_hook trial
301
212 python_execute_trial -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- ${trial_arguments} "$@" 302 python_execute_trial -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- ${trial_arguments} "$@"
213 else 303 else
214 die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'" 304 die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'"
215 fi 305 fi
216} 306}
225distutils_src_install() { 315distutils_src_install() {
226 if [[ "${EBUILD_PHASE}" != "install" ]]; then 316 if [[ "${EBUILD_PHASE}" != "install" ]]; then
227 die "${FUNCNAME}() can be used only in src_install() phase" 317 die "${FUNCNAME}() can be used only in src_install() phase"
228 fi 318 fi
229 319
230 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 320 _python_initialize_prefix_variables
231 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then 321 _python_set_color_variables
232 declare -A wrapper_scripts=()
233 322
234 rename_scripts_with_versioned_shebangs() { 323 if _python_package_supporting_installation_for_multiple_python_abis; then
235 if [[ -d "${D}usr/bin" ]]; then
236 cd "${D}usr/bin"
237
238 local file
239 for file in *; do
240 if [[ -f "${file}" && ! "${file}" =~ [[:digit:]]+\.[[:digit:]]+$ && "$(head -n1 "${file}")" =~ ^'#!'.*python[[:digit:]]+\.[[:digit:]]+ ]]; then
241 mv "${file}" "${file}-${PYTHON_ABI}" || die "Renaming of '${file}' failed"
242 wrapper_scripts+=(["${D}usr/bin/${file}"]=)
243 fi
244 done
245 fi
246 }
247 fi
248
249 distutils_installation() { 324 distutils_installation() {
250 _distutils_hook pre 325 _distutils_hook pre
251 326
327 local setup_file
328 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
252 echo "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --root="${D}" --no-compile "$@" 329 echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --no-compile --root="${T}/images/${PYTHON_ABI}" "$@"${_NORMAL}
253 "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --root="${D}" --no-compile "$@" || return "$?" 330 "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --no-compile --root="${T}/images/${PYTHON_ABI}" "$@" || return "$?"
254 331 done
255 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then
256 rename_scripts_with_versioned_shebangs
257 fi
258 332
259 _distutils_hook post 333 _distutils_hook post
260 } 334 }
261 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_installation "$@" 335 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_installation "$@"
262 336
263 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${#wrapper_scripts[@]}" -ne 0 && "${BASH_VERSINFO[0]}" -ge 4 ]]; then 337 python_merge_intermediate_installation_images "${T}/images"
264 python_generate_wrapper_scripts "${!wrapper_scripts[@]}"
265 fi
266 unset wrapper_scripts
267 else 338 else
268 # Mark the package to be rebuilt after a Python upgrade. 339 # Mark the package to be rebuilt after a Python upgrade.
269 python_need_rebuild 340 python_need_rebuild
270 341
342 local setup_file
343 for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do
271 echo "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" 344 echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@"${_NORMAL}
272 "$(PYTHON -A)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" || die "Installation failed" 345 "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" || die "Installation failed"
346 done
273 fi 347 fi
274 348
275 if [[ -e "${D}usr/local" ]]; then 349 if [[ -e "${ED}usr/local" ]]; then
276 die "Illegal installation into /usr/local" 350 die "Illegal installation into /usr/local"
277 fi 351 fi
278 352
279 local default_docs 353 local default_docs
280 default_docs="AUTHORS Change* CHANGELOG CONTRIBUTORS KNOWN_BUGS MAINTAINERS MANIFEST* NEWS PKG-INFO README* TODO" 354 default_docs="AUTHORS Change* CHANGELOG CONTRIBUTORS KNOWN_BUGS MAINTAINERS MANIFEST* NEWS PKG-INFO README* TODO"
298distutils_pkg_postinst() { 372distutils_pkg_postinst() {
299 if [[ "${EBUILD_PHASE}" != "postinst" ]]; then 373 if [[ "${EBUILD_PHASE}" != "postinst" ]]; then
300 die "${FUNCNAME}() can be used only in pkg_postinst() phase" 374 die "${FUNCNAME}() can be used only in pkg_postinst() phase"
301 fi 375 fi
302 376
377 _python_initialize_prefix_variables
378
303 local pylibdir pymod 379 local pylibdir pymod
304 if [[ -z "${PYTHON_MODNAME}" ]]; then 380 if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then
305 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 381 for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"usr/share/jython-*/Lib; do
306 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then 382 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then
307 PYTHON_MODNAME="${PN}" 383 PYTHON_MODNAME="${PN}"
308 fi 384 fi
309 done 385 done
310 fi 386 fi
311 387
312 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 388 if [[ -n "${PYTHON_MODNAME}" ]]; then
389 if ! has "${EAPI:-0}" 0 1 2 || _python_package_supporting_installation_for_multiple_python_abis; then
313 python_mod_optimize ${PYTHON_MODNAME} 390 python_mod_optimize ${PYTHON_MODNAME}
314 else 391 else
315 for pymod in ${PYTHON_MODNAME}; do 392 for pymod in ${PYTHON_MODNAME}; do
316 python_mod_optimize "$(python_get_sitedir)/${pymod}" 393 python_mod_optimize "$(python_get_sitedir)/${pymod}"
317 done 394 done
395 fi
318 fi 396 fi
319} 397}
320 398
321# @FUNCTION: distutils_pkg_postrm 399# @FUNCTION: distutils_pkg_postrm
322# @DESCRIPTION: 400# @DESCRIPTION:
327distutils_pkg_postrm() { 405distutils_pkg_postrm() {
328 if [[ "${EBUILD_PHASE}" != "postrm" ]]; then 406 if [[ "${EBUILD_PHASE}" != "postrm" ]]; then
329 die "${FUNCNAME}() can be used only in pkg_postrm() phase" 407 die "${FUNCNAME}() can be used only in pkg_postrm() phase"
330 fi 408 fi
331 409
410 _python_initialize_prefix_variables
411
332 local pylibdir pymod 412 local pylibdir pymod
333 if [[ -z "${PYTHON_MODNAME}" ]]; then 413 if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then
334 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 414 for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"usr/share/jython-*/Lib; do
335 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then 415 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then
336 PYTHON_MODNAME="${PN}" 416 PYTHON_MODNAME="${PN}"
337 fi 417 fi
338 done 418 done
339 fi 419 fi
340 420
341 if [[ -n "${PYTHON_MODNAME}" ]]; then 421 if [[ -n "${PYTHON_MODNAME}" ]]; then
342 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 422 if ! has "${EAPI:-0}" 0 1 2 || _python_package_supporting_installation_for_multiple_python_abis; then
343 python_mod_cleanup ${PYTHON_MODNAME} 423 python_mod_cleanup ${PYTHON_MODNAME}
344 else 424 else
345 for pymod in ${PYTHON_MODNAME}; do 425 for pymod in ${PYTHON_MODNAME}; do
346 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 426 for pylibdir in "${EROOT}"usr/$(get_libdir)/python*; do
347 if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then 427 if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then
348 python_mod_cleanup "${pylibdir#${ROOT}}/site-packages/${pymod}" 428 python_mod_cleanup "${pylibdir#${EROOT%/}}/site-packages/${pymod}"
349 fi 429 fi
350 done 430 done
351 done 431 done
352 fi 432 fi
353 else
354 python_mod_cleanup
355 fi 433 fi
356} 434}
357 435
358# @FUNCTION: distutils_python_version 436# Scheduled for deletion on 2011-01-01.
359# @DESCRIPTION:
360# Deprecated wrapper function for deprecated python_version().
361distutils_python_version() { 437distutils_python_version() {
362 if ! has "${EAPI:-0}" 0 1 2; then 438 eerror "Use PYTHON() instead of python variable. Use python_get_*() instead of PYVER* variables."
363 eerror "Use PYTHON() and/or python_get_*() instead of ${FUNCNAME}()." 439 die "${FUNCNAME}() is banned"
364 die "${FUNCNAME}() cannot be used in this EAPI"
365 fi
366
367 python_version
368} 440}
369 441
370# @FUNCTION: distutils_python_tkinter 442# Scheduled for deletion on 2011-01-01.
371# @DESCRIPTION:
372# Deprecated wrapper function for python_tkinter_exists().
373distutils_python_tkinter() { 443distutils_python_tkinter() {
374 if ! has "${EAPI:-0}" 0 1 2; then 444 eerror "Use PYTHON_USE_WITH=\"xml\" and python_pkg_setup() instead of ${FUNCNAME}()."
375 eerror "Use python_tkinter_exists() instead of ${FUNCNAME}()." 445 die "${FUNCNAME}() is banned"
376 die "${FUNCNAME}() cannot be used in this EAPI"
377 fi
378
379 python_tkinter_exists
380} 446}

Legend:
Removed from v.1.72  
changed lines
  Added in v.1.79

  ViewVC Help
Powered by ViewVC 1.1.20