Hanno Böck commited on 2023-10-01 08:44:56
Zeige 3 geänderte Dateien mit 0 Einfügungen und 2369 Löschungen.
... | ... |
@@ -1,395 +0,0 @@ |
1 |
-# Copyright 1999-2020 Gentoo Authors |
|
2 |
-# Distributed under the terms of the GNU General Public License v2 |
|
3 |
- |
|
4 |
-# @ECLASS: python-any-r1.eclass |
|
5 |
-# @MAINTAINER: |
|
6 |
-# Python team <python@gentoo.org> |
|
7 |
-# @AUTHOR: |
|
8 |
-# Author: Michał Górny <mgorny@gentoo.org> |
|
9 |
-# Based on work of: Krzysztof Pawlik <nelchael@gentoo.org> |
|
10 |
-# @SUPPORTED_EAPIS: 5 6 7 |
|
11 |
-# @BLURB: An eclass for packages having build-time dependency on Python. |
|
12 |
-# @DESCRIPTION: |
|
13 |
-# A minimal eclass for packages which need any Python interpreter |
|
14 |
-# installed without a need for explicit choice and invariability. |
|
15 |
-# This usually involves packages requiring Python at build-time |
|
16 |
-# but having no other relevance to it. |
|
17 |
-# |
|
18 |
-# This eclass provides a minimal PYTHON_DEPS variable with a dependency |
|
19 |
-# string on any of the supported Python implementations. It also exports |
|
20 |
-# pkg_setup() which finds the best supported implementation and sets it |
|
21 |
-# as the active one. |
|
22 |
-# |
|
23 |
-# Optionally, you can define a python_check_deps() function. It will |
|
24 |
-# be called by the eclass with EPYTHON set to each matching Python |
|
25 |
-# implementation and it is expected to check whether the implementation |
|
26 |
-# fulfills the package requirements. You can use the locally exported |
|
27 |
-# PYTHON_USEDEP or PYTHON_SINGLE_USEDEP to check USE-dependencies |
|
28 |
-# of relevant packages. It should return a true value (0) if the Python |
|
29 |
-# implementation fulfills the requirements, a false value (non-zero) |
|
30 |
-# otherwise. |
|
31 |
-# |
|
32 |
-# Please note that python-any-r1 will always inherit python-utils-r1 |
|
33 |
-# as well. Thus, all the functions defined there can be used in the |
|
34 |
-# packages using python-any-r1, and there is no need ever to inherit |
|
35 |
-# both. |
|
36 |
-# |
|
37 |
-# For more information, please see the Python Guide: |
|
38 |
-# https://dev.gentoo.org/~mgorny/python-guide/ |
|
39 |
- |
|
40 |
-case "${EAPI:-0}" in |
|
41 |
- [0-4]) die "Unsupported EAPI=${EAPI:-0} (too old) for ${ECLASS}" ;; |
|
42 |
- [5-7]) ;; |
|
43 |
- *) die "Unsupported EAPI=${EAPI} (unknown) for ${ECLASS}" ;; |
|
44 |
-esac |
|
45 |
- |
|
46 |
-if [[ ! ${_PYTHON_ANY_R1} ]]; then |
|
47 |
- |
|
48 |
-if [[ ${_PYTHON_R1} ]]; then |
|
49 |
- die 'python-any-r1.eclass can not be used with python-r1.eclass.' |
|
50 |
-elif [[ ${_PYTHON_SINGLE_R1} ]]; then |
|
51 |
- die 'python-any-r1.eclass can not be used with python-single-r1.eclass.' |
|
52 |
-fi |
|
53 |
- |
|
54 |
-inherit python-utils-r1 |
|
55 |
- |
|
56 |
-fi |
|
57 |
- |
|
58 |
-EXPORT_FUNCTIONS pkg_setup |
|
59 |
- |
|
60 |
-# @ECLASS-VARIABLE: PYTHON_COMPAT |
|
61 |
-# @REQUIRED |
|
62 |
-# @DESCRIPTION: |
|
63 |
-# This variable contains a list of Python implementations the package |
|
64 |
-# supports. It must be set before the `inherit' call. It has to be |
|
65 |
-# an array. |
|
66 |
-# |
|
67 |
-# Example: |
|
68 |
-# @CODE |
|
69 |
-# PYTHON_COMPAT=( python{2_5,2_6,2_7} ) |
|
70 |
-# @CODE |
|
71 |
- |
|
72 |
-# @ECLASS-VARIABLE: PYTHON_COMPAT_OVERRIDE |
|
73 |
-# @USER_VARIABLE |
|
74 |
-# @DEFAULT_UNSET |
|
75 |
-# @DESCRIPTION: |
|
76 |
-# This variable can be used when working with ebuilds to override |
|
77 |
-# the in-ebuild PYTHON_COMPAT. It is a string naming the implementation |
|
78 |
-# which will be used to build the package. It needs to be specified |
|
79 |
-# in the calling environment, and not in ebuilds. |
|
80 |
-# |
|
81 |
-# It should be noted that in order to preserve metadata immutability, |
|
82 |
-# PYTHON_COMPAT_OVERRIDE does not affect dependencies. The value of |
|
83 |
-# EPYTHON and eselect-python preferences are ignored. Dependencies need |
|
84 |
-# to be satisfied manually. |
|
85 |
-# |
|
86 |
-# Example: |
|
87 |
-# @CODE |
|
88 |
-# PYTHON_COMPAT_OVERRIDE='pypy' emerge -1v dev-python/bar |
|
89 |
-# @CODE |
|
90 |
- |
|
91 |
-# @ECLASS-VARIABLE: PYTHON_REQ_USE |
|
92 |
-# @DEFAULT_UNSET |
|
93 |
-# @DESCRIPTION: |
|
94 |
-# The list of USEflags required to be enabled on the Python |
|
95 |
-# implementations, formed as a USE-dependency string. It should be valid |
|
96 |
-# for all implementations in PYTHON_COMPAT, so it may be necessary to |
|
97 |
-# use USE defaults. |
|
98 |
-# |
|
99 |
-# Example: |
|
100 |
-# @CODE |
|
101 |
-# PYTHON_REQ_USE="gdbm,ncurses(-)?" |
|
102 |
-# @CODE |
|
103 |
-# |
|
104 |
-# It will cause the Python dependencies to look like: |
|
105 |
-# @CODE |
|
106 |
-# || ( dev-lang/python:X.Y[gdbm,ncurses(-)?] ... ) |
|
107 |
-# @CODE |
|
108 |
- |
|
109 |
-# @ECLASS-VARIABLE: PYTHON_DEPS |
|
110 |
-# @OUTPUT_VARIABLE |
|
111 |
-# @DESCRIPTION: |
|
112 |
-# This is an eclass-generated Python dependency string for all |
|
113 |
-# implementations listed in PYTHON_COMPAT. |
|
114 |
-# |
|
115 |
-# Any of the supported interpreters will satisfy the dependency. |
|
116 |
-# |
|
117 |
-# Example use: |
|
118 |
-# @CODE |
|
119 |
-# DEPEND="${RDEPEND} |
|
120 |
-# ${PYTHON_DEPS}" |
|
121 |
-# @CODE |
|
122 |
-# |
|
123 |
-# Example value: |
|
124 |
-# @CODE |
|
125 |
-# || ( dev-lang/python:2.7[gdbm] |
|
126 |
-# dev-lang/python:2.6[gdbm] ) |
|
127 |
-# @CODE |
|
128 |
- |
|
129 |
-# @ECLASS-VARIABLE: PYTHON_USEDEP |
|
130 |
-# @OUTPUT_VARIABLE |
|
131 |
-# @DESCRIPTION: |
|
132 |
-# An eclass-generated USE-dependency string for the currently tested |
|
133 |
-# implementation. It is set locally for python_check_deps() call. |
|
134 |
-# |
|
135 |
-# The generated USE-flag list is compatible with packages using |
|
136 |
-# python-r1 eclass. For python-single-r1 dependencies, |
|
137 |
-# use PYTHON_SINGLE_USEDEP. |
|
138 |
-# |
|
139 |
-# Example use: |
|
140 |
-# @CODE |
|
141 |
-# python_check_deps() { |
|
142 |
-# has_version "dev-python/foo[${PYTHON_USEDEP}]" |
|
143 |
-# } |
|
144 |
-# @CODE |
|
145 |
-# |
|
146 |
-# Example value: |
|
147 |
-# @CODE |
|
148 |
-# python_targets_python3_7(-),-python_single_target_python3_7(-) |
|
149 |
-# @CODE |
|
150 |
- |
|
151 |
-# @ECLASS-VARIABLE: PYTHON_SINGLE_USEDEP |
|
152 |
-# @OUTPUT_VARIABLE |
|
153 |
-# @DESCRIPTION: |
|
154 |
-# An eclass-generated USE-dependency string for the currently tested |
|
155 |
-# implementation. It is set locally for python_check_deps() call. |
|
156 |
-# |
|
157 |
-# The generated USE-flag list is compatible with packages using |
|
158 |
-# python-single-r1 eclass. For python-r1 dependencies, |
|
159 |
-# use PYTHON_USEDEP. |
|
160 |
-# |
|
161 |
-# Example use: |
|
162 |
-# @CODE |
|
163 |
-# python_check_deps() { |
|
164 |
-# has_version "dev-python/bar[${PYTHON_SINGLE_USEDEP}]" |
|
165 |
-# } |
|
166 |
-# @CODE |
|
167 |
-# |
|
168 |
-# Example value: |
|
169 |
-# @CODE |
|
170 |
-# python_single_target_python3_7(-) |
|
171 |
-# @CODE |
|
172 |
- |
|
173 |
-_python_any_set_globals() { |
|
174 |
- local usestr deps i PYTHON_PKG_DEP |
|
175 |
- [[ ${PYTHON_REQ_USE} ]] && usestr="[${PYTHON_REQ_USE}]" |
|
176 |
- |
|
177 |
- _python_set_impls |
|
178 |
- |
|
179 |
- for i in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
180 |
- _python_export "${i}" PYTHON_PKG_DEP |
|
181 |
- |
|
182 |
- # note: need to strip '=' slot operator for || deps |
|
183 |
- deps="${PYTHON_PKG_DEP/:0=/:0} ${deps}" |
|
184 |
- done |
|
185 |
- deps="|| ( ${deps})" |
|
186 |
- |
|
187 |
- if [[ ${PYTHON_DEPS+1} ]]; then |
|
188 |
- if [[ ${PYTHON_DEPS} != "${deps}" ]]; then |
|
189 |
- eerror "PYTHON_DEPS have changed between inherits (PYTHON_REQ_USE?)!" |
|
190 |
- eerror "Before: ${PYTHON_DEPS}" |
|
191 |
- eerror "Now : ${deps}" |
|
192 |
- die "PYTHON_DEPS integrity check failed" |
|
193 |
- fi |
|
194 |
- else |
|
195 |
- PYTHON_DEPS=${deps} |
|
196 |
- readonly PYTHON_DEPS |
|
197 |
- fi |
|
198 |
- |
|
199 |
- if [[ ! ${PYTHON_REQUIRED_USE+1} ]]; then |
|
200 |
- # fake var to catch mistaken usage |
|
201 |
- PYTHON_REQUIRED_USE='I-DO-NOT-EXIST-IN-PYTHON-ANY-R1' |
|
202 |
- readonly PYTHON_REQUIRED_USE |
|
203 |
- fi |
|
204 |
-} |
|
205 |
-_python_any_set_globals |
|
206 |
-unset -f _python_any_set_globals |
|
207 |
- |
|
208 |
-if [[ ! ${_PYTHON_ANY_R1} ]]; then |
|
209 |
- |
|
210 |
-# @FUNCTION: python_gen_any_dep |
|
211 |
-# @USAGE: <dependency-block> |
|
212 |
-# @DESCRIPTION: |
|
213 |
-# Generate an any-of dependency that enforces a version match between |
|
214 |
-# the Python interpreter and Python packages. <dependency-block> needs |
|
215 |
-# to list one or more dependencies with verbatim '${PYTHON_USEDEP}' |
|
216 |
-# or '${PYTHON_SINGLE_USEDEP}' references (quoted!) that will get |
|
217 |
-# expanded inside the function. |
|
218 |
-# |
|
219 |
-# This should be used along with an appropriate python_check_deps() |
|
220 |
-# that checks which of the any-of blocks were matched. |
|
221 |
-# |
|
222 |
-# Example use: |
|
223 |
-# @CODE |
|
224 |
-# DEPEND="$(python_gen_any_dep ' |
|
225 |
-# dev-python/foo[${PYTHON_SINGLE_USEDEP}] |
|
226 |
-# || ( dev-python/bar[${PYTHON_USEDEP}] |
|
227 |
-# dev-python/baz[${PYTHON_USEDEP}] )')" |
|
228 |
-# |
|
229 |
-# python_check_deps() { |
|
230 |
-# has_version "dev-python/foo[${PYTHON_SINGLE_USEDEP}]" \ |
|
231 |
-# && { has_version "dev-python/bar[${PYTHON_USEDEP}]" \ |
|
232 |
-# || has_version "dev-python/baz[${PYTHON_USEDEP}]"; } |
|
233 |
-# } |
|
234 |
-# @CODE |
|
235 |
-# |
|
236 |
-# Example value: |
|
237 |
-# @CODE |
|
238 |
-# || ( |
|
239 |
-# ( |
|
240 |
-# dev-lang/python:3.7 |
|
241 |
-# dev-python/foo[python_single_target_python3_7(-)] |
|
242 |
-# || ( dev-python/bar[python_targets_python3_7(-),-python_single_target_python3_7(-)] |
|
243 |
-# dev-python/baz[python_targets_python3_7(-),-python_single_target_python3_7(-)] ) |
|
244 |
-# ) |
|
245 |
-# ( |
|
246 |
-# dev-lang/python:3.8 |
|
247 |
-# dev-python/foo[python_single_target_python3_8(-)] |
|
248 |
-# || ( dev-python/bar[python_targets_python3_8(-),-python_single_target_python3_8(-)] |
|
249 |
-# dev-python/baz[python_targets_python3_8(-),-python_single_target_python3_8(-)] ) |
|
250 |
-# ) |
|
251 |
-# ) |
|
252 |
-# @CODE |
|
253 |
-python_gen_any_dep() { |
|
254 |
- debug-print-function ${FUNCNAME} "${@}" |
|
255 |
- |
|
256 |
- local depstr=${1} |
|
257 |
- [[ ${depstr} ]] || die "No dependency string provided" |
|
258 |
- |
|
259 |
- local i PYTHON_PKG_DEP out= |
|
260 |
- for i in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
261 |
- local PYTHON_USEDEP="python_targets_${i}(-),-python_single_target_${i}(-)" |
|
262 |
- local PYTHON_SINGLE_USEDEP="python_single_target_${i}(-)" |
|
263 |
- _python_export "${i}" PYTHON_PKG_DEP |
|
264 |
- |
|
265 |
- local i_depstr=${depstr//\$\{PYTHON_USEDEP\}/${PYTHON_USEDEP}} |
|
266 |
- i_depstr=${i_depstr//\$\{PYTHON_SINGLE_USEDEP\}/${PYTHON_SINGLE_USEDEP}} |
|
267 |
- # note: need to strip '=' slot operator for || deps |
|
268 |
- out="( ${PYTHON_PKG_DEP%=} ${i_depstr} ) ${out}" |
|
269 |
- done |
|
270 |
- echo "|| ( ${out})" |
|
271 |
-} |
|
272 |
- |
|
273 |
-# @FUNCTION: _python_EPYTHON_supported |
|
274 |
-# @USAGE: <epython> |
|
275 |
-# @INTERNAL |
|
276 |
-# @DESCRIPTION: |
|
277 |
-# Check whether the specified implementation is supported by package |
|
278 |
-# (specified in PYTHON_COMPAT). Calls python_check_deps() if declared. |
|
279 |
-_python_EPYTHON_supported() { |
|
280 |
- debug-print-function ${FUNCNAME} "${@}" |
|
281 |
- |
|
282 |
- local EPYTHON=${1} |
|
283 |
- local i=${EPYTHON/./_} |
|
284 |
- |
|
285 |
- case "${i}" in |
|
286 |
- python*|jython*|pypy*) |
|
287 |
- ;; |
|
288 |
- *) |
|
289 |
- ewarn "Invalid EPYTHON: ${EPYTHON}" |
|
290 |
- return 1 |
|
291 |
- ;; |
|
292 |
- esac |
|
293 |
- |
|
294 |
- if has "${i}" "${_PYTHON_SUPPORTED_IMPLS[@]}"; then |
|
295 |
- if python_is_installed "${i}"; then |
|
296 |
- if declare -f python_check_deps >/dev/null; then |
|
297 |
- local PYTHON_USEDEP="python_targets_${i}(-),-python_single_target_${i}(-)" |
|
298 |
- local PYTHON_SINGLE_USEDEP="python_single_target_${i}(-)" |
|
299 |
- python_check_deps |
|
300 |
- return ${?} |
|
301 |
- fi |
|
302 |
- |
|
303 |
- return 0 |
|
304 |
- fi |
|
305 |
- elif ! has "${i}" "${_PYTHON_ALL_IMPLS[@]}"; then |
|
306 |
- ewarn "Invalid EPYTHON: ${EPYTHON}" |
|
307 |
- fi |
|
308 |
- return 1 |
|
309 |
-} |
|
310 |
- |
|
311 |
-# @FUNCTION: python_setup |
|
312 |
-# @DESCRIPTION: |
|
313 |
-# Determine what the best installed (and supported) Python |
|
314 |
-# implementation is, and set the Python build environment up for it. |
|
315 |
-# |
|
316 |
-# This function will call python_check_deps() if defined. |
|
317 |
-python_setup() { |
|
318 |
- debug-print-function ${FUNCNAME} "${@}" |
|
319 |
- |
|
320 |
- # support developer override |
|
321 |
- if [[ ${PYTHON_COMPAT_OVERRIDE} ]]; then |
|
322 |
- local impls=( ${PYTHON_COMPAT_OVERRIDE} ) |
|
323 |
- [[ ${#impls[@]} -eq 1 ]] || die "PYTHON_COMPAT_OVERRIDE must name exactly one implementation for python-any-r1" |
|
324 |
- |
|
325 |
- ewarn "WARNING: PYTHON_COMPAT_OVERRIDE in effect. The following Python" |
|
326 |
- ewarn "implementation will be used:" |
|
327 |
- ewarn |
|
328 |
- ewarn " ${PYTHON_COMPAT_OVERRIDE}" |
|
329 |
- ewarn |
|
330 |
- ewarn "Dependencies won't be satisfied, and EPYTHON/eselect-python will be ignored." |
|
331 |
- |
|
332 |
- _python_export "${impls[0]}" EPYTHON PYTHON |
|
333 |
- _python_wrapper_setup |
|
334 |
- einfo "Using ${EPYTHON} to build" |
|
335 |
- return |
|
336 |
- fi |
|
337 |
- |
|
338 |
- # first, try ${EPYTHON}... maybe it's good enough for us. |
|
339 |
- if [[ ${EPYTHON} ]]; then |
|
340 |
- if _python_EPYTHON_supported "${EPYTHON}"; then |
|
341 |
- _python_export EPYTHON PYTHON |
|
342 |
- _python_wrapper_setup |
|
343 |
- einfo "Using ${EPYTHON} to build" |
|
344 |
- return |
|
345 |
- fi |
|
346 |
- fi |
|
347 |
- |
|
348 |
- # then, try eselect-python |
|
349 |
- local variant i |
|
350 |
- for variant in '' '--python2' '--python3'; do |
|
351 |
- i=$(eselect python --show ${variant} 2>/dev/null) |
|
352 |
- |
|
353 |
- if [[ ! ${i} ]]; then |
|
354 |
- # no eselect-python? |
|
355 |
- break |
|
356 |
- elif _python_EPYTHON_supported "${i}"; then |
|
357 |
- _python_export "${i}" EPYTHON PYTHON |
|
358 |
- _python_wrapper_setup |
|
359 |
- einfo "Using ${EPYTHON} to build" |
|
360 |
- return |
|
361 |
- fi |
|
362 |
- done |
|
363 |
- |
|
364 |
- # fallback to best installed impl. |
|
365 |
- # (reverse iteration over _PYTHON_SUPPORTED_IMPLS) |
|
366 |
- for (( i = ${#_PYTHON_SUPPORTED_IMPLS[@]} - 1; i >= 0; i-- )); do |
|
367 |
- _python_export "${_PYTHON_SUPPORTED_IMPLS[i]}" EPYTHON PYTHON |
|
368 |
- if _python_EPYTHON_supported "${EPYTHON}"; then |
|
369 |
- _python_wrapper_setup |
|
370 |
- einfo "Using ${EPYTHON} to build" |
|
371 |
- return |
|
372 |
- fi |
|
373 |
- done |
|
374 |
- |
|
375 |
- eerror "No Python implementation found for the build. This is usually" |
|
376 |
- eerror "a bug in the ebuild. Please report it to bugs.gentoo.org" |
|
377 |
- eerror "along with the build log." |
|
378 |
- echo |
|
379 |
- die "No supported Python implementation installed." |
|
380 |
-} |
|
381 |
- |
|
382 |
-# @FUNCTION: python-any-r1_pkg_setup |
|
383 |
-# @DESCRIPTION: |
|
384 |
-# Runs python_setup during from-source installs. |
|
385 |
-# |
|
386 |
-# In a binary package installs is a no-op. If you need Python in pkg_* |
|
387 |
-# phases of a binary package, call python_setup directly. |
|
388 |
-python-any-r1_pkg_setup() { |
|
389 |
- debug-print-function ${FUNCNAME} "${@}" |
|
390 |
- |
|
391 |
- [[ ${MERGE_TYPE} != binary ]] && python_setup |
|
392 |
-} |
|
393 |
- |
|
394 |
-_PYTHON_ANY_R1=1 |
|
395 |
-fi |
... | ... |
@@ -1,529 +0,0 @@ |
1 |
-# Copyright 1999-2021 Gentoo Authors |
|
2 |
-# Distributed under the terms of the GNU General Public License v2 |
|
3 |
- |
|
4 |
-# @ECLASS: python-single-r1.eclass |
|
5 |
-# @MAINTAINER: |
|
6 |
-# Python team <python@gentoo.org> |
|
7 |
-# @AUTHOR: |
|
8 |
-# Author: Michał Górny <mgorny@gentoo.org> |
|
9 |
-# Based on work of: Krzysztof Pawlik <nelchael@gentoo.org> |
|
10 |
-# @SUPPORTED_EAPIS: 5 6 7 |
|
11 |
-# @BLURB: An eclass for Python packages not installed for multiple implementations. |
|
12 |
-# @DESCRIPTION: |
|
13 |
-# An extension of the python-r1 eclass suite for packages which |
|
14 |
-# don't support being installed for multiple Python implementations. |
|
15 |
-# This mostly includes tools embedding Python and packages using foreign |
|
16 |
-# build systems. |
|
17 |
-# |
|
18 |
-# This eclass sets correct IUSE. It also provides PYTHON_DEPS |
|
19 |
-# and PYTHON_REQUIRED_USE that need to be added to appropriate ebuild |
|
20 |
-# metadata variables. |
|
21 |
-# |
|
22 |
-# The eclass exports PYTHON_SINGLE_USEDEP that is suitable for depending |
|
23 |
-# on other packages using the eclass. Dependencies on packages using |
|
24 |
-# python-r1 should be created via python_gen_cond_dep() function, |
|
25 |
-# using PYTHON_USEDEP placeholder. |
|
26 |
-# |
|
27 |
-# Please note that packages support multiple Python implementations |
|
28 |
-# (using python-r1 eclass) can not depend on packages not supporting |
|
29 |
-# them (using this eclass). |
|
30 |
-# |
|
31 |
-# Please note that python-single-r1 will always inherit python-utils-r1 |
|
32 |
-# as well. Thus, all the functions defined there can be used |
|
33 |
-# in the packages using python-single-r1, and there is no need ever |
|
34 |
-# to inherit both. |
|
35 |
-# |
|
36 |
-# For more information, please see the Python Guide: |
|
37 |
-# https://dev.gentoo.org/~mgorny/python-guide/ |
|
38 |
- |
|
39 |
-case "${EAPI:-0}" in |
|
40 |
- 0|1|2|3|4) |
|
41 |
- die "Unsupported EAPI=${EAPI:-0} (too old) for ${ECLASS}" |
|
42 |
- ;; |
|
43 |
- 5|6|7) |
|
44 |
- # EAPI=5 is required for sane USE_EXPAND dependencies |
|
45 |
- ;; |
|
46 |
- *) |
|
47 |
- die "Unsupported EAPI=${EAPI} (unknown) for ${ECLASS}" |
|
48 |
- ;; |
|
49 |
-esac |
|
50 |
- |
|
51 |
-if [[ ! ${_PYTHON_SINGLE_R1} ]]; then |
|
52 |
- |
|
53 |
-if [[ ${_PYTHON_R1} ]]; then |
|
54 |
- die 'python-single-r1.eclass can not be used with python-r1.eclass.' |
|
55 |
-elif [[ ${_PYTHON_ANY_R1} ]]; then |
|
56 |
- die 'python-single-r1.eclass can not be used with python-any-r1.eclass.' |
|
57 |
-fi |
|
58 |
- |
|
59 |
-inherit python-utils-r1 |
|
60 |
- |
|
61 |
-fi |
|
62 |
- |
|
63 |
-EXPORT_FUNCTIONS pkg_setup |
|
64 |
- |
|
65 |
-# @ECLASS-VARIABLE: PYTHON_COMPAT |
|
66 |
-# @REQUIRED |
|
67 |
-# @DESCRIPTION: |
|
68 |
-# This variable contains a list of Python implementations the package |
|
69 |
-# supports. It must be set before the `inherit' call. It has to be |
|
70 |
-# an array. |
|
71 |
-# |
|
72 |
-# Example: |
|
73 |
-# @CODE |
|
74 |
-# PYTHON_COMPAT=( python2_7 python3_3 python3_4 ) |
|
75 |
-# @CODE |
|
76 |
-# |
|
77 |
-# Please note that you can also use bash brace expansion if you like: |
|
78 |
-# @CODE |
|
79 |
-# PYTHON_COMPAT=( python2_7 python3_{3,4} ) |
|
80 |
-# @CODE |
|
81 |
- |
|
82 |
-# @ECLASS-VARIABLE: PYTHON_COMPAT_OVERRIDE |
|
83 |
-# @USER_VARIABLE |
|
84 |
-# @DEFAULT_UNSET |
|
85 |
-# @DESCRIPTION: |
|
86 |
-# This variable can be used when working with ebuilds to override |
|
87 |
-# the in-ebuild PYTHON_COMPAT. It is a string naming the implementation |
|
88 |
-# which package will be built for. It needs to be specified |
|
89 |
-# in the calling environment, and not in ebuilds. |
|
90 |
-# |
|
91 |
-# It should be noted that in order to preserve metadata immutability, |
|
92 |
-# PYTHON_COMPAT_OVERRIDE does not affect IUSE nor dependencies. |
|
93 |
-# The state of PYTHON_SINGLE_TARGET is ignored, and the implementation |
|
94 |
-# in PYTHON_COMPAT_OVERRIDE is built instead. Dependencies need to be |
|
95 |
-# satisfied manually. |
|
96 |
-# |
|
97 |
-# Example: |
|
98 |
-# @CODE |
|
99 |
-# PYTHON_COMPAT_OVERRIDE='pypy' emerge -1v dev-python/bar |
|
100 |
-# @CODE |
|
101 |
- |
|
102 |
-# @ECLASS-VARIABLE: PYTHON_REQ_USE |
|
103 |
-# @DEFAULT_UNSET |
|
104 |
-# @DESCRIPTION: |
|
105 |
-# The list of USEflags required to be enabled on the chosen Python |
|
106 |
-# implementations, formed as a USE-dependency string. It should be valid |
|
107 |
-# for all implementations in PYTHON_COMPAT, so it may be necessary to |
|
108 |
-# use USE defaults. |
|
109 |
-# |
|
110 |
-# This should be set before calling `inherit'. |
|
111 |
-# |
|
112 |
-# Example: |
|
113 |
-# @CODE |
|
114 |
-# PYTHON_REQ_USE="gdbm,ncurses(-)?" |
|
115 |
-# @CODE |
|
116 |
-# |
|
117 |
-# It will cause the Python dependencies to look like: |
|
118 |
-# @CODE |
|
119 |
-# python_single_target_pythonX_Y? ( dev-lang/python:X.Y[gdbm,ncurses(-)?] ) |
|
120 |
-# @CODE |
|
121 |
- |
|
122 |
-# @ECLASS-VARIABLE: PYTHON_DEPS |
|
123 |
-# @OUTPUT_VARIABLE |
|
124 |
-# @DESCRIPTION: |
|
125 |
-# This is an eclass-generated Python dependency string for all |
|
126 |
-# implementations listed in PYTHON_COMPAT. |
|
127 |
-# |
|
128 |
-# The dependency string is conditional on PYTHON_SINGLE_TARGET. |
|
129 |
-# |
|
130 |
-# Example use: |
|
131 |
-# @CODE |
|
132 |
-# RDEPEND="${PYTHON_DEPS} |
|
133 |
-# dev-foo/mydep" |
|
134 |
-# BDEPEND="${PYTHON_DEPS}" |
|
135 |
-# @CODE |
|
136 |
-# |
|
137 |
-# Example value: |
|
138 |
-# @CODE |
|
139 |
-# dev-lang/python-exec:= |
|
140 |
-# python_single_target_python2_7? ( dev-lang/python:2.7[gdbm] ) |
|
141 |
-# python_single_target_pypy? ( dev-python/pypy[gdbm] ) |
|
142 |
-# @CODE |
|
143 |
- |
|
144 |
-# @ECLASS-VARIABLE: PYTHON_SINGLE_USEDEP |
|
145 |
-# @OUTPUT_VARIABLE |
|
146 |
-# @DESCRIPTION: |
|
147 |
-# This is an eclass-generated USE-dependency string which can be used to |
|
148 |
-# depend on another python-single-r1 package being built for the same |
|
149 |
-# Python implementations. |
|
150 |
-# |
|
151 |
-# If you need to depend on a multi-impl (python-r1) package, use |
|
152 |
-# python_gen_cond_dep with PYTHON_USEDEP placeholder instead. |
|
153 |
-# |
|
154 |
-# Example use: |
|
155 |
-# @CODE |
|
156 |
-# RDEPEND="dev-python/foo[${PYTHON_SINGLE_USEDEP}]" |
|
157 |
-# @CODE |
|
158 |
-# |
|
159 |
-# Example value: |
|
160 |
-# @CODE |
|
161 |
-# python_single_target_python3_4(-)? |
|
162 |
-# @CODE |
|
163 |
- |
|
164 |
-# @ECLASS-VARIABLE: PYTHON_USEDEP |
|
165 |
-# @OUTPUT_VARIABLE |
|
166 |
-# @DESCRIPTION: |
|
167 |
-# This is a placeholder variable supported by python_gen_cond_dep, |
|
168 |
-# in order to depend on python-r1 packages built for the same Python |
|
169 |
-# implementations. |
|
170 |
-# |
|
171 |
-# Example use: |
|
172 |
-# @CODE |
|
173 |
-# RDEPEND="$(python_gen_cond_dep ' |
|
174 |
-# dev-python/foo[${PYTHON_USEDEP}] |
|
175 |
-# ')" |
|
176 |
-# @CODE |
|
177 |
-# |
|
178 |
-# Example value: |
|
179 |
-# @CODE |
|
180 |
-# python_targets_python3_4(-) |
|
181 |
-# @CODE |
|
182 |
- |
|
183 |
-# @ECLASS-VARIABLE: PYTHON_MULTI_USEDEP |
|
184 |
-# @OUTPUT_VARIABLE |
|
185 |
-# @DESCRIPTION: |
|
186 |
-# This is a backwards-compatibility placeholder. Use PYTHON_USEDEP |
|
187 |
-# instead. |
|
188 |
- |
|
189 |
-# @ECLASS-VARIABLE: PYTHON_REQUIRED_USE |
|
190 |
-# @OUTPUT_VARIABLE |
|
191 |
-# @DESCRIPTION: |
|
192 |
-# This is an eclass-generated required-use expression which ensures |
|
193 |
-# that exactly one PYTHON_SINGLE_TARGET value has been enabled. |
|
194 |
-# |
|
195 |
-# This expression should be utilized in an ebuild by including it in |
|
196 |
-# REQUIRED_USE, optionally behind a use flag. |
|
197 |
-# |
|
198 |
-# Example use: |
|
199 |
-# @CODE |
|
200 |
-# REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )" |
|
201 |
-# @CODE |
|
202 |
-# |
|
203 |
-# Example value: |
|
204 |
-# @CODE |
|
205 |
-# ^^ ( python_single_target_python2_7 python_single_target_python3_3 ) |
|
206 |
-# @CODE |
|
207 |
- |
|
208 |
-_python_single_set_globals() { |
|
209 |
- _python_set_impls |
|
210 |
- |
|
211 |
- local flags=( "${_PYTHON_SUPPORTED_IMPLS[@]/#/python_single_target_}" ) |
|
212 |
- |
|
213 |
- if [[ ${#_PYTHON_SUPPORTED_IMPLS[@]} -eq 1 ]]; then |
|
214 |
- # if only one implementation is supported, use IUSE defaults |
|
215 |
- # to avoid requesting the user to enable it |
|
216 |
- IUSE="+${flags[0]}" |
|
217 |
- else |
|
218 |
- IUSE="${flags[*]}" |
|
219 |
- fi |
|
220 |
- |
|
221 |
- local requse="^^ ( ${flags[*]} )" |
|
222 |
- local single_flags="${flags[@]/%/(-)?}" |
|
223 |
- local single_usedep=${single_flags// /,} |
|
224 |
- |
|
225 |
- local deps= i PYTHON_PKG_DEP |
|
226 |
- for i in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
227 |
- _python_export "${i}" PYTHON_PKG_DEP |
|
228 |
- # 1) well, python-exec would suffice as an RDEP |
|
229 |
- # but no point in making this overcomplex, BDEP doesn't hurt anyone |
|
230 |
- # 2) python-exec should be built with all targets forced anyway |
|
231 |
- # but if new targets were added, we may need to force a rebuild |
|
232 |
- deps+="python_single_target_${i}? ( |
|
233 |
- ${PYTHON_PKG_DEP} |
|
234 |
- >=dev-lang/python-exec-2:=[python_targets_${i}] |
|
235 |
- ) " |
|
236 |
- done |
|
237 |
- |
|
238 |
- if [[ ${PYTHON_DEPS+1} ]]; then |
|
239 |
- if [[ ${PYTHON_DEPS} != "${deps}" ]]; then |
|
240 |
- eerror "PYTHON_DEPS have changed between inherits (PYTHON_REQ_USE?)!" |
|
241 |
- eerror "Before: ${PYTHON_DEPS}" |
|
242 |
- eerror "Now : ${deps}" |
|
243 |
- die "PYTHON_DEPS integrity check failed" |
|
244 |
- fi |
|
245 |
- |
|
246 |
- # these two are formality -- they depend on PYTHON_COMPAT only |
|
247 |
- if [[ ${PYTHON_REQUIRED_USE} != ${requse} ]]; then |
|
248 |
- eerror "PYTHON_REQUIRED_USE have changed between inherits!" |
|
249 |
- eerror "Before: ${PYTHON_REQUIRED_USE}" |
|
250 |
- eerror "Now : ${requse}" |
|
251 |
- die "PYTHON_REQUIRED_USE integrity check failed" |
|
252 |
- fi |
|
253 |
- |
|
254 |
- if [[ ${PYTHON_SINGLE_USEDEP} != "${single_usedep}" ]]; then |
|
255 |
- eerror "PYTHON_SINGLE_USEDEP have changed between inherits!" |
|
256 |
- eerror "Before: ${PYTHON_SINGLE_USEDEP}" |
|
257 |
- eerror "Now : ${single_usedep}" |
|
258 |
- die "PYTHON_SINGLE_USEDEP integrity check failed" |
|
259 |
- fi |
|
260 |
- else |
|
261 |
- PYTHON_DEPS=${deps} |
|
262 |
- PYTHON_REQUIRED_USE=${requse} |
|
263 |
- PYTHON_USEDEP='%PYTHON_USEDEP-NEEDS-TO-BE-USED-IN-PYTHON_GEN_COND_DEP%' |
|
264 |
- PYTHON_SINGLE_USEDEP=${single_usedep} |
|
265 |
- readonly PYTHON_DEPS PYTHON_REQUIRED_USE PYTHON_SINGLE_USEDEP \ |
|
266 |
- PYTHON_USEDEP |
|
267 |
- fi |
|
268 |
-} |
|
269 |
-_python_single_set_globals |
|
270 |
-unset -f _python_single_set_globals |
|
271 |
- |
|
272 |
-if [[ ! ${_PYTHON_SINGLE_R1} ]]; then |
|
273 |
- |
|
274 |
-# @FUNCTION: _python_gen_usedep |
|
275 |
-# @USAGE: [<pattern>...] |
|
276 |
-# @INTERNAL |
|
277 |
-# @DESCRIPTION: |
|
278 |
-# Output a USE dependency string for Python implementations which |
|
279 |
-# are both in PYTHON_COMPAT and match any of the patterns passed |
|
280 |
-# as parameters to the function. |
|
281 |
-# |
|
282 |
-# The patterns can be either fnmatch-style patterns (matched via bash |
|
283 |
-# == operator against PYTHON_COMPAT values) or '-2' / '-3' to indicate |
|
284 |
-# appropriately all enabled Python 2/3 implementations (alike |
|
285 |
-# python_is_python3). Remember to escape or quote the fnmatch patterns |
|
286 |
-# to prevent accidental shell filename expansion. |
|
287 |
-# |
|
288 |
-# This is an internal function used to implement python_gen_cond_dep. |
|
289 |
-_python_gen_usedep() { |
|
290 |
- debug-print-function ${FUNCNAME} "${@}" |
|
291 |
- |
|
292 |
- local impl matches=() |
|
293 |
- |
|
294 |
- _python_verify_patterns "${@}" |
|
295 |
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
296 |
- if _python_impl_matches "${impl}" "${@}"; then |
|
297 |
- matches+=( |
|
298 |
- "python_single_target_${impl}(-)?" |
|
299 |
- ) |
|
300 |
- fi |
|
301 |
- done |
|
302 |
- |
|
303 |
- [[ ${matches[@]} ]] || die "No supported implementations match python_gen_usedep patterns: ${@}" |
|
304 |
- |
|
305 |
- local out=${matches[@]} |
|
306 |
- echo "${out// /,}" |
|
307 |
-} |
|
308 |
- |
|
309 |
-# @FUNCTION: python_gen_useflags |
|
310 |
-# @USAGE: [<pattern>...] |
|
311 |
-# @DESCRIPTION: |
|
312 |
-# Output a list of USE flags for Python implementations which |
|
313 |
-# are both in PYTHON_COMPAT and match any of the patterns passed |
|
314 |
-# as parameters to the function. |
|
315 |
-# |
|
316 |
-# The patterns can be either fnmatch-style patterns (matched via bash |
|
317 |
-# == operator against PYTHON_COMPAT values) or '-2' / '-3' to indicate |
|
318 |
-# appropriately all enabled Python 2/3 implementations (alike |
|
319 |
-# python_is_python3). Remember to escape or quote the fnmatch patterns |
|
320 |
-# to prevent accidental shell filename expansion. |
|
321 |
-# |
|
322 |
-# Example: |
|
323 |
-# @CODE |
|
324 |
-# PYTHON_COMPAT=( python{2_7,3_4} ) |
|
325 |
-# REQUIRED_USE="doc? ( ^^ ( $(python_gen_useflags 'python2*') ) )" |
|
326 |
-# @CODE |
|
327 |
-# |
|
328 |
-# It will cause the variable to look like: |
|
329 |
-# @CODE |
|
330 |
-# REQUIRED_USE="doc? ( ^^ ( python_single_target_python2_7 ) )" |
|
331 |
-# @CODE |
|
332 |
-python_gen_useflags() { |
|
333 |
- debug-print-function ${FUNCNAME} "${@}" |
|
334 |
- |
|
335 |
- local impl matches=() |
|
336 |
- |
|
337 |
- _python_verify_patterns "${@}" |
|
338 |
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
339 |
- if _python_impl_matches "${impl}" "${@}"; then |
|
340 |
- matches+=( "python_single_target_${impl}" ) |
|
341 |
- fi |
|
342 |
- done |
|
343 |
- |
|
344 |
- echo "${matches[@]}" |
|
345 |
-} |
|
346 |
- |
|
347 |
-# @FUNCTION: python_gen_cond_dep |
|
348 |
-# @USAGE: <dependency> [<pattern>...] |
|
349 |
-# @DESCRIPTION: |
|
350 |
-# Output a list of <dependency>-ies made conditional to USE flags |
|
351 |
-# of Python implementations which are both in PYTHON_COMPAT and match |
|
352 |
-# any of the patterns passed as the remaining parameters. |
|
353 |
-# |
|
354 |
-# The patterns can be either fnmatch-style patterns (matched via bash |
|
355 |
-# == operator against PYTHON_COMPAT values) or '-2' / '-3' to indicate |
|
356 |
-# appropriately all enabled Python 2/3 implementations (alike |
|
357 |
-# python_is_python3). Remember to escape or quote the fnmatch patterns |
|
358 |
-# to prevent accidental shell filename expansion. |
|
359 |
-# |
|
360 |
-# In order to enforce USE constraints on the packages, verbatim |
|
361 |
-# '${PYTHON_SINGLE_USEDEP}' and '${PYTHON_USEDEP}' (quoted!) may |
|
362 |
-# be placed in the dependency specification. It will get expanded within |
|
363 |
-# the function into a proper USE dependency string. |
|
364 |
-# |
|
365 |
-# Example: |
|
366 |
-# @CODE |
|
367 |
-# PYTHON_COMPAT=( python{2_7,3_{3,4}} pypy ) |
|
368 |
-# RDEPEND="$(python_gen_cond_dep \ |
|
369 |
-# 'dev-python/unittest2[${PYTHON_USEDEP}]' python2_7 pypy )" |
|
370 |
-# @CODE |
|
371 |
-# |
|
372 |
-# It will cause the variable to look like: |
|
373 |
-# @CODE |
|
374 |
-# RDEPEND="python_single_target_python2_7? ( |
|
375 |
-# dev-python/unittest2[python_targets_python2_7(-)?,...] ) |
|
376 |
-# python_single_target_pypy? ( |
|
377 |
-# dev-python/unittest2[python_targets_pypy(-)?,...] )" |
|
378 |
-# @CODE |
|
379 |
-python_gen_cond_dep() { |
|
380 |
- debug-print-function ${FUNCNAME} "${@}" |
|
381 |
- |
|
382 |
- local impl matches=() |
|
383 |
- |
|
384 |
- local dep=${1} |
|
385 |
- shift |
|
386 |
- |
|
387 |
- _python_verify_patterns "${@}" |
|
388 |
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
389 |
- if _python_impl_matches "${impl}" "${@}"; then |
|
390 |
- # substitute ${PYTHON_SINGLE_USEDEP} if used |
|
391 |
- # (since python_gen_usedep() will not return |
|
392 |
- # ${PYTHON_SINGLE_USEDEP}, the code is run at most once) |
|
393 |
- if [[ ${dep} == *'${PYTHON_SINGLE_USEDEP}'* ]]; then |
|
394 |
- local usedep=$(_python_gen_usedep "${@}") |
|
395 |
- dep=${dep//\$\{PYTHON_SINGLE_USEDEP\}/${usedep}} |
|
396 |
- fi |
|
397 |
- local multi_usedep="python_targets_${impl}(-)" |
|
398 |
- |
|
399 |
- local subdep=${dep//\$\{PYTHON_MULTI_USEDEP\}/${multi_usedep}} |
|
400 |
- matches+=( "python_single_target_${impl}? ( |
|
401 |
- ${subdep//\$\{PYTHON_USEDEP\}/${multi_usedep}} )" ) |
|
402 |
- fi |
|
403 |
- done |
|
404 |
- |
|
405 |
- echo "${matches[@]}" |
|
406 |
-} |
|
407 |
- |
|
408 |
-# @FUNCTION: python_gen_impl_dep |
|
409 |
-# @USAGE: [<requested-use-flags> [<impl-pattern>...]] |
|
410 |
-# @DESCRIPTION: |
|
411 |
-# Output a dependency on Python implementations with the specified USE |
|
412 |
-# dependency string appended, or no USE dependency string if called |
|
413 |
-# without the argument (or with empty argument). If any implementation |
|
414 |
-# patterns are passed, the output dependencies will be generated only |
|
415 |
-# for the implementations matching them. |
|
416 |
-# |
|
417 |
-# The patterns can be either fnmatch-style patterns (matched via bash |
|
418 |
-# == operator against PYTHON_COMPAT values) or '-2' / '-3' to indicate |
|
419 |
-# appropriately all enabled Python 2/3 implementations (alike |
|
420 |
-# python_is_python3). Remember to escape or quote the fnmatch patterns |
|
421 |
-# to prevent accidental shell filename expansion. |
|
422 |
-# |
|
423 |
-# Use this function when you need to request different USE flags |
|
424 |
-# on the Python interpreter depending on package's USE flags. If you |
|
425 |
-# only need a single set of interpreter USE flags, just set |
|
426 |
-# PYTHON_REQ_USE and use ${PYTHON_DEPS} globally. |
|
427 |
-# |
|
428 |
-# Example: |
|
429 |
-# @CODE |
|
430 |
-# PYTHON_COMPAT=( python{2_7,3_{3,4}} pypy ) |
|
431 |
-# RDEPEND="foo? ( $(python_gen_impl_dep 'xml(+)') )" |
|
432 |
-# @CODE |
|
433 |
-# |
|
434 |
-# It will cause the variable to look like: |
|
435 |
-# @CODE |
|
436 |
-# RDEPEND="foo? ( |
|
437 |
-# python_single_target_python2_7? ( |
|
438 |
-# dev-lang/python:2.7[xml(+)] ) |
|
439 |
-# python_single_target_pypy? ( |
|
440 |
-# dev-python/pypy[xml(+)] ) )" |
|
441 |
-# @CODE |
|
442 |
-python_gen_impl_dep() { |
|
443 |
- debug-print-function ${FUNCNAME} "${@}" |
|
444 |
- |
|
445 |
- local impl |
|
446 |
- local matches=() |
|
447 |
- |
|
448 |
- local PYTHON_REQ_USE=${1} |
|
449 |
- shift |
|
450 |
- |
|
451 |
- _python_verify_patterns "${@}" |
|
452 |
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
453 |
- if _python_impl_matches "${impl}" "${@}"; then |
|
454 |
- local PYTHON_PKG_DEP |
|
455 |
- _python_export "${impl}" PYTHON_PKG_DEP |
|
456 |
- matches+=( "python_single_target_${impl}? ( ${PYTHON_PKG_DEP} )" ) |
|
457 |
- fi |
|
458 |
- done |
|
459 |
- |
|
460 |
- echo "${matches[@]}" |
|
461 |
-} |
|
462 |
- |
|
463 |
-# @FUNCTION: python_setup |
|
464 |
-# @DESCRIPTION: |
|
465 |
-# Determine what the selected Python implementation is and set |
|
466 |
-# the Python build environment up for it. |
|
467 |
-python_setup() { |
|
468 |
- debug-print-function ${FUNCNAME} "${@}" |
|
469 |
- |
|
470 |
- unset EPYTHON |
|
471 |
- |
|
472 |
- # support developer override |
|
473 |
- if [[ ${PYTHON_COMPAT_OVERRIDE} ]]; then |
|
474 |
- local impls=( ${PYTHON_COMPAT_OVERRIDE} ) |
|
475 |
- [[ ${#impls[@]} -eq 1 ]] || die "PYTHON_COMPAT_OVERRIDE must name exactly one implementation for python-single-r1" |
|
476 |
- |
|
477 |
- ewarn "WARNING: PYTHON_COMPAT_OVERRIDE in effect. The following Python" |
|
478 |
- ewarn "implementation will be used:" |
|
479 |
- ewarn |
|
480 |
- ewarn " ${PYTHON_COMPAT_OVERRIDE}" |
|
481 |
- ewarn |
|
482 |
- ewarn "Dependencies won't be satisfied, and PYTHON_SINGLE_TARGET flags will be ignored." |
|
483 |
- |
|
484 |
- _python_export "${impls[0]}" EPYTHON PYTHON |
|
485 |
- _python_wrapper_setup |
|
486 |
- einfo "Using ${EPYTHON} to build" |
|
487 |
- return |
|
488 |
- fi |
|
489 |
- |
|
490 |
- local impl |
|
491 |
- for impl in "${_PYTHON_SUPPORTED_IMPLS[@]}"; do |
|
492 |
- if use "python_single_target_${impl}"; then |
|
493 |
- if [[ ${EPYTHON} ]]; then |
|
494 |
- eerror "Your PYTHON_SINGLE_TARGET setting lists more than a single Python" |
|
495 |
- eerror "implementation. Please set it to just one value. If you need" |
|
496 |
- eerror "to override the value for a single package, please use package.env" |
|
497 |
- eerror "or an equivalent solution (man 5 portage)." |
|
498 |
- echo |
|
499 |
- die "More than one implementation in PYTHON_SINGLE_TARGET." |
|
500 |
- fi |
|
501 |
- |
|
502 |
- _python_export "${impl}" EPYTHON PYTHON |
|
503 |
- _python_wrapper_setup |
|
504 |
- einfo "Using ${EPYTHON} to build" |
|
505 |
- fi |
|
506 |
- done |
|
507 |
- |
|
508 |
- if [[ ! ${EPYTHON} ]]; then |
|
509 |
- eerror "No Python implementation selected for the build. Please set" |
|
510 |
- eerror "the PYTHON_SINGLE_TARGET variable in your make.conf to one" |
|
511 |
- eerror "of the following values:" |
|
512 |
- eerror |
|
513 |
- eerror "${_PYTHON_SUPPORTED_IMPLS[@]}" |
|
514 |
- echo |
|
515 |
- die "No supported Python implementation in PYTHON_SINGLE_TARGET." |
|
516 |
- fi |
|
517 |
-} |
|
518 |
- |
|
519 |
-# @FUNCTION: python-single-r1_pkg_setup |
|
520 |
-# @DESCRIPTION: |
|
521 |
-# Runs python_setup. |
|
522 |
-python-single-r1_pkg_setup() { |
|
523 |
- debug-print-function ${FUNCNAME} "${@}" |
|
524 |
- |
|
525 |
- [[ ${MERGE_TYPE} != binary ]] && python_setup |
|
526 |
-} |
|
527 |
- |
|
528 |
-_PYTHON_SINGLE_R1=1 |
|
529 |
-fi |
... | ... |
@@ -1,1445 +0,0 @@ |
1 |
-# Copyright 1999-2021 Gentoo Authors |
|
2 |
-# Distributed under the terms of the GNU General Public License v2 |
|
3 |
- |
|
4 |
-# @ECLASS: python-utils-r1.eclass |
|
5 |
-# @MAINTAINER: |
|
6 |
-# Python team <python@gentoo.org> |
|
7 |
-# @AUTHOR: |
|
8 |
-# Author: Michał Górny <mgorny@gentoo.org> |
|
9 |
-# Based on work of: Krzysztof Pawlik <nelchael@gentoo.org> |
|
10 |
-# @SUPPORTED_EAPIS: 5 6 7 |
|
11 |
-# @BLURB: Utility functions for packages with Python parts. |
|
12 |
-# @DESCRIPTION: |
|
13 |
-# A utility eclass providing functions to query Python implementations, |
|
14 |
-# install Python modules and scripts. |
|
15 |
-# |
|
16 |
-# This eclass does not set any metadata variables nor export any phase |
|
17 |
-# functions. It can be inherited safely. |
|
18 |
-# |
|
19 |
-# For more information, please see the Python Guide: |
|
20 |
-# https://dev.gentoo.org/~mgorny/python-guide/ |
|
21 |
- |
|
22 |
-case "${EAPI:-0}" in |
|
23 |
- [0-4]) die "Unsupported EAPI=${EAPI:-0} (too old) for ${ECLASS}" ;; |
|
24 |
- [5-7]) ;; |
|
25 |
- *) die "Unsupported EAPI=${EAPI} (unknown) for ${ECLASS}" ;; |
|
26 |
-esac |
|
27 |
- |
|
28 |
-if [[ ${_PYTHON_ECLASS_INHERITED} ]]; then |
|
29 |
- die 'python-r1 suite eclasses can not be used with python.eclass.' |
|
30 |
-fi |
|
31 |
- |
|
32 |
-if [[ ! ${_PYTHON_UTILS_R1} ]]; then |
|
33 |
- |
|
34 |
-[[ ${EAPI} == 5 ]] && inherit eutils multilib |
|
35 |
-inherit toolchain-funcs |
|
36 |
- |
|
37 |
-# @ECLASS-VARIABLE: _PYTHON_ALL_IMPLS |
|
38 |
-# @INTERNAL |
|
39 |
-# @DESCRIPTION: |
|
40 |
-# All supported Python implementations, most preferred last. |
|
41 |
-_PYTHON_ALL_IMPLS=( |
|
42 |
- pypy3 |
|
43 |
- python2_7 |
|
44 |
- python3_7 python3_8 python3_9 |
|
45 |
-) |
|
46 |
-readonly _PYTHON_ALL_IMPLS |
|
47 |
- |
|
48 |
-# @ECLASS-VARIABLE: _PYTHON_HISTORICAL_IMPLS |
|
49 |
-# @INTERNAL |
|
50 |
-# @DESCRIPTION: |
|
51 |
-# All historical Python implementations that are no longer supported. |
|
52 |
-_PYTHON_HISTORICAL_IMPLS=( |
|
53 |
- jython2_7 |
|
54 |
- pypy pypy1_{8,9} pypy2_0 |
|
55 |
- python2_{5,6} |
|
56 |
- python3_{1..6} |
|
57 |
-) |
|
58 |
-readonly _PYTHON_HISTORICAL_IMPLS |
|
59 |
- |
|
60 |
-# @ECLASS-VARIABLE: PYTHON_COMPAT_NO_STRICT |
|
61 |
-# @INTERNAL |
|
62 |
-# @DESCRIPTION: |
|
63 |
-# Set to a non-empty value in order to make eclass tolerate (ignore) |
|
64 |
-# unknown implementations in PYTHON_COMPAT. |
|
65 |
-# |
|
66 |
-# This is intended to be set by the user when using ebuilds that may |
|
67 |
-# have unknown (newer) implementations in PYTHON_COMPAT. The assumption |
|
68 |
-# is that the ebuilds are intended to be used within multiple contexts |
|
69 |
-# which can involve revisions of this eclass that support a different |
|
70 |
-# set of Python implementations. |
|
71 |
- |
|
72 |
-# @FUNCTION: _python_verify_patterns |
|
73 |
-# @USAGE: <pattern>... |
|
74 |
-# @INTERNAL |
|
75 |
-# @DESCRIPTION: |
|
76 |
-# Verify whether the patterns passed to the eclass function are correct |
|
77 |
-# (i.e. can match any valid implementation). Dies on wrong pattern. |
|
78 |
-_python_verify_patterns() { |
|
79 |
- debug-print-function ${FUNCNAME} "${@}" |
|
80 |
- |
|
81 |
- local impl pattern |
|
82 |
- for pattern; do |
|
83 |
- [[ ${pattern} == -[23] ]] && continue |
|
84 |
- |
|
85 |
- for impl in "${_PYTHON_ALL_IMPLS[@]}" "${_PYTHON_HISTORICAL_IMPLS[@]}" |
|
86 |
- do |
|
87 |
- [[ ${impl} == ${pattern/./_} ]] && continue 2 |
|
88 |
- done |
|
89 |
- |
|
90 |
- die "Invalid implementation pattern: ${pattern}" |
|
91 |
- done |
|
92 |
-} |
|
93 |
- |
|
94 |
-# @FUNCTION: _python_set_impls |
|
95 |
-# @INTERNAL |
|
96 |
-# @DESCRIPTION: |
|
97 |
-# Check PYTHON_COMPAT for well-formedness and validity, then set |
|
98 |
-# two global variables: |
|
99 |
-# |
|
100 |
-# - _PYTHON_SUPPORTED_IMPLS containing valid implementations supported |
|
101 |
-# by the ebuild (PYTHON_COMPAT - dead implementations), |
|
102 |
-# |
|
103 |
-# - and _PYTHON_UNSUPPORTED_IMPLS containing valid implementations that |
|
104 |
-# are not supported by the ebuild. |
|
105 |
-# |
|
106 |
-# Implementations in both variables are ordered using the pre-defined |
|
107 |
-# eclass implementation ordering. |
|
108 |
-# |
|
109 |
-# This function must be called once in global scope by an eclass |
|
110 |
-# utilizing PYTHON_COMPAT. |
|
111 |
-_python_set_impls() { |
|
112 |
- local i |
|
113 |
- |
|
114 |
- if ! declare -p PYTHON_COMPAT &>/dev/null; then |
|
115 |
- die 'PYTHON_COMPAT not declared.' |
|
116 |
- fi |
|
117 |
- if [[ $(declare -p PYTHON_COMPAT) != "declare -a"* ]]; then |
|
118 |
- die 'PYTHON_COMPAT must be an array.' |
|
119 |
- fi |
|
120 |
- if [[ ! ${PYTHON_COMPAT_NO_STRICT} ]]; then |
|
121 |
- for i in "${PYTHON_COMPAT[@]}"; do |
|
122 |
- # check for incorrect implementations |
|
123 |
- # we're using pattern matching as an optimization |
|
124 |
- # please keep them in sync with _PYTHON_ALL_IMPLS |
|
125 |
- # and _PYTHON_HISTORICAL_IMPLS |
|
126 |
- case ${i} in |
|
127 |
- jython2_7|pypy|pypy1_[89]|pypy2_0|pypy3|python2_[5-7]|python3_[1-9]) |
|
128 |
- ;; |
|
129 |
- *) |
|
130 |
- if has "${i}" "${_PYTHON_ALL_IMPLS[@]}" \ |
|
131 |
- "${_PYTHON_HISTORICAL_IMPLS[@]}" |
|
132 |
- then |
|
133 |
- die "Mis-synced patterns in _python_set_impls: missing ${i}" |
|
134 |
- else |
|
135 |
- die "Invalid implementation in PYTHON_COMPAT: ${i}" |
|
136 |
- fi |
|
137 |
- esac |
|
138 |
- done |
|
139 |
- fi |
|
140 |
- |
|
141 |
- local supp=() unsupp=() |
|
142 |
- |
|
143 |
- for i in "${_PYTHON_ALL_IMPLS[@]}"; do |
|
144 |
- if has "${i}" "${PYTHON_COMPAT[@]}"; then |
|
145 |
- supp+=( "${i}" ) |
|
146 |
- else |
|
147 |
- unsupp+=( "${i}" ) |
|
148 |
- fi |
|
149 |
- done |
|
150 |
- |
|
151 |
- if [[ ! ${supp[@]} ]]; then |
|
152 |
- die "No supported implementation in PYTHON_COMPAT." |
|
153 |
- fi |
|
154 |
- |
|
155 |
- if [[ ${_PYTHON_SUPPORTED_IMPLS[@]} ]]; then |
|
156 |
- # set once already, verify integrity |
|
157 |
- if [[ ${_PYTHON_SUPPORTED_IMPLS[@]} != ${supp[@]} ]]; then |
|
158 |
- eerror "Supported impls (PYTHON_COMPAT) changed between inherits!" |
|
159 |
- eerror "Before: ${_PYTHON_SUPPORTED_IMPLS[*]}" |
|
160 |
- eerror "Now : ${supp[*]}" |
|
161 |
- die "_PYTHON_SUPPORTED_IMPLS integrity check failed" |
|
162 |
- fi |
|
163 |
- if [[ ${_PYTHON_UNSUPPORTED_IMPLS[@]} != ${unsupp[@]} ]]; then |
|
164 |
- eerror "Unsupported impls changed between inherits!" |
|
165 |
- eerror "Before: ${_PYTHON_UNSUPPORTED_IMPLS[*]}" |
|
166 |
- eerror "Now : ${unsupp[*]}" |
|
167 |
- die "_PYTHON_UNSUPPORTED_IMPLS integrity check failed" |
|
168 |
- fi |
|
169 |
- else |
|
170 |
- _PYTHON_SUPPORTED_IMPLS=( "${supp[@]}" ) |
|
171 |
- _PYTHON_UNSUPPORTED_IMPLS=( "${unsupp[@]}" ) |
|
172 |
- readonly _PYTHON_SUPPORTED_IMPLS _PYTHON_UNSUPPORTED_IMPLS |
|
173 |
- fi |
|
174 |
-} |
|
175 |
- |
|
176 |
-# @FUNCTION: _python_impl_matches |
|
177 |
-# @USAGE: <impl> [<pattern>...] |
|
178 |
-# @INTERNAL |
|
179 |
-# @DESCRIPTION: |
|
180 |
-# Check whether the specified <impl> matches at least one |
|
181 |
-# of the patterns following it. Return 0 if it does, 1 otherwise. |
|
182 |
-# Matches if no patterns are provided. |
|
183 |
-# |
|
184 |
-# <impl> can be in PYTHON_COMPAT or EPYTHON form. The patterns can be |
|
185 |
-# either: |
|
186 |
-# a) fnmatch-style patterns, e.g. 'python2*', 'pypy'... |
|
187 |
-# b) '-2' to indicate all Python 2 variants (= !python_is_python3) |
|
188 |
-# c) '-3' to indicate all Python 3 variants (= python_is_python3) |
|
189 |
-_python_impl_matches() { |
|
190 |
- [[ ${#} -ge 1 ]] || die "${FUNCNAME}: takes at least 1 parameter" |
|
191 |
- [[ ${#} -eq 1 ]] && return 0 |
|
192 |
- |
|
193 |
- local impl=${1} pattern |
|
194 |
- shift |
|
195 |
- |
|
196 |
- for pattern; do |
|
197 |
- if [[ ${pattern} == -2 ]]; then |
|
198 |
- python_is_python3 "${impl}" || return 0 |
|
199 |
- elif [[ ${pattern} == -3 ]]; then |
|
200 |
- python_is_python3 "${impl}" && return 0 |
|
201 |
- return |
|
202 |
- # unify value style to allow lax matching |
|
203 |
- elif [[ ${impl/./_} == ${pattern/./_} ]]; then |
|
204 |
- return 0 |
|
205 |
- fi |
|
206 |
- done |
|
207 |
- |
|
208 |
- return 1 |
|
209 |
-} |
|
210 |
- |
|
211 |
-# @ECLASS-VARIABLE: PYTHON |
|
212 |
-# @DEFAULT_UNSET |
|
213 |
-# @DESCRIPTION: |
|
214 |
-# The absolute path to the current Python interpreter. |
|
215 |
-# |
|
216 |
-# This variable is set automatically in the following contexts: |
|
217 |
-# |
|
218 |
-# python-r1: Set in functions called by python_foreach_impl() or after |
|
219 |
-# calling python_setup(). |
|
220 |
-# |
|
221 |
-# python-single-r1: Set after calling python-single-r1_pkg_setup(). |
|
222 |
-# |
|
223 |
-# distutils-r1: Set within any of the python sub-phase functions. |
|
224 |
-# |
|
225 |
-# Example value: |
|
226 |
-# @CODE |
|
227 |
-# /usr/bin/python2.7 |
|
228 |
-# @CODE |
|
229 |
- |
|
230 |
-# @ECLASS-VARIABLE: EPYTHON |
|
231 |
-# @DEFAULT_UNSET |
|
232 |
-# @DESCRIPTION: |
|
233 |
-# The executable name of the current Python interpreter. |
|
234 |
-# |
|
235 |
-# This variable is set automatically in the following contexts: |
|
236 |
-# |
|
237 |
-# python-r1: Set in functions called by python_foreach_impl() or after |
|
238 |
-# calling python_setup(). |
|
239 |
-# |
|
240 |
-# python-single-r1: Set after calling python-single-r1_pkg_setup(). |
|
241 |
-# |
|
242 |
-# distutils-r1: Set within any of the python sub-phase functions. |
|
243 |
-# |
|
244 |
-# Example value: |
|
245 |
-# @CODE |
|
246 |
-# python2.7 |
|
247 |
-# @CODE |
|
248 |
- |
|
249 |
-# @FUNCTION: python_export |
|
250 |
-# @USAGE: [<impl>] <variables>... |
|
251 |
-# @INTERNAL |
|
252 |
-# @DESCRIPTION: |
|
253 |
-# Backwards compatibility function. The relevant API is now considered |
|
254 |
-# private, please use python_get* instead. |
|
255 |
-python_export() { |
|
256 |
- debug-print-function ${FUNCNAME} "${@}" |
|
257 |
- |
|
258 |
- eqawarn "python_export() is part of private eclass API." |
|
259 |
- eqawarn "Please call python_get*() instead." |
|
260 |
- |
|
261 |
- _python_export "${@}" |
|
262 |
-} |
|
263 |
- |
|
264 |
-# @FUNCTION: _python_export |
|
265 |
-# @USAGE: [<impl>] <variables>... |
|
266 |
-# @INTERNAL |
|
267 |
-# @DESCRIPTION: |
|
268 |
-# Set and export the Python implementation-relevant variables passed |
|
269 |
-# as parameters. |
|
270 |
-# |
|
271 |
-# The optional first parameter may specify the requested Python |
|
272 |
-# implementation (either as PYTHON_TARGETS value, e.g. python2_7, |
|
273 |
-# or an EPYTHON one, e.g. python2.7). If no implementation passed, |
|
274 |
-# the current one will be obtained from ${EPYTHON}. |
|
275 |
-# |
|
276 |
-# The variables which can be exported are: PYTHON, EPYTHON, |
|
277 |
-# PYTHON_SITEDIR. They are described more completely in the eclass |
|
278 |
-# variable documentation. |
|
279 |
-_python_export() { |
|
280 |
- debug-print-function ${FUNCNAME} "${@}" |
|
281 |
- |
|
282 |
- local impl var |
|
283 |
- |
|
284 |
- case "${1}" in |
|
285 |
- python*|jython*) |
|
286 |
- impl=${1/_/.} |
|
287 |
- shift |
|
288 |
- ;; |
|
289 |
- pypy|pypy3) |
|
290 |
- impl=${1} |
|
291 |
- shift |
|
292 |
- ;; |
|
293 |
- *) |
|
294 |
- impl=${EPYTHON} |
|
295 |
- if [[ -z ${impl} ]]; then |
|
296 |
- die "_python_export called without a python implementation and EPYTHON is unset" |
|
297 |
- fi |
|
298 |
- ;; |
|
299 |
- esac |
|
300 |
- debug-print "${FUNCNAME}: implementation: ${impl}" |
|
301 |
- |
|
302 |
- for var; do |
|
303 |
- case "${var}" in |
|
304 |
- EPYTHON) |
|
305 |
- export EPYTHON=${impl} |
|
306 |
- debug-print "${FUNCNAME}: EPYTHON = ${EPYTHON}" |
|
307 |
- ;; |
|
308 |
- PYTHON) |
|
309 |
- export PYTHON=${EPREFIX}/usr/bin/${impl} |
|
310 |
- debug-print "${FUNCNAME}: PYTHON = ${PYTHON}" |
|
311 |
- ;; |
|
312 |
- PYTHON_SITEDIR) |
|
313 |
- [[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it" |
|
314 |
- # sysconfig can't be used because: |
|
315 |
- # 1) pypy doesn't give site-packages but stdlib |
|
316 |
- # 2) jython gives paths with wrong case |
|
317 |
- PYTHON_SITEDIR=$("${PYTHON}" -c 'import distutils.sysconfig; print(distutils.sysconfig.get_python_lib())') || die |
|
318 |
- export PYTHON_SITEDIR |
|
319 |
- debug-print "${FUNCNAME}: PYTHON_SITEDIR = ${PYTHON_SITEDIR}" |
|
320 |
- ;; |
|
321 |
- PYTHON_INCLUDEDIR) |
|
322 |
- [[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it" |
|
323 |
- PYTHON_INCLUDEDIR=$("${PYTHON}" -c 'import distutils.sysconfig; print(distutils.sysconfig.get_python_inc())') || die |
|
324 |
- export PYTHON_INCLUDEDIR |
|
325 |
- debug-print "${FUNCNAME}: PYTHON_INCLUDEDIR = ${PYTHON_INCLUDEDIR}" |
|
326 |
- |
|
327 |
- # Jython gives a non-existing directory |
|
328 |
- if [[ ! -d ${PYTHON_INCLUDEDIR} ]]; then |
|
329 |
- die "${impl} does not install any header files!" |
|
330 |
- fi |
|
331 |
- ;; |
|
332 |
- PYTHON_LIBPATH) |
|
333 |
- [[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it" |
|
334 |
- PYTHON_LIBPATH=$("${PYTHON}" -c 'import os.path, sysconfig; print(os.path.join(sysconfig.get_config_var("LIBDIR"), sysconfig.get_config_var("LDLIBRARY")) if sysconfig.get_config_var("LDLIBRARY") else "")') || die |
|
335 |
- export PYTHON_LIBPATH |
|
336 |
- debug-print "${FUNCNAME}: PYTHON_LIBPATH = ${PYTHON_LIBPATH}" |
|
337 |
- |
|
338 |
- if [[ ! ${PYTHON_LIBPATH} ]]; then |
|
339 |
- die "${impl} lacks a (usable) dynamic library" |
|
340 |
- fi |
|
341 |
- ;; |
|
342 |
- PYTHON_CFLAGS) |
|
343 |
- local val |
|
344 |
- |
|
345 |
- case "${impl}" in |
|
346 |
- python*) |
|
347 |
- # python-2.7, python-3.2, etc. |
|
348 |
- val=$($(tc-getPKG_CONFIG) --cflags ${impl/n/n-}) || die |
|
349 |
- ;; |
|
350 |
- *) |
|
351 |
- die "${impl}: obtaining ${var} not supported" |
|
352 |
- ;; |
|
353 |
- esac |
|
354 |
- |
|
355 |
- export PYTHON_CFLAGS=${val} |
|
356 |
- debug-print "${FUNCNAME}: PYTHON_CFLAGS = ${PYTHON_CFLAGS}" |
|
357 |
- ;; |
|
358 |
- PYTHON_LIBS) |
|
359 |
- local val |
|
360 |
- |
|
361 |
- case "${impl}" in |
|
362 |
- python2*|python3.6|python3.7*) |
|
363 |
- # python* up to 3.7 |
|
364 |
- val=$($(tc-getPKG_CONFIG) --libs ${impl/n/n-}) || die |
|
365 |
- ;; |
|
366 |
- python*) |
|
367 |
- # python3.8+ |
|
368 |
- val=$($(tc-getPKG_CONFIG) --libs ${impl/n/n-}-embed) || die |
|
369 |
- ;; |
|
370 |
- *) |
|
371 |
- die "${impl}: obtaining ${var} not supported" |
|
372 |
- ;; |
|
373 |
- esac |
|
374 |
- |
|
375 |
- export PYTHON_LIBS=${val} |
|
376 |
- debug-print "${FUNCNAME}: PYTHON_LIBS = ${PYTHON_LIBS}" |
|
377 |
- ;; |
|
378 |
- PYTHON_CONFIG) |
|
379 |
- local flags val |
|
380 |
- |
|
381 |
- case "${impl}" in |
|
382 |
- python*) |
|
383 |
- [[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it" |
|
384 |
- flags=$("${PYTHON}" -c 'import sysconfig; print(sysconfig.get_config_var("ABIFLAGS") or "")') || die |
|
385 |
- val=${PYTHON}${flags}-config |
|
386 |
- ;; |
|
387 |
- *) |
|
388 |
- die "${impl}: obtaining ${var} not supported" |
|
389 |
- ;; |
|
390 |
- esac |
|
391 |
- |
|
392 |
- export PYTHON_CONFIG=${val} |
|
393 |
- debug-print "${FUNCNAME}: PYTHON_CONFIG = ${PYTHON_CONFIG}" |
|
394 |
- ;; |
|
395 |
- PYTHON_PKG_DEP) |
|
396 |
- local d |
|
397 |
- case ${impl} in |
|
398 |
- python2.7) |
|
399 |
- PYTHON_PKG_DEP='>=dev-lang/python-2.7.5-r2:2.7';; |
|
400 |
- python*) |
|
401 |
- PYTHON_PKG_DEP="dev-lang/python:${impl#python}";; |
|
402 |
- pypy) |
|
403 |
- PYTHON_PKG_DEP='>=dev-python/pypy-7.3.0:0=';; |
|
404 |
- pypy3) |
|
405 |
- PYTHON_PKG_DEP='>=dev-python/pypy3-7.3.0:0=';; |
|
406 |
- *) |
|
407 |
- die "Invalid implementation: ${impl}" |
|
408 |
- esac |
|
409 |
- |
|
410 |
- # use-dep |
|
411 |
- if [[ ${PYTHON_REQ_USE} ]]; then |
|
412 |
- PYTHON_PKG_DEP+=[${PYTHON_REQ_USE}] |
|
413 |
- fi |
|
414 |
- |
|
415 |
- export PYTHON_PKG_DEP |
|
416 |
- debug-print "${FUNCNAME}: PYTHON_PKG_DEP = ${PYTHON_PKG_DEP}" |
|
417 |
- ;; |
|
418 |
- PYTHON_SCRIPTDIR) |
|
419 |
- local dir |
|
420 |
- export PYTHON_SCRIPTDIR=${EPREFIX}/usr/lib/python-exec/${impl} |
|
421 |
- debug-print "${FUNCNAME}: PYTHON_SCRIPTDIR = ${PYTHON_SCRIPTDIR}" |
|
422 |
- ;; |
|
423 |
- *) |
|
424 |
- die "_python_export: unknown variable ${var}" |
|
425 |
- esac |
|
426 |
- done |
|
427 |
-} |
|
428 |
- |
|
429 |
-# @FUNCTION: python_get_sitedir |
|
430 |
-# @USAGE: [<impl>] |
|
431 |
-# @DESCRIPTION: |
|
432 |
-# Obtain and print the 'site-packages' path for the given |
|
433 |
-# implementation. If no implementation is provided, ${EPYTHON} will |
|
434 |
-# be used. |
|
435 |
-python_get_sitedir() { |
|
436 |
- debug-print-function ${FUNCNAME} "${@}" |
|
437 |
- |
|
438 |
- _python_export "${@}" PYTHON_SITEDIR |
|
439 |
- echo "${PYTHON_SITEDIR}" |
|
440 |
-} |
|
441 |
- |
|
442 |
-# @FUNCTION: python_get_includedir |
|
443 |
-# @USAGE: [<impl>] |
|
444 |
-# @DESCRIPTION: |
|
445 |
-# Obtain and print the include path for the given implementation. If no |
|
446 |
-# implementation is provided, ${EPYTHON} will be used. |
|
447 |
-python_get_includedir() { |
|
448 |
- debug-print-function ${FUNCNAME} "${@}" |
|
449 |
- |
|
450 |
- _python_export "${@}" PYTHON_INCLUDEDIR |
|
451 |
- echo "${PYTHON_INCLUDEDIR}" |
|
452 |
-} |
|
453 |
- |
|
454 |
-# @FUNCTION: python_get_library_path |
|
455 |
-# @USAGE: [<impl>] |
|
456 |
-# @DESCRIPTION: |
|
457 |
-# Obtain and print the Python library path for the given implementation. |
|
458 |
-# If no implementation is provided, ${EPYTHON} will be used. |
|
459 |
-# |
|
460 |
-# Please note that this function can be used with CPython only. Use |
|
461 |
-# in another implementation will result in a fatal failure. |
|
462 |
-python_get_library_path() { |
|
463 |
- debug-print-function ${FUNCNAME} "${@}" |
|
464 |
- |
|
465 |
- _python_export "${@}" PYTHON_LIBPATH |
|
466 |
- echo "${PYTHON_LIBPATH}" |
|
467 |
-} |
|
468 |
- |
|
469 |
-# @FUNCTION: python_get_CFLAGS |
|
470 |
-# @USAGE: [<impl>] |
|
471 |
-# @DESCRIPTION: |
|
472 |
-# Obtain and print the compiler flags for building against Python, |
|
473 |
-# for the given implementation. If no implementation is provided, |
|
474 |
-# ${EPYTHON} will be used. |
|
475 |
-# |
|
476 |
-# Please note that this function can be used with CPython only. |
|
477 |
-# It requires Python and pkg-config installed, and therefore proper |
|
478 |
-# build-time dependencies need be added to the ebuild. |
|
479 |
-python_get_CFLAGS() { |
|
480 |
- debug-print-function ${FUNCNAME} "${@}" |
|
481 |
- |
|
482 |
- _python_export "${@}" PYTHON_CFLAGS |
|
483 |
- echo "${PYTHON_CFLAGS}" |
|
484 |
-} |
|
485 |
- |
|
486 |
-# @FUNCTION: python_get_LIBS |
|
487 |
-# @USAGE: [<impl>] |
|
488 |
-# @DESCRIPTION: |
|
489 |
-# Obtain and print the compiler flags for linking against Python, |
|
490 |
-# for the given implementation. If no implementation is provided, |
|
491 |
-# ${EPYTHON} will be used. |
|
492 |
-# |
|
493 |
-# Please note that this function can be used with CPython only. |
|
494 |
-# It requires Python and pkg-config installed, and therefore proper |
|
495 |
-# build-time dependencies need be added to the ebuild. |
|
496 |
-python_get_LIBS() { |
|
497 |
- debug-print-function ${FUNCNAME} "${@}" |
|
498 |
- |
|
499 |
- _python_export "${@}" PYTHON_LIBS |
|
500 |
- echo "${PYTHON_LIBS}" |
|
501 |
-} |
|
502 |
- |
|
503 |
-# @FUNCTION: python_get_PYTHON_CONFIG |
|
504 |
-# @USAGE: [<impl>] |
|
505 |
-# @DESCRIPTION: |
|
506 |
-# Obtain and print the PYTHON_CONFIG location for the given |
|
507 |
-# implementation. If no implementation is provided, ${EPYTHON} will be |
|
508 |
-# used. |
|
509 |
-# |
|
510 |
-# Please note that this function can be used with CPython only. |
|
511 |
-# It requires Python installed, and therefore proper build-time |
|
512 |
-# dependencies need be added to the ebuild. |
|
513 |
-python_get_PYTHON_CONFIG() { |
|
514 |
- debug-print-function ${FUNCNAME} "${@}" |
|
515 |
- |
|
516 |
- _python_export "${@}" PYTHON_CONFIG |
|
517 |
- echo "${PYTHON_CONFIG}" |
|
518 |
-} |
|
519 |
- |
|
520 |
-# @FUNCTION: python_get_scriptdir |
|
521 |
-# @USAGE: [<impl>] |
|
522 |
-# @DESCRIPTION: |
|
523 |
-# Obtain and print the script install path for the given |
|
524 |
-# implementation. If no implementation is provided, ${EPYTHON} will |
|
525 |
-# be used. |
|
526 |
-python_get_scriptdir() { |
|
527 |
- debug-print-function ${FUNCNAME} "${@}" |
|
528 |
- |
|
529 |
- _python_export "${@}" PYTHON_SCRIPTDIR |
|
530 |
- echo "${PYTHON_SCRIPTDIR}" |
|
531 |
-} |
|
532 |
- |
|
533 |
-# @FUNCTION: _python_ln_rel |
|
534 |
-# @USAGE: <from> <to> |
|
535 |
-# @INTERNAL |
|
536 |
-# @DESCRIPTION: |
|
537 |
-# Create a relative symlink. |
|
538 |
-_python_ln_rel() { |
|
539 |
- debug-print-function ${FUNCNAME} "${@}" |
|
540 |
- |
|
541 |
- local target=${1} |
|
542 |
- local symname=${2} |
|
543 |
- |
|
544 |
- local tgpath=${target%/*}/ |
|
545 |
- local sympath=${symname%/*}/ |
|
546 |
- local rel_target= |
|
547 |
- |
|
548 |
- while [[ ${sympath} ]]; do |
|
549 |
- local tgseg= symseg= |
|
550 |
- |
|
551 |
- while [[ ! ${tgseg} && ${tgpath} ]]; do |
|
552 |
- tgseg=${tgpath%%/*} |
|
553 |
- tgpath=${tgpath#${tgseg}/} |
|
554 |
- done |
|
555 |
- |
|
556 |
- while [[ ! ${symseg} && ${sympath} ]]; do |
|
557 |
- symseg=${sympath%%/*} |
|
558 |
- sympath=${sympath#${symseg}/} |
|
559 |
- done |
|
560 |
- |
|
561 |
- if [[ ${tgseg} != ${symseg} ]]; then |
|
562 |
- rel_target=../${rel_target}${tgseg:+${tgseg}/} |
|
563 |
- fi |
|
564 |
- done |
|
565 |
- rel_target+=${tgpath}${target##*/} |
|
566 |
- |
|
567 |
- debug-print "${FUNCNAME}: ${symname} -> ${target}" |
|
568 |
- debug-print "${FUNCNAME}: rel_target = ${rel_target}" |
|
569 |
- |
|
570 |
- ln -fs "${rel_target}" "${symname}" |
|
571 |
-} |
|
572 |
- |
|
573 |
-# @FUNCTION: python_optimize |
|
574 |
-# @USAGE: [<directory>...] |
|
575 |
-# @DESCRIPTION: |
|
576 |
-# Compile and optimize Python modules in specified directories (absolute |
|
577 |
-# paths). If no directories are provided, the default system paths |
|
578 |
-# are used (prepended with ${D}). |
|
579 |
-python_optimize() { |
|
580 |
- debug-print-function ${FUNCNAME} "${@}" |
|
581 |
- |
|
582 |
- if [[ ${EBUILD_PHASE} == pre* || ${EBUILD_PHASE} == post* ]]; then |
|
583 |
- eerror "The new Python eclasses expect the compiled Python files to" |
|
584 |
- eerror "be controlled by the Package Manager. For this reason," |
|
585 |
- eerror "the python_optimize function can be used only during src_* phases" |
|
586 |
- eerror "(src_install most commonly) and not during pkg_* phases." |
|
587 |
- echo |
|
588 |
- die "python_optimize is not to be used in pre/post* phases" |
|
589 |
- fi |
|
590 |
- |
|
591 |
- [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' |
|
592 |
- |
|
593 |
- local PYTHON=${PYTHON} |
|
594 |
- [[ ${PYTHON} ]] || _python_export PYTHON |
|
595 |
- [[ -x ${PYTHON} ]] || die "PYTHON (${PYTHON}) is not executable" |
|
596 |
- |
|
597 |
- # default to sys.path |
|
598 |
- if [[ ${#} -eq 0 ]]; then |
|
599 |
- local f |
|
600 |
- while IFS= read -r -d '' f; do |
|
601 |
- # 1) accept only absolute paths |
|
602 |
- # (i.e. skip '', '.' or anything like that) |
|
603 |
- # 2) skip paths which do not exist |
|
604 |
- # (python2.6 complains about them verbosely) |
|
605 |
- |
|
606 |
- if [[ ${f} == /* && -d ${D%/}${f} ]]; then |
|
607 |
- set -- "${D%/}${f}" "${@}" |
|
608 |
- fi |
|
609 |
- done < <("${PYTHON}" -c 'import sys; print("".join(x + "\0" for x in sys.path))' || die) |
|
610 |
- |
|
611 |
- debug-print "${FUNCNAME}: using sys.path: ${*/%/;}" |
|
612 |
- fi |
|
613 |
- |
|
614 |
- local d |
|
615 |
- for d; do |
|
616 |
- # make sure to get a nice path without // |
|
617 |
- local instpath=${d#${D%/}} |
|
618 |
- instpath=/${instpath##/} |
|
619 |
- |
|
620 |
- case "${EPYTHON}" in |
|
621 |
- python2.7|python3.[34]) |
|
622 |
- "${PYTHON}" -m compileall -q -f -d "${instpath}" "${d}" |
|
623 |
- "${PYTHON}" -OO -m compileall -q -f -d "${instpath}" "${d}" |
|
624 |
- ;; |
|
625 |
- python*|pypy3) |
|
626 |
- # both levels of optimization are separate since 3.5 |
|
627 |
- "${PYTHON}" -m compileall -q -f -d "${instpath}" "${d}" |
|
628 |
- "${PYTHON}" -O -m compileall -q -f -d "${instpath}" "${d}" |
|
629 |
- "${PYTHON}" -OO -m compileall -q -f -d "${instpath}" "${d}" |
|
630 |
- ;; |
|
631 |
- *) |
|
632 |
- "${PYTHON}" -m compileall -q -f -d "${instpath}" "${d}" |
|
633 |
- ;; |
|
634 |
- esac |
|
635 |
- done |
|
636 |
-} |
|
637 |
- |
|
638 |
-# @FUNCTION: python_scriptinto |
|
639 |
-# @USAGE: <new-path> |
|
640 |
-# @DESCRIPTION: |
|
641 |
-# Set the directory to which files passed to python_doexe(), |
|
642 |
-# python_doscript(), python_newexe() and python_newscript() |
|
643 |
-# are going to be installed. The new value needs to be relative |
|
644 |
-# to the installation root (${ED}). |
|
645 |
-# |
|
646 |
-# If not set explicitly, the directory defaults to /usr/bin. |
|
647 |
-# |
|
648 |
-# Example: |
|
649 |
-# @CODE |
|
650 |
-# src_install() { |
|
651 |
-# python_scriptinto /usr/sbin |
|
652 |
-# python_foreach_impl python_doscript foo |
|
653 |
-# } |
|
654 |
-# @CODE |
|
655 |
-python_scriptinto() { |
|
656 |
- debug-print-function ${FUNCNAME} "${@}" |
|
657 |
- |
|
658 |
- python_scriptroot=${1} |
|
659 |
-} |
|
660 |
- |
|
661 |
-# @FUNCTION: python_doexe |
|
662 |
-# @USAGE: <files>... |
|
663 |
-# @DESCRIPTION: |
|
664 |
-# Install the given executables into the executable install directory, |
|
665 |
-# for the current Python implementation (${EPYTHON}). |
|
666 |
-# |
|
667 |
-# The executable will be wrapped properly for the Python implementation, |
|
668 |
-# though no shebang mangling will be performed. |
|
669 |
-python_doexe() { |
|
670 |
- debug-print-function ${FUNCNAME} "${@}" |
|
671 |
- |
|
672 |
- local f |
|
673 |
- for f; do |
|
674 |
- python_newexe "${f}" "${f##*/}" |
|
675 |
- done |
|
676 |
-} |
|
677 |
- |
|
678 |
-# @FUNCTION: python_newexe |
|
679 |
-# @USAGE: <path> <new-name> |
|
680 |
-# @DESCRIPTION: |
|
681 |
-# Install the given executable into the executable install directory, |
|
682 |
-# for the current Python implementation (${EPYTHON}). |
|
683 |
-# |
|
684 |
-# The executable will be wrapped properly for the Python implementation, |
|
685 |
-# though no shebang mangling will be performed. It will be renamed |
|
686 |
-# to <new-name>. |
|
687 |
-python_newexe() { |
|
688 |
- debug-print-function ${FUNCNAME} "${@}" |
|
689 |
- |
|
690 |
- [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' |
|
691 |
- [[ ${#} -eq 2 ]] || die "Usage: ${FUNCNAME} <path> <new-name>" |
|
692 |
- |
|
693 |
- local wrapd=${python_scriptroot:-/usr/bin} |
|
694 |
- |
|
695 |
- local f=${1} |
|
696 |
- local newfn=${2} |
|
697 |
- |
|
698 |
- local scriptdir=$(python_get_scriptdir) |
|
699 |
- local d=${scriptdir#${EPREFIX}} |
|
700 |
- |
|
701 |
- ( |
|
702 |
- dodir "${wrapd}" |
|
703 |
- exeopts -m 0755 |
|
704 |
- exeinto "${d}" |
|
705 |
- newexe "${f}" "${newfn}" || return ${?} |
|
706 |
- ) |
|
707 |
- |
|
708 |
- # install the wrapper |
|
709 |
- _python_ln_rel "${ED%/}"/usr/lib/python-exec/python-exec2 \ |
|
710 |
- "${ED%/}/${wrapd}/${newfn}" || die |
|
711 |
- |
|
712 |
- # don't use this at home, just call python_doscript() instead |
|
713 |
- if [[ ${_PYTHON_REWRITE_SHEBANG} ]]; then |
|
714 |
- python_fix_shebang -q "${ED%/}/${d}/${newfn}" |
|
715 |
- fi |
|
716 |
-} |
|
717 |
- |
|
718 |
-# @FUNCTION: python_doscript |
|
719 |
-# @USAGE: <files>... |
|
720 |
-# @DESCRIPTION: |
|
721 |
-# Install the given scripts into the executable install directory, |
|
722 |
-# for the current Python implementation (${EPYTHON}). |
|
723 |
-# |
|
724 |
-# All specified files must start with a 'python' shebang. The shebang |
|
725 |
-# will be converted, and the files will be wrapped properly |
|
726 |
-# for the Python implementation. |
|
727 |
-# |
|
728 |
-# Example: |
|
729 |
-# @CODE |
|
730 |
-# src_install() { |
|
731 |
-# python_foreach_impl python_doscript ${PN} |
|
732 |
-# } |
|
733 |
-# @CODE |
|
734 |
-python_doscript() { |
|
735 |
- debug-print-function ${FUNCNAME} "${@}" |
|
736 |
- |
|
737 |
- local _PYTHON_REWRITE_SHEBANG=1 |
|
738 |
- python_doexe "${@}" |
|
739 |
-} |
|
740 |
- |
|
741 |
-# @FUNCTION: python_newscript |
|
742 |
-# @USAGE: <path> <new-name> |
|
743 |
-# @DESCRIPTION: |
|
744 |
-# Install the given script into the executable install directory |
|
745 |
-# for the current Python implementation (${EPYTHON}), and name it |
|
746 |
-# <new-name>. |
|
747 |
-# |
|
748 |
-# The file must start with a 'python' shebang. The shebang will be |
|
749 |
-# converted, and the file will be wrapped properly for the Python |
|
750 |
-# implementation. It will be renamed to <new-name>. |
|
751 |
-# |
|
752 |
-# Example: |
|
753 |
-# @CODE |
|
754 |
-# src_install() { |
|
755 |
-# python_foreach_impl python_newscript foo.py foo |
|
756 |
-# } |
|
757 |
-# @CODE |
|
758 |
-python_newscript() { |
|
759 |
- debug-print-function ${FUNCNAME} "${@}" |
|
760 |
- |
|
761 |
- local _PYTHON_REWRITE_SHEBANG=1 |
|
762 |
- python_newexe "${@}" |
|
763 |
-} |
|
764 |
- |
|
765 |
-# @FUNCTION: python_moduleinto |
|
766 |
-# @USAGE: <new-path> |
|
767 |
-# @DESCRIPTION: |
|
768 |
-# Set the Python module install directory for python_domodule(). |
|
769 |
-# The <new-path> can either be an absolute target system path (in which |
|
770 |
-# case it needs to start with a slash, and ${ED} will be prepended to |
|
771 |
-# it) or relative to the implementation's site-packages directory |
|
772 |
-# (then it must not start with a slash). The relative path can be |
|
773 |
-# specified either using the Python package notation (separated by dots) |
|
774 |
-# or the directory notation (using slashes). |
|
775 |
-# |
|
776 |
-# When not set explicitly, the modules are installed to the top |
|
777 |
-# site-packages directory. |
|
778 |
-# |
|
779 |
-# In the relative case, the exact path is determined directly |
|
780 |
-# by each python_doscript/python_newscript function. Therefore, |
|
781 |
-# python_moduleinto can be safely called before establishing the Python |
|
782 |
-# interpreter and/or a single call can be used to set the path correctly |
|
783 |
-# for multiple implementations, as can be seen in the following example. |
|
784 |
-# |
|
785 |
-# Example: |
|
786 |
-# @CODE |
|
787 |
-# src_install() { |
|
788 |
-# python_moduleinto bar |
|
789 |
-# # installs ${PYTHON_SITEDIR}/bar/baz.py |
|
790 |
-# python_foreach_impl python_domodule baz.py |
|
791 |
-# } |
|
792 |
-# @CODE |
|
793 |
-python_moduleinto() { |
|
794 |
- debug-print-function ${FUNCNAME} "${@}" |
|
795 |
- |
|
796 |
- python_moduleroot=${1} |
|
797 |
-} |
|
798 |
- |
|
799 |
-# @FUNCTION: python_domodule |
|
800 |
-# @USAGE: <files>... |
|
801 |
-# @DESCRIPTION: |
|
802 |
-# Install the given modules (or packages) into the current Python module |
|
803 |
-# installation directory. The list can mention both modules (files) |
|
804 |
-# and packages (directories). All listed files will be installed |
|
805 |
-# for all enabled implementations, and compiled afterwards. |
|
806 |
-# |
|
807 |
-# Example: |
|
808 |
-# @CODE |
|
809 |
-# src_install() { |
|
810 |
-# # (${PN} being a directory) |
|
811 |
-# python_foreach_impl python_domodule ${PN} |
|
812 |
-# } |
|
813 |
-# @CODE |
|
814 |
-python_domodule() { |
|
815 |
- debug-print-function ${FUNCNAME} "${@}" |
|
816 |
- |
|
817 |
- [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' |
|
818 |
- |
|
819 |
- local d |
|
820 |
- if [[ ${python_moduleroot} == /* ]]; then |
|
821 |
- # absolute path |
|
822 |
- d=${python_moduleroot} |
|
823 |
- else |
|
824 |
- # relative to site-packages |
|
825 |
- local sitedir=$(python_get_sitedir) |
|
826 |
- d=${sitedir#${EPREFIX}}/${python_moduleroot//.//} |
|
827 |
- fi |
|
828 |
- |
|
829 |
- ( |
|
830 |
- insopts -m 0644 |
|
831 |
- insinto "${d}" |
|
832 |
- doins -r "${@}" || return ${?} |
|
833 |
- ) |
|
834 |
- |
|
835 |
- python_optimize "${ED%/}/${d}" |
|
836 |
-} |
|
837 |
- |
|
838 |
-# @FUNCTION: python_doheader |
|
839 |
-# @USAGE: <files>... |
|
840 |
-# @DESCRIPTION: |
|
841 |
-# Install the given headers into the implementation-specific include |
|
842 |
-# directory. This function is unconditionally recursive, i.e. you can |
|
843 |
-# pass directories instead of files. |
|
844 |
-# |
|
845 |
-# Example: |
|
846 |
-# @CODE |
|
847 |
-# src_install() { |
|
848 |
-# python_foreach_impl python_doheader foo.h bar.h |
|
849 |
-# } |
|
850 |
-# @CODE |
|
851 |
-python_doheader() { |
|
852 |
- debug-print-function ${FUNCNAME} "${@}" |
|
853 |
- |
|
854 |
- [[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).' |
|
855 |
- |
|
856 |
- local includedir=$(python_get_includedir) |
|
857 |
- local d=${includedir#${EPREFIX}} |
|
858 |
- |
|
859 |
- ( |
|
860 |
- insopts -m 0644 |
|
861 |
- insinto "${d}" |
|
862 |
- doins -r "${@}" || return ${?} |
|
863 |
- ) |
|
864 |
-} |
|
865 |
- |
|
866 |
-# @FUNCTION: python_wrapper_setup |
|
867 |
-# @USAGE: [<path> [<impl>]] |
|
868 |
-# @DESCRIPTION: |
|
869 |
-# Backwards compatibility function. The relevant API is now considered |
|
870 |
-# private, please use python_setup instead. |
|
871 |
-python_wrapper_setup() { |
|
872 |
- debug-print-function ${FUNCNAME} "${@}" |
|
873 |
- |
|
874 |
- eqawarn "python_wrapper_setup() is part of private eclass API." |
|
875 |
- eqawarn "Please call python_setup() instead." |
|
876 |
- |
|
877 |
- _python_wrapper_setup "${@}" |
|
878 |
-} |
|
879 |
- |
|
880 |
-# @FUNCTION: _python_wrapper_setup |
|
881 |
-# @USAGE: [<path> [<impl>]] |
|
882 |
-# @INTERNAL |
|
883 |
-# @DESCRIPTION: |
|
884 |
-# Create proper 'python' executable and pkg-config wrappers |
|
885 |
-# (if available) in the directory named by <path>. Set up PATH |
|
886 |
-# and PKG_CONFIG_PATH appropriately. <path> defaults to ${T}/${EPYTHON}. |
|
887 |
-# |
|
888 |
-# The wrappers will be created for implementation named by <impl>, |
|
889 |
-# or for one named by ${EPYTHON} if no <impl> passed. |
|
890 |
-# |
|
891 |
-# If the named directory contains a python symlink already, it will |
|
892 |
-# be assumed to contain proper wrappers already and only environment |
|
893 |
-# setup will be done. If wrapper update is requested, the directory |
|
894 |
-# shall be removed first. |
|
895 |
-_python_wrapper_setup() { |
|
896 |
- debug-print-function ${FUNCNAME} "${@}" |
|
897 |
- |
|
898 |
- local workdir=${1:-${T}/${EPYTHON}} |
|
899 |
- local impl=${2:-${EPYTHON}} |
|
900 |
- |
|
901 |
- [[ ${workdir} ]] || die "${FUNCNAME}: no workdir specified." |
|
902 |
- [[ ${impl} ]] || die "${FUNCNAME}: no impl nor EPYTHON specified." |
|
903 |
- |
|
904 |
- if [[ ! -x ${workdir}/bin/python ]]; then |
|
905 |
- _python_check_dead_variables |
|
906 |
- |
|
907 |
- mkdir -p "${workdir}"/{bin,pkgconfig} || die |
|
908 |
- |
|
909 |
- # Clean up, in case we were supposed to do a cheap update. |
|
910 |
- rm -f "${workdir}"/bin/python{,2,3}{,-config} || die |
|
911 |
- rm -f "${workdir}"/bin/2to3 || die |
|
912 |
- rm -f "${workdir}"/pkgconfig/python{2,3}{,-embed}.pc || die |
|
913 |
- |
|
914 |
- local EPYTHON PYTHON |
|
915 |
- _python_export "${impl}" EPYTHON PYTHON |
|
916 |
- |
|
917 |
- local pyver pyother |
|
918 |
- if python_is_python3; then |
|
919 |
- pyver=3 |
|
920 |
- pyother=2 |
|
921 |
- else |
|
922 |
- pyver=2 |
|
923 |
- pyother=3 |
|
924 |
- fi |
|
925 |
- |
|
926 |
- # Python interpreter |
|
927 |
- # note: we don't use symlinks because python likes to do some |
|
928 |
- # symlink reading magic that breaks stuff |
|
929 |
- # https://bugs.gentoo.org/show_bug.cgi?id=555752 |
|
930 |
- cat > "${workdir}/bin/python" <<-_EOF_ || die |
|
931 |
- #!/bin/sh |
|
932 |
- exec "${PYTHON}" "\${@}" |
|
933 |
- _EOF_ |
|
934 |
- cp "${workdir}/bin/python" "${workdir}/bin/python${pyver}" || die |
|
935 |
- chmod +x "${workdir}/bin/python" "${workdir}/bin/python${pyver}" || die |
|
936 |
- |
|
937 |