| 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.71 2010/02/07 21:17:15 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 | |
| 14 | inherit eutils multilib python |
14 | inherit multilib python |
| 15 | |
15 | |
| 16 | case "${EAPI:-0}" in |
16 | case "${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 | ;; |
| 23 | esac |
23 | esac |
| 24 | |
24 | |
| 25 | if [[ -z "${PYTHON_DEPEND}" ]]; then |
25 | if [[ -z "$(declare -p PYTHON_DEPEND 2> /dev/null)" ]]; then |
| 26 | DEPEND="virtual/python" |
26 | DEPEND="dev-lang/python" |
| 27 | RDEPEND="${DEPEND}" |
27 | RDEPEND="${DEPEND}" |
| 28 | fi |
28 | fi |
| 29 | |
29 | |
| 30 | if has "${EAPI:-0}" 0 1 2; then |
30 | if [[ -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 |
|
|
46 | fi |
|
|
47 | |
|
|
48 | # 'python' variable is deprecated. Use PYTHON() instead. |
|
|
49 | if has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then |
| 31 | python="python" |
50 | python="python" |
| 32 | else |
51 | else |
| 33 | # Use "$(PYTHON)" or "$(PYTHON -A)" instead of "${python}". |
|
|
| 34 | python="die" |
52 | python="die" |
| 35 | fi |
53 | fi |
| 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. |
|
|
107 | if [[ -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=(".*") |
|
|
116 | fi |
| 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. |
| 118 | distutils_src_unpack() { |
150 | distutils_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. |
| … | |
… | |
| 163 | distutils_src_compile() { |
199 | distutils_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. |
| 187 | distutils_src_test() { |
255 | distutils_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 | } |
| … | |
… | |
| 225 | distutils_src_install() { |
315 | distutils_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" |
| … | |
… | |
| 298 | distutils_pkg_postinst() { |
372 | distutils_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: |
| … | |
… | |
| 327 | distutils_pkg_postrm() { |
405 | distutils_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(). |
|
|
| 361 | distutils_python_version() { |
437 | distutils_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(). |
|
|
| 373 | distutils_python_tkinter() { |
443 | distutils_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 | } |