| 1 | # Copyright 1999-2010 Gentoo Foundation |
1 | # Copyright 1999-2012 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.76 2010/07/17 23:03:29 arfrever Exp $ |
3 | # $Header: /var/cvsroot/gentoo-x86/eclass/distutils.eclass,v 1.81 2012/01/01 05:02:27 floppym 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 | # |
|
|
| 9 | # Original author: Jon Nelson <jnelson@gentoo.org> |
|
|
| 10 | # @BLURB: Eclass for packages with build systems using Distutils |
8 | # @BLURB: Eclass for packages with build systems using Distutils |
| 11 | # @DESCRIPTION: |
9 | # @DESCRIPTION: |
| 12 | # The distutils eclass defines phase functions for packages with build systems using Distutils. |
10 | # The distutils eclass defines phase functions for packages with build systems using Distutils. |
| 13 | |
11 | |
|
|
12 | if [[ -z "${_PYTHON_ECLASS_INHERITED}" ]]; then |
|
|
13 | inherit python |
|
|
14 | fi |
|
|
15 | |
| 14 | inherit multilib python |
16 | inherit multilib |
| 15 | |
17 | |
| 16 | case "${EAPI:-0}" in |
18 | case "${EAPI:-0}" in |
| 17 | 0|1) |
19 | 0|1) |
| 18 | EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_postinst pkg_postrm |
20 | EXPORT_FUNCTIONS src_unpack src_compile src_install pkg_postinst pkg_postrm |
| 19 | ;; |
21 | ;; |
| … | |
… | |
| 25 | if [[ -z "$(declare -p PYTHON_DEPEND 2> /dev/null)" ]]; then |
27 | if [[ -z "$(declare -p PYTHON_DEPEND 2> /dev/null)" ]]; then |
| 26 | DEPEND="dev-lang/python" |
28 | DEPEND="dev-lang/python" |
| 27 | RDEPEND="${DEPEND}" |
29 | RDEPEND="${DEPEND}" |
| 28 | fi |
30 | fi |
| 29 | |
31 | |
|
|
32 | if has "${EAPI:-0}" 0 1 && [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
|
|
33 | ewarn |
|
|
34 | ewarn "\"${EBUILD}\":" |
|
|
35 | ewarn "Deprecation Warning: Usage of distutils.eclass in packages supporting installation" |
|
|
36 | ewarn "for multiple Python ABIs in EAPI <=1 is deprecated and will be banned on 2011-06-01." |
|
|
37 | ewarn "The ebuild needs to be fixed. Please report a bug, if it has not been already reported." |
|
|
38 | ewarn |
|
|
39 | elif has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then |
|
|
40 | ewarn |
|
|
41 | ewarn "\"${EBUILD}\":" |
|
|
42 | ewarn "Deprecation Warning: Usage of distutils.eclass in packages not supporting installation" |
|
|
43 | ewarn "for multiple Python ABIs in EAPI <=2 is deprecated and will be banned on 2011-06-01." |
|
|
44 | ewarn "The ebuild needs to be fixed. Please report a bug, if it has not been already reported." |
|
|
45 | ewarn |
|
|
46 | fi |
|
|
47 | |
| 30 | # 'python' variable is deprecated. Use PYTHON() instead. |
48 | # 'python' variable is deprecated. Use PYTHON() instead. |
| 31 | if has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then |
49 | if has "${EAPI:-0}" 0 1 2 && [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then |
| 32 | python="python" |
50 | python="python" |
| 33 | else |
51 | else |
| 34 | python="die" |
52 | python="die" |
| … | |
… | |
| 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 | |
| 41 | # @ECLASS-VARIABLE: DISTUTILS_SETUP_FILES |
59 | # @ECLASS-VARIABLE: DISTUTILS_SETUP_FILES |
| 42 | # @DESCRIPTION: |
60 | # @DESCRIPTION: |
| 43 | # Paths to setup files. |
61 | # Array of paths to setup files. |
|
|
62 | # Syntax: |
|
|
63 | # [current_working_directory|]path_to_setup_file |
| 44 | |
64 | |
| 45 | # @ECLASS-VARIABLE: DISTUTILS_GLOBAL_OPTIONS |
65 | # @ECLASS-VARIABLE: DISTUTILS_GLOBAL_OPTIONS |
| 46 | # @DESCRIPTION: |
66 | # @DESCRIPTION: |
| 47 | # Global options passed to setup files. |
67 | # Array of global options passed to setup files. |
|
|
68 | # Syntax in EAPI <4: |
|
|
69 | # global_option |
|
|
70 | # Syntax in EAPI >=4: |
|
|
71 | # Python_ABI_pattern global_option |
| 48 | |
72 | |
| 49 | # @ECLASS-VARIABLE: DISTUTILS_SRC_TEST |
73 | # @ECLASS-VARIABLE: DISTUTILS_SRC_TEST |
| 50 | # @DESCRIPTION: |
74 | # @DESCRIPTION: |
| 51 | # Type of test command used by distutils_src_test(). |
75 | # Type of test command used by distutils_src_test(). |
| 52 | # IUSE and DEPEND are automatically adjusted, unless DISTUTILS_DISABLE_TEST_DEPENDENCY is set. |
76 | # IUSE and DEPEND are automatically adjusted, unless DISTUTILS_DISABLE_TEST_DEPENDENCY is set. |
| … | |
… | |
| 68 | if [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then |
92 | if [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then |
| 69 | IUSE="test" |
93 | IUSE="test" |
| 70 | DEPEND+="${DEPEND:+ }test? ( dev-python/nose )" |
94 | DEPEND+="${DEPEND:+ }test? ( dev-python/nose )" |
| 71 | elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then |
95 | elif [[ "${DISTUTILS_SRC_TEST}" == "py.test" ]]; then |
| 72 | IUSE="test" |
96 | IUSE="test" |
| 73 | DEPEND+="${DEPEND:+ }test? ( dev-python/py )" |
97 | DEPEND+="${DEPEND:+ }test? ( dev-python/pytest )" |
| 74 | # trial requires an argument, which is usually equal to "${PN}". |
98 | # trial requires an argument, which is usually equal to "${PN}". |
| 75 | elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then |
99 | elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then |
| 76 | IUSE="test" |
100 | IUSE="test" |
| 77 | DEPEND+="${DEPEND:+ }test? ( dev-python/twisted )" |
101 | DEPEND+="${DEPEND:+ }test? ( dev-python/twisted )" |
| 78 | fi |
102 | fi |
| … | |
… | |
| 80 | |
104 | |
| 81 | if [[ -n "${DISTUTILS_SRC_TEST}" ]]; then |
105 | if [[ -n "${DISTUTILS_SRC_TEST}" ]]; then |
| 82 | EXPORT_FUNCTIONS src_test |
106 | EXPORT_FUNCTIONS src_test |
| 83 | fi |
107 | fi |
| 84 | |
108 | |
| 85 | # @ECLASS-VARIABLE: DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS |
109 | # Scheduled for deletion on 2011-06-01. |
| 86 | # @DESCRIPTION: |
110 | if [[ -n "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" ]]; then |
| 87 | # Set this to disable renaming of Python scripts containing versioned shebangs |
111 | eerror "Use PYTHON_NONVERSIONED_EXECUTABLES=(\".*\") instead of DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS variable." |
| 88 | # and generation of wrapper scripts. |
112 | die "DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS variable is banned" |
| 89 | |
113 | fi |
| 90 | # @ECLASS-VARIABLE: DISTUTILS_NONVERSIONED_PYTHON_SCRIPTS |
|
|
| 91 | # @DESCRIPTION: |
|
|
| 92 | # List of paths to Python scripts, relative to ${ED}, which are excluded from |
|
|
| 93 | # renaming and generation of wrapper scripts. |
|
|
| 94 | |
114 | |
| 95 | # @ECLASS-VARIABLE: DOCS |
115 | # @ECLASS-VARIABLE: DOCS |
| 96 | # @DESCRIPTION: |
116 | # @DESCRIPTION: |
| 97 | # Additional documentation files installed by distutils_src_install(). |
117 | # Additional documentation files installed by distutils_src_install(). |
| 98 | |
118 | |
| 99 | _distutils_get_build_dir() { |
119 | _distutils_get_build_dir() { |
| 100 | if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then |
120 | if _python_package_supporting_installation_for_multiple_python_abis && [[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then |
| 101 | echo "build-${PYTHON_ABI}" |
121 | echo "build-${PYTHON_ABI}" |
| 102 | else |
122 | else |
| 103 | echo "build" |
123 | echo "build" |
| 104 | fi |
124 | fi |
| 105 | } |
125 | } |
| 106 | |
126 | |
| 107 | _distutils_get_PYTHONPATH() { |
127 | _distutils_get_PYTHONPATH() { |
| 108 | if [[ -n "${SUPPORT_PYTHON_ABIS}" && -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then |
128 | if _python_package_supporting_installation_for_multiple_python_abis && [[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]]; then |
| 109 | ls -d build-${PYTHON_ABI}/lib* 2> /dev/null |
129 | ls -d build-${PYTHON_ABI}/lib* 2> /dev/null |
| 110 | else |
130 | else |
| 111 | ls -d build/lib* 2> /dev/null |
131 | ls -d build/lib* 2> /dev/null |
| 112 | fi |
132 | fi |
| 113 | } |
133 | } |
| … | |
… | |
| 116 | if [[ "$#" -ne 1 ]]; then |
136 | if [[ "$#" -ne 1 ]]; then |
| 117 | die "${FUNCNAME}() requires 1 argument" |
137 | die "${FUNCNAME}() requires 1 argument" |
| 118 | fi |
138 | fi |
| 119 | if [[ "$(type -t "distutils_src_${EBUILD_PHASE}_$1_hook")" == "function" ]]; then |
139 | if [[ "$(type -t "distutils_src_${EBUILD_PHASE}_$1_hook")" == "function" ]]; then |
| 120 | "distutils_src_${EBUILD_PHASE}_$1_hook" |
140 | "distutils_src_${EBUILD_PHASE}_$1_hook" |
|
|
141 | fi |
|
|
142 | } |
|
|
143 | |
|
|
144 | _distutils_prepare_global_options() { |
|
|
145 | local element option pattern |
|
|
146 | |
|
|
147 | if [[ -n "$(declare -p DISTUTILS_GLOBAL_OPTIONS 2> /dev/null)" && "$(declare -p DISTUTILS_GLOBAL_OPTIONS)" != "declare -a DISTUTILS_GLOBAL_OPTIONS="* ]]; then |
|
|
148 | die "DISTUTILS_GLOBAL_OPTIONS should be indexed array" |
|
|
149 | fi |
|
|
150 | |
|
|
151 | if has "${EAPI:-0}" 0 1 2 3; then |
|
|
152 | _DISTUTILS_GLOBAL_OPTIONS=("${DISTUTILS_GLOBAL_OPTIONS[@]}") |
|
|
153 | else |
|
|
154 | _DISTUTILS_GLOBAL_OPTIONS=() |
|
|
155 | |
|
|
156 | for element in "${DISTUTILS_GLOBAL_OPTIONS[@]}"; do |
|
|
157 | if [[ ! "${element}" =~ ^[^[:space:]]+\ . ]]; then |
|
|
158 | die "Element '${element}' of DISTUTILS_GLOBAL_OPTIONS array has invalid syntax" |
|
|
159 | fi |
|
|
160 | pattern="${element%% *}" |
|
|
161 | option="${element#* }" |
|
|
162 | if _python_check_python_abi_matching "${PYTHON_ABI}" "${pattern}"; then |
|
|
163 | _DISTUTILS_GLOBAL_OPTIONS+=("${option}") |
|
|
164 | fi |
|
|
165 | done |
|
|
166 | fi |
|
|
167 | } |
|
|
168 | |
|
|
169 | _distutils_prepare_current_working_directory() { |
|
|
170 | if [[ "$1" == *"|"*"|"* ]]; then |
|
|
171 | die "Element '$1' of DISTUTILS_SETUP_FILES array has invalid syntax" |
|
|
172 | fi |
|
|
173 | |
|
|
174 | if [[ "$1" == *"|"* ]]; then |
|
|
175 | echo "${_BOLD}[${1%|*}]${_NORMAL}" |
|
|
176 | pushd "${1%|*}" > /dev/null || die "Entering directory '${1%|*}' failed" |
|
|
177 | fi |
|
|
178 | } |
|
|
179 | |
|
|
180 | _distutils_restore_current_working_directory() { |
|
|
181 | if [[ "$1" == *"|"* ]]; then |
|
|
182 | popd > /dev/null || die "Leaving directory '${1%|*}' failed" |
| 121 | fi |
183 | fi |
| 122 | } |
184 | } |
| 123 | |
185 | |
| 124 | # @FUNCTION: distutils_src_unpack |
186 | # @FUNCTION: distutils_src_unpack |
| 125 | # @DESCRIPTION: |
187 | # @DESCRIPTION: |
| … | |
… | |
| 145 | distutils_src_prepare() { |
207 | distutils_src_prepare() { |
| 146 | if ! has "${EAPI:-0}" 0 1 && [[ "${EBUILD_PHASE}" != "prepare" ]]; then |
208 | if ! has "${EAPI:-0}" 0 1 && [[ "${EBUILD_PHASE}" != "prepare" ]]; then |
| 147 | die "${FUNCNAME}() can be used only in src_prepare() phase" |
209 | die "${FUNCNAME}() can be used only in src_prepare() phase" |
| 148 | fi |
210 | fi |
| 149 | |
211 | |
|
|
212 | _python_check_python_pkg_setup_execution |
|
|
213 | |
|
|
214 | local distribute_setup_existence="0" ez_setup_existence="0" |
|
|
215 | |
|
|
216 | if [[ "$#" -ne 0 ]]; then |
|
|
217 | die "${FUNCNAME}() does not accept arguments" |
|
|
218 | fi |
|
|
219 | |
| 150 | # Delete ez_setup files to prevent packages from installing Setuptools on their own. |
220 | # Delete ez_setup files to prevent packages from installing Setuptools on their own. |
| 151 | local ez_setup_existence="0" |
|
|
| 152 | [[ -d ez_setup || -f ez_setup.py ]] && ez_setup_existence="1" |
221 | [[ -d ez_setup || -f ez_setup.py ]] && ez_setup_existence="1" |
| 153 | rm -fr ez_setup* |
222 | rm -fr ez_setup* |
| 154 | if [[ "${ez_setup_existence}" == "1" ]]; then |
223 | if [[ "${ez_setup_existence}" == "1" ]]; then |
| 155 | echo "def use_setuptools(*args, **kwargs): pass" > ez_setup.py |
224 | echo "def use_setuptools(*args, **kwargs): pass" > ez_setup.py |
| 156 | fi |
225 | fi |
| 157 | |
226 | |
| 158 | # Delete distribute_setup files to prevent packages from installing Distribute on their own. |
227 | # Delete distribute_setup files to prevent packages from installing Distribute on their own. |
| 159 | local distribute_setup_existence="0" |
|
|
| 160 | [[ -d distribute_setup || -f distribute_setup.py ]] && distribute_setup_existence="1" |
228 | [[ -d distribute_setup || -f distribute_setup.py ]] && distribute_setup_existence="1" |
| 161 | rm -fr distribute_setup* |
229 | rm -fr distribute_setup* |
| 162 | if [[ "${distribute_setup_existence}" == "1" ]]; then |
230 | if [[ "${distribute_setup_existence}" == "1" ]]; then |
| 163 | echo "def use_setuptools(*args, **kwargs): pass" > distribute_setup.py |
231 | echo "def use_setuptools(*args, **kwargs): pass" > distribute_setup.py |
| 164 | fi |
232 | fi |
| … | |
… | |
| 176 | distutils_src_compile() { |
244 | distutils_src_compile() { |
| 177 | if [[ "${EBUILD_PHASE}" != "compile" ]]; then |
245 | if [[ "${EBUILD_PHASE}" != "compile" ]]; then |
| 178 | die "${FUNCNAME}() can be used only in src_compile() phase" |
246 | die "${FUNCNAME}() can be used only in src_compile() phase" |
| 179 | fi |
247 | fi |
| 180 | |
248 | |
|
|
249 | _python_check_python_pkg_setup_execution |
| 181 | _python_set_color_variables |
250 | _python_set_color_variables |
| 182 | |
251 | |
| 183 | if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
252 | local setup_file |
|
|
253 | |
|
|
254 | if _python_package_supporting_installation_for_multiple_python_abis; then |
| 184 | distutils_building() { |
255 | distutils_building() { |
| 185 | _distutils_hook pre |
256 | _distutils_hook pre |
| 186 | |
257 | |
| 187 | local setup_file |
258 | _distutils_prepare_global_options |
|
|
259 | |
| 188 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
260 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
261 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
262 | |
| 189 | echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@"${_NORMAL} |
263 | echo ${_BOLD}"$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@"${_NORMAL} |
| 190 | "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" || return "$?" |
264 | "$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" build -b "$(_distutils_get_build_dir)" "$@" || return "$?" |
|
|
265 | |
|
|
266 | _distutils_restore_current_working_directory "${setup_file}" |
| 191 | done |
267 | done |
| 192 | |
268 | |
| 193 | _distutils_hook post |
269 | _distutils_hook post |
| 194 | } |
270 | } |
| 195 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_building "$@" |
271 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_building "$@" |
|
|
272 | unset -f distutils_building |
| 196 | else |
273 | else |
| 197 | local setup_file |
274 | _distutils_prepare_global_options |
|
|
275 | |
| 198 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
276 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
277 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
278 | |
| 199 | echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@"${_NORMAL} |
279 | echo ${_BOLD}"$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@"${_NORMAL} |
| 200 | "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" || die "Building failed" |
280 | "$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" build "$@" || die "Building failed" |
|
|
281 | |
|
|
282 | _distutils_restore_current_working_directory "${setup_file}" |
| 201 | done |
283 | done |
| 202 | fi |
284 | fi |
| 203 | } |
285 | } |
| 204 | |
286 | |
| 205 | _distutils_src_test_hook() { |
287 | _distutils_src_test_hook() { |
| 206 | if [[ "$#" -ne 1 ]]; then |
288 | if [[ "$#" -ne 1 ]]; then |
| 207 | die "${FUNCNAME}() requires 1 arguments" |
289 | die "${FUNCNAME}() requires 1 arguments" |
| 208 | fi |
290 | fi |
| 209 | |
291 | |
| 210 | if [[ -z "${SUPPORT_PYTHON_ABIS}" ]]; then |
292 | if ! _python_package_supporting_installation_for_multiple_python_abis; then |
| 211 | return |
293 | return |
| 212 | fi |
294 | fi |
| 213 | |
295 | |
| 214 | if [[ "$(type -t "distutils_src_test_pre_hook")" == "function" ]]; then |
296 | if [[ "$(type -t "distutils_src_test_pre_hook")" == "function" ]]; then |
| 215 | eval "python_execute_$1_pre_hook() { |
297 | eval "python_execute_$1_pre_hook() { |
| … | |
… | |
| 232 | distutils_src_test() { |
314 | distutils_src_test() { |
| 233 | if [[ "${EBUILD_PHASE}" != "test" ]]; then |
315 | if [[ "${EBUILD_PHASE}" != "test" ]]; then |
| 234 | die "${FUNCNAME}() can be used only in src_test() phase" |
316 | die "${FUNCNAME}() can be used only in src_test() phase" |
| 235 | fi |
317 | fi |
| 236 | |
318 | |
|
|
319 | _python_check_python_pkg_setup_execution |
| 237 | _python_set_color_variables |
320 | _python_set_color_variables |
| 238 | |
321 | |
|
|
322 | local arguments setup_file |
|
|
323 | |
| 239 | if [[ "${DISTUTILS_SRC_TEST}" == "setup.py" ]]; then |
324 | if [[ "${DISTUTILS_SRC_TEST}" == "setup.py" ]]; then |
| 240 | if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
325 | if _python_package_supporting_installation_for_multiple_python_abis; then |
| 241 | distutils_testing() { |
326 | distutils_testing() { |
| 242 | _distutils_hook pre |
327 | _distutils_hook pre |
| 243 | |
328 | |
| 244 | local setup_file |
329 | _distutils_prepare_global_options |
|
|
330 | |
| 245 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
331 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
332 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
333 | |
| 246 | 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} |
334 | 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} |
| 247 | 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 "$?" |
335 | 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 "$?" |
|
|
336 | |
|
|
337 | _distutils_restore_current_working_directory "${setup_file}" |
| 248 | done |
338 | done |
| 249 | |
339 | |
| 250 | _distutils_hook post |
340 | _distutils_hook post |
| 251 | } |
341 | } |
| 252 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_testing "$@" |
342 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_testing "$@" |
|
|
343 | unset -f distutils_testing |
| 253 | else |
344 | else |
| 254 | local setup_file |
345 | _distutils_prepare_global_options |
|
|
346 | |
| 255 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
347 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
348 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
349 | |
| 256 | echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@"${_NORMAL} |
350 | echo ${_BOLD}PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@"${_NORMAL} |
| 257 | PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed" |
351 | PYTHONPATH="$(_distutils_get_PYTHONPATH)" "$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" test "$@" || die "Testing failed" |
|
|
352 | |
|
|
353 | _distutils_restore_current_working_directory "${setup_file}" |
| 258 | done |
354 | done |
| 259 | fi |
355 | fi |
| 260 | elif [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then |
356 | elif [[ "${DISTUTILS_SRC_TEST}" == "nosetests" ]]; then |
| 261 | _distutils_src_test_hook nosetests |
357 | _distutils_src_test_hook nosetests |
| 262 | |
358 | |
| … | |
… | |
| 265 | _distutils_src_test_hook py.test |
361 | _distutils_src_test_hook py.test |
| 266 | |
362 | |
| 267 | python_execute_py.test -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@" |
363 | python_execute_py.test -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- "$@" |
| 268 | # trial requires an argument, which is usually equal to "${PN}". |
364 | # trial requires an argument, which is usually equal to "${PN}". |
| 269 | elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then |
365 | elif [[ "${DISTUTILS_SRC_TEST}" =~ ^trial(\ .*)?$ ]]; then |
| 270 | local trial_arguments |
|
|
| 271 | if [[ "${DISTUTILS_SRC_TEST}" == "trial "* ]]; then |
366 | if [[ "${DISTUTILS_SRC_TEST}" == "trial "* ]]; then |
| 272 | trial_arguments="${DISTUTILS_SRC_TEST#trial }" |
367 | arguments="${DISTUTILS_SRC_TEST#trial }" |
| 273 | else |
368 | else |
| 274 | trial_arguments="${PN}" |
369 | arguments="${PN}" |
| 275 | fi |
370 | fi |
| 276 | |
371 | |
| 277 | _distutils_src_test_hook trial |
372 | _distutils_src_test_hook trial |
| 278 | |
373 | |
| 279 | python_execute_trial -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- ${trial_arguments} "$@" |
374 | python_execute_trial -P '$(_distutils_get_PYTHONPATH)' ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} -- ${arguments} "$@" |
| 280 | else |
375 | else |
| 281 | die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'" |
376 | die "'DISTUTILS_SRC_TEST' variable has unsupported value '${DISTUTILS_SRC_TEST}'" |
| 282 | fi |
377 | fi |
| 283 | } |
378 | } |
| 284 | |
379 | |
| … | |
… | |
| 286 | # @DESCRIPTION: |
381 | # @DESCRIPTION: |
| 287 | # The distutils src_install function. This function is exported. |
382 | # The distutils src_install function. This function is exported. |
| 288 | # In ebuilds of packages supporting installation for multiple versions of Python, this function |
383 | # In ebuilds of packages supporting installation for multiple versions of Python, this function |
| 289 | # calls distutils_src_install_pre_hook() and distutils_src_install_post_hook(), if they are defined. |
384 | # calls distutils_src_install_pre_hook() and distutils_src_install_post_hook(), if they are defined. |
| 290 | # It also installs some standard documentation files (AUTHORS, Change*, CHANGELOG, CONTRIBUTORS, |
385 | # It also installs some standard documentation files (AUTHORS, Change*, CHANGELOG, CONTRIBUTORS, |
| 291 | # KNOWN_BUGS, MAINTAINERS, MANIFEST*, NEWS, PKG-INFO, README*, TODO). |
386 | # KNOWN_BUGS, MAINTAINERS, NEWS, README*, TODO). |
| 292 | distutils_src_install() { |
387 | distutils_src_install() { |
| 293 | if [[ "${EBUILD_PHASE}" != "install" ]]; then |
388 | if [[ "${EBUILD_PHASE}" != "install" ]]; then |
| 294 | die "${FUNCNAME}() can be used only in src_install() phase" |
389 | die "${FUNCNAME}() can be used only in src_install() phase" |
| 295 | fi |
390 | fi |
| 296 | |
391 | |
|
|
392 | _python_check_python_pkg_setup_execution |
| 297 | _python_initialize_prefix_variables |
393 | _python_initialize_prefix_variables |
| 298 | _python_set_color_variables |
394 | _python_set_color_variables |
| 299 | |
395 | |
| 300 | if [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
396 | local default_docs doc line nspkg_pth_file nspkg_pth_files=() setup_file |
| 301 | if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then |
|
|
| 302 | declare -A wrapper_scripts=() |
|
|
| 303 | |
397 | |
| 304 | rename_scripts_with_versioned_shebangs() { |
398 | if _python_package_supporting_installation_for_multiple_python_abis; then |
| 305 | if [[ -d "${ED}usr/bin" ]]; then |
|
|
| 306 | cd "${ED}usr/bin" |
|
|
| 307 | |
|
|
| 308 | local nonversioned_file file |
|
|
| 309 | for file in *; do |
|
|
| 310 | if [[ -f "${file}" && ! "${file}" =~ [[:digit:]]+\.[[:digit:]](-jython)?+$ && "$(head -n1 "${file}")" =~ ^'#!'.*(python|jython-)[[:digit:]]+\.[[:digit:]]+ ]]; then |
|
|
| 311 | for nonversioned_file in "${DISTUTILS_NONVERSIONED_PYTHON_SCRIPTS[@]}"; do |
|
|
| 312 | [[ "${nonversioned_file}" == "/usr/bin/${file}" ]] && continue 2 |
|
|
| 313 | done |
|
|
| 314 | mv "${file}" "${file}-${PYTHON_ABI}" || die "Renaming of '${file}' failed" |
|
|
| 315 | wrapper_scripts+=(["${ED}usr/bin/${file}"]=) |
|
|
| 316 | fi |
|
|
| 317 | done |
|
|
| 318 | fi |
|
|
| 319 | } |
|
|
| 320 | fi |
|
|
| 321 | |
|
|
| 322 | distutils_installation() { |
399 | distutils_installation() { |
| 323 | _distutils_hook pre |
400 | _distutils_hook pre |
| 324 | |
401 | |
| 325 | local setup_file |
402 | _distutils_prepare_global_options |
|
|
403 | |
| 326 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
404 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
405 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
406 | |
| 327 | echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --root="${D}" --no-compile "$@"${_NORMAL} |
407 | 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} |
| 328 | "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" $([[ -z "${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES}" ]] && echo build -b "$(_distutils_get_build_dir)") install --root="${D}" --no-compile "$@" || return "$?" |
408 | "$(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 "$?" |
|
|
409 | |
|
|
410 | _distutils_restore_current_working_directory "${setup_file}" |
| 329 | done |
411 | done |
| 330 | |
|
|
| 331 | if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${BASH_VERSINFO[0]}" -ge 4 ]]; then |
|
|
| 332 | rename_scripts_with_versioned_shebangs |
|
|
| 333 | fi |
|
|
| 334 | |
412 | |
| 335 | _distutils_hook post |
413 | _distutils_hook post |
| 336 | } |
414 | } |
| 337 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_installation "$@" |
415 | python_execute_function ${DISTUTILS_USE_SEPARATE_SOURCE_DIRECTORIES:+-s} distutils_installation "$@" |
|
|
416 | unset -f distutils_installation |
| 338 | |
417 | |
| 339 | if [[ -z "${DISTUTILS_DISABLE_VERSIONING_OF_PYTHON_SCRIPTS}" && "${#wrapper_scripts[@]}" -ne 0 && "${BASH_VERSINFO[0]}" -ge 4 ]]; then |
418 | python_merge_intermediate_installation_images "${T}/images" |
| 340 | python_generate_wrapper_scripts "${!wrapper_scripts[@]}" |
|
|
| 341 | fi |
|
|
| 342 | unset wrapper_scripts |
|
|
| 343 | else |
419 | else |
| 344 | # Mark the package to be rebuilt after a Python upgrade. |
420 | # Mark the package to be rebuilt after a Python upgrade. |
| 345 | python_need_rebuild |
421 | python_need_rebuild |
| 346 | |
422 | |
| 347 | local setup_file |
423 | _distutils_prepare_global_options |
|
|
424 | |
| 348 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
425 | for setup_file in "${DISTUTILS_SETUP_FILES[@]-setup.py}"; do |
|
|
426 | _distutils_prepare_current_working_directory "${setup_file}" |
|
|
427 | |
| 349 | echo ${_BOLD}"$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@"${_NORMAL} |
428 | echo ${_BOLD}"$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@"${_NORMAL} |
| 350 | "$(PYTHON)" "${setup_file}" "${DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" || die "Installation failed" |
429 | "$(PYTHON)" "${setup_file#*|}" "${_DISTUTILS_GLOBAL_OPTIONS[@]}" install --root="${D}" --no-compile "$@" || die "Installation failed" |
|
|
430 | |
|
|
431 | _distutils_restore_current_working_directory "${setup_file}" |
| 351 | done |
432 | done |
|
|
433 | fi |
|
|
434 | |
|
|
435 | while read -d $'\0' -r nspkg_pth_file; do |
|
|
436 | nspkg_pth_files+=("${nspkg_pth_file}") |
|
|
437 | done < <(find "${ED}" -name "*-nspkg.pth" -type f -print0) |
|
|
438 | |
|
|
439 | if [[ "${#nspkg_pth_files[@]}" -gt 0 ]]; then |
|
|
440 | einfo |
|
|
441 | einfo "Python namespaces:" |
|
|
442 | for nspkg_pth_file in "${nspkg_pth_files[@]}"; do |
|
|
443 | einfo " '${nspkg_pth_file#${ED%/}}':" |
|
|
444 | while read -r line; do |
|
|
445 | einfo " $(echo "${line}" | sed -e "s/.*types\.ModuleType('\([^']\+\)').*/\1/")" |
|
|
446 | done < "${nspkg_pth_file}" |
|
|
447 | if ! has "${EAPI:-0}" 0 1 2 3; then |
|
|
448 | rm -f "${nspkg_pth_file}" || die "Deletion of '${nspkg_pth_file}' failed" |
|
|
449 | fi |
|
|
450 | done |
|
|
451 | einfo |
| 352 | fi |
452 | fi |
| 353 | |
453 | |
| 354 | if [[ -e "${ED}usr/local" ]]; then |
454 | if [[ -e "${ED}usr/local" ]]; then |
| 355 | die "Illegal installation into /usr/local" |
455 | die "Illegal installation into /usr/local" |
| 356 | fi |
456 | fi |
| 357 | |
457 | |
| 358 | local default_docs |
|
|
| 359 | default_docs="AUTHORS Change* CHANGELOG CONTRIBUTORS KNOWN_BUGS MAINTAINERS MANIFEST* NEWS PKG-INFO README* TODO" |
458 | default_docs="AUTHORS Change* CHANGELOG CONTRIBUTORS KNOWN_BUGS MAINTAINERS NEWS README* TODO" |
| 360 | |
459 | |
| 361 | local doc |
|
|
| 362 | for doc in ${default_docs}; do |
460 | for doc in ${default_docs}; do |
| 363 | [[ -s "${doc}" ]] && dodoc "${doc}" |
461 | [[ -s "${doc}" ]] && dodoc "${doc}" |
| 364 | done |
462 | done |
| 365 | |
463 | |
|
|
464 | if has "${EAPI:-0}" 0 1 2 3; then |
| 366 | if [[ -n "${DOCS}" ]]; then |
465 | if [[ -n "${DOCS}" ]]; then |
| 367 | dodoc ${DOCS} || die "dodoc failed" |
466 | dodoc ${DOCS} || die "dodoc failed" |
| 368 | fi |
467 | fi |
|
|
468 | else |
|
|
469 | if [[ -n "${DOCS}" ]]; then |
|
|
470 | dodoc -r ${DOCS} || die "dodoc failed" |
|
|
471 | fi |
|
|
472 | fi |
|
|
473 | |
|
|
474 | DISTUTILS_SRC_INSTALL_EXECUTED="1" |
| 369 | } |
475 | } |
| 370 | |
476 | |
| 371 | # @FUNCTION: distutils_pkg_postinst |
477 | # @FUNCTION: distutils_pkg_postinst |
| 372 | # @DESCRIPTION: |
478 | # @DESCRIPTION: |
| 373 | # The distutils pkg_postinst function. This function is exported. |
479 | # The distutils pkg_postinst function. This function is exported. |
| … | |
… | |
| 377 | distutils_pkg_postinst() { |
483 | distutils_pkg_postinst() { |
| 378 | if [[ "${EBUILD_PHASE}" != "postinst" ]]; then |
484 | if [[ "${EBUILD_PHASE}" != "postinst" ]]; then |
| 379 | die "${FUNCNAME}() can be used only in pkg_postinst() phase" |
485 | die "${FUNCNAME}() can be used only in pkg_postinst() phase" |
| 380 | fi |
486 | fi |
| 381 | |
487 | |
|
|
488 | _python_check_python_pkg_setup_execution |
| 382 | _python_initialize_prefix_variables |
489 | _python_initialize_prefix_variables |
| 383 | |
490 | |
|
|
491 | if [[ -z "${DISTUTILS_SRC_INSTALL_EXECUTED}" ]]; then |
|
|
492 | die "${FUNCNAME}() called illegally" |
|
|
493 | fi |
|
|
494 | |
| 384 | local pylibdir pymod |
495 | local pylibdir pymod |
|
|
496 | |
|
|
497 | if [[ "$#" -ne 0 ]]; then |
|
|
498 | die "${FUNCNAME}() does not accept arguments" |
|
|
499 | fi |
|
|
500 | |
| 385 | if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then |
501 | if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then |
| 386 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"/usr/share/jython-*/Lib; do |
502 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"usr/share/jython-*/Lib; do |
| 387 | if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then |
503 | if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then |
| 388 | PYTHON_MODNAME="${PN}" |
504 | PYTHON_MODNAME="${PN}" |
| 389 | fi |
505 | fi |
| 390 | done |
506 | done |
| 391 | fi |
507 | fi |
| 392 | |
508 | |
| 393 | if [[ -n "${PYTHON_MODNAME}" ]]; then |
509 | if [[ -n "${PYTHON_MODNAME}" ]]; then |
| 394 | if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
510 | if ! has "${EAPI:-0}" 0 1 2 || _python_package_supporting_installation_for_multiple_python_abis; then |
| 395 | python_mod_optimize ${PYTHON_MODNAME} |
511 | python_mod_optimize ${PYTHON_MODNAME} |
| 396 | else |
512 | else |
| 397 | for pymod in ${PYTHON_MODNAME}; do |
513 | for pymod in ${PYTHON_MODNAME}; do |
| 398 | python_mod_optimize "$(python_get_sitedir)/${pymod}" |
514 | python_mod_optimize "$(python_get_sitedir)/${pymod}" |
| 399 | done |
515 | done |
| … | |
… | |
| 410 | distutils_pkg_postrm() { |
526 | distutils_pkg_postrm() { |
| 411 | if [[ "${EBUILD_PHASE}" != "postrm" ]]; then |
527 | if [[ "${EBUILD_PHASE}" != "postrm" ]]; then |
| 412 | die "${FUNCNAME}() can be used only in pkg_postrm() phase" |
528 | die "${FUNCNAME}() can be used only in pkg_postrm() phase" |
| 413 | fi |
529 | fi |
| 414 | |
530 | |
|
|
531 | _python_check_python_pkg_setup_execution |
| 415 | _python_initialize_prefix_variables |
532 | _python_initialize_prefix_variables |
| 416 | |
533 | |
|
|
534 | if [[ -z "${DISTUTILS_SRC_INSTALL_EXECUTED}" ]]; then |
|
|
535 | die "${FUNCNAME}() called illegally" |
|
|
536 | fi |
|
|
537 | |
| 417 | local pylibdir pymod |
538 | local pylibdir pymod |
|
|
539 | |
|
|
540 | if [[ "$#" -ne 0 ]]; then |
|
|
541 | die "${FUNCNAME}() does not accept arguments" |
|
|
542 | fi |
|
|
543 | |
| 418 | if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then |
544 | if [[ -z "$(declare -p PYTHON_MODNAME 2> /dev/null)" ]]; then |
| 419 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"/usr/share/jython-*/Lib; do |
545 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python* "${EROOT}"usr/share/jython-*/Lib; do |
| 420 | if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then |
546 | if [[ -d "${pylibdir}/site-packages/${PN}" ]]; then |
| 421 | PYTHON_MODNAME="${PN}" |
547 | PYTHON_MODNAME="${PN}" |
| 422 | fi |
548 | fi |
| 423 | done |
549 | done |
| 424 | fi |
550 | fi |
| 425 | |
551 | |
| 426 | if [[ -n "${PYTHON_MODNAME}" ]]; then |
552 | if [[ -n "${PYTHON_MODNAME}" ]]; then |
| 427 | if ! has "${EAPI:-0}" 0 1 2 || [[ -n "${SUPPORT_PYTHON_ABIS}" ]]; then |
553 | if ! has "${EAPI:-0}" 0 1 2 || _python_package_supporting_installation_for_multiple_python_abis; then |
| 428 | python_mod_cleanup ${PYTHON_MODNAME} |
554 | python_mod_cleanup ${PYTHON_MODNAME} |
| 429 | else |
555 | else |
| 430 | for pymod in ${PYTHON_MODNAME}; do |
556 | for pymod in ${PYTHON_MODNAME}; do |
| 431 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python*; do |
557 | for pylibdir in "${EROOT}"usr/$(get_libdir)/python*; do |
| 432 | if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then |
558 | if [[ -d "${pylibdir}/site-packages/${pymod}" ]]; then |
| … | |
… | |
| 436 | done |
562 | done |
| 437 | fi |
563 | fi |
| 438 | fi |
564 | fi |
| 439 | } |
565 | } |
| 440 | |
566 | |
| 441 | # Scheduled for deletion on 2011-01-01. |
567 | # @FUNCTION: distutils_get_intermediate_installation_image |
| 442 | distutils_python_version() { |
568 | # @DESCRIPTION: |
| 443 | eerror "Use PYTHON() instead of python variable. Use python_get_*() instead of PYVER* variables." |
569 | # Print path to intermediate installation image. |
| 444 | die "${FUNCNAME}() is banned" |
570 | # |
| 445 | } |
571 | # This function can be used only in distutils_src_install_pre_hook() and distutils_src_install_post_hook(). |
|
|
572 | distutils_get_intermediate_installation_image() { |
|
|
573 | if [[ "${EBUILD_PHASE}" != "install" ]]; then |
|
|
574 | die "${FUNCNAME}() can be used only in src_install() phase" |
|
|
575 | fi |
| 446 | |
576 | |
| 447 | # Scheduled for deletion on 2011-01-01. |
577 | if ! _python_package_supporting_installation_for_multiple_python_abis; then |
| 448 | distutils_python_tkinter() { |
578 | die "${FUNCNAME}() cannot be used in ebuilds of packages not supporting installation for multiple Python ABIs" |
| 449 | eerror "Use PYTHON_USE_WITH=\"xml\" and python_pkg_setup() instead of ${FUNCNAME}()." |
579 | fi |
| 450 | die "${FUNCNAME}() is banned" |
580 | |
|
|
581 | _python_check_python_pkg_setup_execution |
|
|
582 | |
|
|
583 | if [[ ! "${FUNCNAME[1]}" =~ ^distutils_src_install_(pre|post)_hook$ ]]; then |
|
|
584 | die "${FUNCNAME}() can be used only in distutils_src_install_pre_hook() and distutils_src_install_post_hook()" |
|
|
585 | fi |
|
|
586 | |
|
|
587 | if [[ "$#" -ne 0 ]]; then |
|
|
588 | die "${FUNCNAME}() does not accept arguments" |
|
|
589 | fi |
|
|
590 | |
|
|
591 | echo "${T}/images/${PYTHON_ABI}" |
| 451 | } |
592 | } |