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

Diff of /eclass/distutils.eclass

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

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

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

  ViewVC Help
Powered by ViewVC 1.1.20