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

Diff of /eclass/distutils.eclass

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

Revision 1.57 Revision 1.75
1# Copyright 1999-2009 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.57 2009/08/02 00:30:29 arfrever Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/distutils.eclass,v 1.75 2010/05/25 15:07:04 arfrever Exp $
4 4
5# @ECLASS: distutils.eclass 5# @ECLASS: distutils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# <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: This eclass allows easier installation of distutils-based python modules 10# @BLURB: Eclass for packages with build systems using Distutils
11# @DESCRIPTION: 11# @DESCRIPTION:
12# The distutils eclass is designed to allow easier installation of 12# The distutils eclass defines phase functions for packages with build systems using Distutils.
13# distutils-based python modules and their incorporation into
14# the Gentoo Linux system.
15#
16# It inherits python, multilib, and eutils
17 13
18inherit python multilib eutils 14inherit multilib python
19 15
20case "${EAPI:-0}" in 16case "${EAPI:-0}" in
21 0|1) 17 0|1)
22 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
23 ;; 19 ;;
24 *) 20 *)
25 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
26 ;; 22 ;;
27esac 23esac
28 24
29# @ECLASS-VARIABLE: PYTHON_SLOT_VERSION 25if [[ -z "$(declare -p PYTHON_DEPEND 2> /dev/null)" ]]; then
30# @DESCRIPTION:
31# This helps make it possible to add extensions to python slots.
32# Normally only a -py21- ebuild would set PYTHON_SLOT_VERSION.
33if [ "${PYTHON_SLOT_VERSION}" = "2.1" ] ; then
34 DEPEND="=dev-lang/python-2.1*" 26 DEPEND="dev-lang/python"
27 RDEPEND="${DEPEND}"
28fi
29
30# 'python' variable is deprecated. Use PYTHON() instead.
31if has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then
35 python="python2.1" 32 python="python"
36elif [ "${PYTHON_SLOT_VERSION}" = "2.3" ] ; then
37 DEPEND="=dev-lang/python-2.3*"
38 python="python2.3"
39else 33else
40 DEPEND="virtual/python" 34 python="die"
41 python="python"
42fi 35fi
43 36
37# @ECLASS-VARIABLE: DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES
38# @DESCRIPTION:
39# Set this to use separate source directories for each enabled version of Python.
40
41# @ECLASS-VARIABLE: DISTUTILS_GLOBAL_OPTIONS
42# @DESCRIPTION:
43# Global options passed to setup.py.
44
45# @ECLASS-VARIABLE: DISTUTILS_SRC_TEST
46# @DESCRIPTION:
47# Type of test command used by distutils_src_test().
48# IUSE and DEPEND are automatically adjusted, unless DISTUTILS_DISABLE_TEST_DEPENDENCY is set.
49# Valid values:
50# setup.py
51# nosetests
52# py.test
53# trial [arguments]
54
55# @ECLASS-VARIABLE: DISTUTILS_DISABLE_TEST_DEPENDENCY
56# @DESCRIPTION:
57# Disable modification of IUSE and DEPEND caused by setting of DISTUTILS_SRC_TEST.
58
59if [[ -n "${DISTUTILS_SRC_TEST}" && ! "${DISTUTILS_SRC_TEST}" =~ ^(setup\.py|nosetests|py\.test|trial(\ .*)?)$ ]]; then
60 die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'"
61fi
62
63if [[ -z "${DISTUTILS_DISABLE_TEST_DEPENDENCY}" ]]; then
64 if [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then
65 IUSE="test"
66 DEPEND+="${DEPEND:+ }test? ( dev-python/nose )"
67 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then
68 IUSE="test"
69 DEPEND+="${DEPEND:+ }test? ( dev-python/py )"
70 # trial requires an argument, which is usually equal to "${PN}".
71 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then
72 IUSE="test"
73 DEPEND+="${DEPEND:+ }test? ( dev-python/twisted )"
74 fi
75fi
76
77if [[ -n "${DISTUTILS_SRC_TEST}" ]]; then
78 EXPORT_FUNCTIONS src_test
79fi
80
81# @ECLASS-VARIABLE: DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS
82# @DESCRIPTION:
83# Set this to disable renaming of Python scripts containing versioned shebangs
84# and generation of wrapper scripts.
85
86# @ECLASS-VARIABLE: DISTUTILS_NONVERSIONED_PYTHON_SCRIPTS
87# @DESCRIPTION:
88# List of paths to Python scripts, relative to ${ED}, which are excluded from
89# renaming and generation of wrapper scripts.
90
44# @ECLASS-VARIABLE: DOCS 91# @ECLASS-VARIABLE: DOCS
45# @DESCRIPTION: 92# @DESCRIPTION:
46# Additional DOCS 93# Additional documentation files installed by distutils_src_install().
94
95_distutils_get_build_dir() {
96 if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then
97 echo "build-${PYTHON_ABI}"
98 else
99 echo "build"
100 fi
101}
102
103_distutils_get_PYTHONPATH() {
104 if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then
105 ls -d build-${PYTHON_ABI}/lib* 2> /dev/null
106 else
107 ls -d build/lib* 2> /dev/null
108 fi
109}
110
111_distutils_hook() {
112 if [[ "$#" -ne 1 ]]; then
113 die "${FUNCNAME}() requires 1 argument"
114 fi
115 if [[ "$(type -t "distutils_src_${EBUILD_PHASE}_$1_hook")" == "function" ]]; then
116 "distutils_src_${EBUILD_PHASE}_$1_hook"
117 fi
118}
47 119
48# @FUNCTION: distutils_src_unpack 120# @FUNCTION: distutils_src_unpack
49# @DESCRIPTION: 121# @DESCRIPTION:
50# The distutils src_unpack function, this function is exported 122# The distutils src_unpack function. This function is exported.
51distutils_src_unpack() { 123distutils_src_unpack() {
124 if ! has "${EAPI:-0}" 0 1; then
125 die "${FUNCNAME}() cannot be used in this EAPI"
126 fi
127
128 if [[ "${EBUILD_PHASE}" != "unpack" ]]; then
129 die "${FUNCNAME}() can be used only in src_unpack() phase"
130 fi
131
52 unpack ${A} 132 unpack ${A}
53 cd "${S}" 133 cd "${S}"
54 134
55 has "${EAPI:-0}" 0 1 && distutils_src_prepare 135 distutils_src_prepare
56} 136}
57 137
58# @FUNCTION: distutils_src_prepare 138# @FUNCTION: distutils_src_prepare
59# @DESCRIPTION: 139# @DESCRIPTION:
60# The distutils src_prepare function, this function is exported 140# The distutils src_prepare function. This function is exported.
61distutils_src_prepare() { 141distutils_src_prepare() {
62 # remove ez_setup stuff to prevent packages 142 if ! has "${EAPI:-0}" 0 1 && [[ "${EBUILD_PHASE}" != "prepare" ]]; then
63 # from installing setuptools on their own 143 die "${FUNCNAME}() can be used only in src_prepare() phase"
144 fi
145
146 # Delete ez_setup files to prevent packages from installing Setuptools on their own.
147 local ez_setup_existence="0"
148 [[ -d ez_setup || -f ez_setup.py ]] && ez_setup_existence="1"
64 rm -rf ez_setup* 149 rm -fr ez_setup*
150 if [[ "${ez_setup_existence}" == "1" ]]; then
65 echo "def use_setuptools(*args, **kwargs): pass" > ez_setup.py 151 echo "def use_setuptools(*args, **kwargs): pass" > ez_setup.py
152 fi
153
154 # Delete distribute_setup files to prevent packages from installing Distribute on their own.
155 local distribute_setup_existence="0"
156 [[ -d distribute_setup || -f distribute_setup.py ]] && distribute_setup_existence="1"
157 rm -fr distribute_setup*
158 if [[ "${distribute_setup_existence}" == "1" ]]; then
159 echo "def use_setuptools(*args, **kwargs): pass" > distribute_setup.py
160 fi
161
162 if [[ -n "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then
163 python_copy_sources
164 fi
66} 165}
67 166
68# @FUNCTION: distutils_src_compile 167# @FUNCTION: distutils_src_compile
69# @DESCRIPTION: 168# @DESCRIPTION:
70# The distutils src_compile function, this function is exported 169# The distutils src_compile function. This function is exported.
170# In ebuilds of packages supporting installation for multiple versions of Python, this function
171# calls distutils_src_compile_pre_hook() and distutils_src_compile_post_hook(), if they are defined.
71distutils_src_compile() { 172distutils_src_compile() {
173 if [[ "${EBUILD_PHASE}" != "compile" ]]; then
174 die "${FUNCNAME}() can be used only in src_compile() phase"
175 fi
176
177 _python_set_color_variables
178
72 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 179 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
73 build_modules() { 180 distutils_building() {
74 echo "$(get_python)" setup.py build -b "build-${PYTHON_ABI}" "$@" 181 _distutils_hook pre
75 "$(get_python)" setup.py build -b "build-${PYTHON_ABI}" "$@" 182
183 echo ${_BOLD}"$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@"${_NORMAL}
184 "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" || return "$?"
185
186 _distutils_hook post
76 } 187 }
77 python_execute_function build_modules "$@" 188 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_building "$@"
78 else 189 else
79 ${python} setup.py build "$@" || die "compilation failed" 190 echo ${_BOLD}"$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@"${_NORMAL}
191 "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" || die "Building failed"
192 fi
193}
194
195_distutils_src_test_hook() {
196 if [[ "$#" -ne 1 ]]; then
197 die "${FUNCNAME}() requires 1 arguments"
198 fi
199
200 if [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then
201 return
202 fi
203
204 if [[ "$(type -t "distutils_src_test_pre_hook")" == "function" ]]; then
205 eval "python_execute_$1_pre_hook() {
206 distutils_src_test_pre_hook
207 }"
208 fi
209
210 if [[ "$(type -t "distutils_src_test_post_hook")" == "function" ]]; then
211 eval "python_execute_$1_post_hook() {
212 distutils_src_test_post_hook
213 }"
214 fi
215}
216
217# @FUNCTION: distutils_src_test
218# @DESCRIPTION:
219# The distutils src_test function. This function is exported, when DISTUTILS_SRC_TEST variable is set.
220# In ebuilds of packages supporting installation for multiple versions of Python, this function
221# calls distutils_src_test_pre_hook() and distutils_src_test_post_hook(), if they are defined.
222distutils_src_test() {
223 if [[ "${EBUILD_PHASE}" != "test" ]]; then
224 die "${FUNCNAME}() can be used only in src_test() phase"
225 fi
226
227 _python_set_color_variables
228
229 if [[ "${DISTUTILS_SRC_TEST}" == "setup.py" ]]; then
230 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
231 distutils_testing() {
232 _distutils_hook pre
233
234 echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@"${_NORMAL}
235 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") test "$@" || return "$?"
236
237 _distutils_hook post
238 }
239 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_testing "$@"
240 else
241 echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@"${_NORMAL}
242 PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed"
243 fi
244 elif [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then
245 _distutils_src_test_hook nosetests
246
247 python_execute_nosetests -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@"
248 elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then
249 _distutils_src_test_hook py.test
250
251 python_execute_py.test -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@"
252 # trial requires an argument, which is usually equal to "${PN}".
253 elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then
254 local trial_arguments
255 if [[ "${DISTUTILS_SRC_TEST}" == "trial "* ]]; then
256 trial_arguments="${DISTUTILS_SRC_TEST#trial }"
257 else
258 trial_arguments="${PN}"
259 fi
260
261 _distutils_src_test_hook trial
262
263 python_execute_trial -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- ${trial_arguments} "$@"
264 else
265 die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'"
80 fi 266 fi
81} 267}
82 268
83# @FUNCTION: distutils_src_install 269# @FUNCTION: distutils_src_install
84# @DESCRIPTION: 270# @DESCRIPTION:
85# The distutils src_install function, this function is exported. 271# The distutils src_install function. This function is exported.
86# It also installs the "standard docs" (CHANGELOG, Change*, KNOWN_BUGS, MAINTAINERS, 272# In ebuilds of packages supporting installation for multiple versions of Python, this function
87# PKG-INFO, CONTRIBUTORS, TODO, NEWS, MANIFEST*, README*, and AUTHORS) 273# calls distutils_src_install_pre_hook() and distutils_src_install_post_hook(), if they are defined.
274# It also installs some standard documentation files (AUTHORS, Change*, CHANGELOG, CONTRIBUTORS,
275# KNOWN_BUGS, MAINTAINERS, MANIFEST*, NEWS, PKG-INFO, README*, TODO).
88distutils_src_install() { 276distutils_src_install() {
277 if [[ "${EBUILD_PHASE}" != "install" ]]; then
278 die "${FUNCNAME}() can be used only in src_install() phase"
279 fi
89 280
90 # Mark the package to be rebuilt after a python upgrade. 281 _python_initialize_prefix_variables
91 python_need_rebuild 282 _python_set_color_variables
92 283
93 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 284 if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
94 install_modules() { 285 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then
95 # need this for python-2.5 + setuptools in cases where 286 declare -A wrapper_scripts=()
96 # a package uses distutils but does not install anything
97 # in site-packages. (eg. dev-java/java-config-2.x)
98 # - liquidx (14/08/2006)
99 pylibdir="$("$(get_python)" -c 'from distutils.sysconfig import get_python_lib; print(get_python_lib())')"
100 [[ -n "${pylibdir}" ]] && dodir "${pylibdir}"
101 287
102 echo "$(get_python)" setup.py build -b "build-${PYTHON_ABI}" install --root="${D}" --no-compile "$@" 288 rename_scripts_with_versioned_shebangs() {
103 "$(get_python)" setup.py build -b "build-${PYTHON_ABI}" install --root="${D}" --no-compile "$@" 289 if [[ -d "${ED}usr/bin" ]]; then
290 cd "${ED}usr/bin"
291
292 local nonversioned_file file
293 for file in *; do
294 if [[ -f "${file}" && ! "${file}" =~ [[:digit:]]+\.[[:digit:]](-jython)?+$ && "$(head -n1 "${file}")" =~ ^'#!'.*(python|jython-)[[:digit:]]+\.[[:digit:]]+ ]]; then
295 for nonversioned_file in "${DISTUTILS_NONVERSIONED_PYTHON_SCRIPTS[@]}"; do
296 [[ "${nonversioned_file}" == "/usr/bin/${file}" ]] && continue 2
297 done
298 mv "${file}" "${file}-${PYTHON_ABI}" || die "Renaming of '${file}' failed"
299 wrapper_scripts+=(["${ED}usr/bin/${file}"]=)
300 fi
301 done
302 fi
303 }
304 fi
305
306 distutils_installation() {
307 _distutils_hook pre
308
309 echo ${_BOLD}"$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --root="${D}" --no-compile "$@"${_NORMAL}
310 "$(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 "$?"
311
312 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then
313 rename_scripts_with_versioned_shebangs
314 fi
315
316 _distutils_hook post
104 } 317 }
105 python_execute_function install_modules "$@" 318 python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_installation "$@"
319
320 if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${#wrapper_scripts[@]}" -ne 0 && "${BASH_VERSINFO[0]}" -ge 4 ]]; then
321 python_generate_wrapper_scripts "${!wrapper_scripts[@]}"
322 fi
323 unset wrapper_scripts
106 else 324 else
107 # need this for python-2.5 + setuptools in cases where 325 # Mark the package to be rebuilt after a Python upgrade.
108 # a package uses distutils but does not install anything 326 python_need_rebuild
109 # in site-packages. (eg. dev-java/java-config-2.x)
110 # - liquidx (14/08/2006)
111 pylibdir="$(${python} -c 'from distutils.sysconfig import get_python_lib; print(get_python_lib())')"
112 [[ -n "${pylibdir}" ]] && dodir "${pylibdir}"
113 327
114 ${python} setup.py install --root="${D}" --no-compile "$@" || die "python setup.py install failed" 328 echo ${_BOLD}"$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@"${_NORMAL}
329 "$(PYTHON)" setup.py "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" || die "Installation failed"
115 fi 330 fi
116 331
117 DDOCS="CHANGELOG KNOWN_BUGS MAINTAINERS PKG-INFO CONTRIBUTORS TODO NEWS" 332 if [[ -e "${ED}usr/local" ]]; then
118 DDOCS="${DDOCS} Change* MANIFEST* README* AUTHORS" 333 die "Illegal installation into /usr/local"
334 fi
335
336 local default_docs
337 default_docs="AUTHORS Change* CHANGELOG CONTRIBUTORS KNOWN_BUGS MAINTAINERS MANIFEST* NEWS PKG-INFO README* TODO"
119 338
120 local doc 339 local doc
121 for doc in ${DDOCS}; do 340 for doc in ${default_docs}; do
122 [[ -s "$doc" ]] && dodoc $doc 341 [[ -s "${doc}" ]] && dodoc "${doc}"
123 done 342 done
124 343
125 [[ -n "${DOCS}" ]] && dodoc ${DOCS} 344 if [[ -n "${DOCS}" ]]; then
345 dodoc ${DOCS} || die "dodoc failed"
346 fi
126} 347}
127 348
128# @FUNCTION: distutils_pkg_postrm 349# @FUNCTION: distutils_pkg_postinst
129# @DESCRIPTION: 350# @DESCRIPTION:
130# Generic pyc/pyo cleanup script. This function is exported. 351# The distutils pkg_postinst function. This function is exported.
352# When PYTHON_MODNAME variable is set, then this function calls python_mod_optimize() with modules
353# specified in PYTHON_MODNAME variable. Otherwise it calls python_mod_optimize() with module, whose
354# name is equal to name of current package, if this module exists.
131distutils_pkg_postrm() { 355distutils_pkg_postinst() {
356 if [[ "${EBUILD_PHASE}" != "postinst" ]]; then
357 die "${FUNCNAME}() can be used only in pkg_postinst() phase"
358 fi
359
360 _python_initialize_prefix_variables
361
132 local pylibdir pymod 362 local pylibdir pymod
133 if [[ -z "${PYTHON_MODNAME}" ]]; then 363 if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then
134 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 364 for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"/usr/share/jython-*/Lib; do
135 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then 365 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then
136 PYTHON_MODNAME="${PN}" 366 PYTHON_MODNAME="${PN}"
137 fi 367 fi
138 done 368 done
139 fi 369 fi
140 370
141 ebegin "Performing cleanup of Python modules..."
142 if [[ -n "${PYTHON_MODNAME}" ]]; then 371 if [[ -n "${PYTHON_MODNAME}" ]]; then
372 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
373 python_mod_optimize ${PYTHON_MODNAME}
374 else
143 for pymod in ${PYTHON_MODNAME}; do 375 for pymod in ${PYTHON_MODNAME}; do
144 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 376 python_mod_optimize "$(python_get_sitedir)/${pymod}"
145 if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then
146 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
147 python_mod_cleanup "${pymod}"
148 else
149 python_mod_cleanup "${pylibdir#${ROOT}}/site-packages/${pymod}"
150 fi
151 fi
152 done 377 done
153 done
154 else
155 python_mod_cleanup
156 fi 378 fi
157 eend 0 379 fi
158} 380}
159 381
160# @FUNCTION: distutils_pkg_postinst 382# @FUNCTION: distutils_pkg_postrm
161# @DESCRIPTION: 383# @DESCRIPTION:
162# This is a generic optimization, you should override it if your package 384# The distutils pkg_postrm function. This function is exported.
163# installs modules in another directory. This function is exported. 385# When PYTHON_MODNAME variable is set, then this function calls python_mod_cleanup() with modules
386# specified in PYTHON_MODNAME variable. Otherwise it calls python_mod_cleanup() with module, whose
387# name is equal to name of current package, if this module exists.
164distutils_pkg_postinst() { 388distutils_pkg_postrm() {
389 if [[ "${EBUILD_PHASE}" != "postrm" ]]; then
390 die "${FUNCNAME}() can be used only in pkg_postrm() phase"
391 fi
392
393 _python_initialize_prefix_variables
394
165 local pylibdir pymod 395 local pylibdir pymod
166 if [[ -z "${PYTHON_MODNAME}" ]]; then 396 if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then
167 for pylibdir in "${ROOT}"/usr/$(get_libdir)/python*; do 397 for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"/usr/share/jython-*/Lib; do
168 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then 398 if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then
169 PYTHON_MODNAME="${PN}" 399 PYTHON_MODNAME="${PN}"
170 fi 400 fi
171 done 401 done
172 fi 402 fi
173 403
404 if [[ -n "${PYTHON_MODNAME}" ]]; then
405 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
406 python_mod_cleanup ${PYTHON_MODNAME}
407 else
408 for pymod in ${PYTHON_MODNAME}; do
409 for pylibdir in "${EROOT}"usr/$(get_libdir)/python*; do
410 if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then
411 python_mod_cleanup "${pylibdir#${EROOT%/}}/site-packages/${pymod}"
412 fi
413 done
414 done
415 fi
416 fi
417}
418
419# @FUNCTION: distutils_python_version
420# @DESCRIPTION:
421# Deprecated wrapper function for deprecated python_version().
422distutils_python_version() {
174 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then 423 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
175 for pymod in ${PYTHON_MODNAME}; do 424 eerror "Use PYTHON() and/or python_get_*() instead of ${FUNCNAME}()."
176 python_mod_optimize "${pymod}" 425 die "${FUNCNAME}() cannot be used in this EAPI"
177 done
178 else
179 python_version
180 for pymod in ${PYTHON_MODNAME}; do
181 python_mod_optimize "/usr/$(get_libdir)/python${PYVER}/site-packages/${pymod}"
182 done
183 fi 426 fi
184}
185 427
186# @FUNCTION: distutils_python_version 428 _python_set_color_variables
187# @DESCRIPTION: 429
188# Calls python_version, so that you can use something like 430 eerror
189# e.g. insinto ${ROOT}/usr/include/python${PYVER} 431 eerror "${_RED}Deprecation Warning: ${FUNCNAME}() is deprecated and will be banned on 2010-07-01.${_NORMAL}"
190distutils_python_version() { 432 eerror "${_RED}Use PYTHON() instead of python variable. Use python_get_*() instead of PYVER* variables.${_NORMAL}"
433 eerror
434
191 python_version 435 python_version
192} 436}
193 437
194# @FUNCTION: distutils_python_tkinter 438# @FUNCTION: distutils_python_tkinter
195# @DESCRIPTION: 439# @DESCRIPTION:
196# Checks for if tkinter support is compiled into python 440# Deprecated wrapper function for deprecated python_tkinter_exists().
197distutils_python_tkinter() { 441distutils_python_tkinter() {
442 if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then
443 eerror "Use PYTHON_USE_WITH=\"xml\" and python_pkg_setup() instead of ${FUNCNAME}()."
444 die "${FUNCNAME}() cannot be used in this EAPI"
445 fi
446
447 _python_set_color_variables
448
449 eerror
450 eerror "${_RED}Deprecation Warning: ${FUNCNAME}() is deprecated and will be banned on 2010-07-01.${_NORMAL}"
451 eerror "${_RED}Use PYTHON_USE_WITH=\"xml\" and python_pkg_setup() instead of ${FUNCNAME}().${_NORMAL}"
452 eerror
453
198 python_tkinter_exists 454 python_tkinter_exists
199} 455}

Legend:
Removed from v.1.57  
changed lines
  Added in v.1.75

  ViewVC Help
Powered by ViewVC 1.1.20