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

Diff of /eclass/multilib.eclass

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

Revision 1.28 Revision 1.82
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2008 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/multilib.eclass,v 1.28 2005/07/06 20:20:04 agriffis Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/multilib.eclass,v 1.82 2011/03/10 04:26:38 vapier Exp $
4# 4
5# Author: Jeremy Huddleston <eradicator@gentoo.org> 5# @ECLASS: multilib.eclass
6# 6# @MAINTAINER:
7# amd64@gentoo.org
8# toolchain@gentoo.org
9# @BLURB: This eclass is for all functions pertaining to handling multilib configurations.
10# @DESCRIPTION:
7# This eclass is for all functions pertaining to handling multilib. 11# This eclass is for all functions pertaining to handling multilib configurations.
8# configurations.
9 12
10INHERITED="$INHERITED $ECLASS" 13___ECLASS_RECUR_MULTILIB="yes"
11 14[[ -z ${___ECLASS_RECUR_TOOLCHAIN_FUNCS} ]] && inherit toolchain-funcs
12DESCRIPTION="Based on the ${ECLASS} eclass"
13
14# has_multilib_profile:
15# Return true if the current profile is a multilib profile and lists more than
16# one abi in ${MULTILIB_ABIS}. You might want to use this like
17# 'use multilib || has_multilib_profile' until all profiles utilizing the
18# 'multilib' use flag are removed from portage
19
20# is_final_abi:
21# Return true if ${ABI} is the final abi to be installed (and thus we are
22# on our last run through a src_* function.
23
24# number_abis:
25# echo the number of ABIs we will be installing for
26
27# get_install_abis:
28# Return a list of the ABIs we want to install for with
29# the last one in the list being the default.
30
31# get_all_abis:
32# Return a list of the ABIs supported by this profile.
33# the last one in the list being the default.
34
35# get_all_libdirs:
36# Returns a list of all the libdirs used by this profile. This includes
37# those that might not be touched by the current ebuild and always includes
38# "lib".
39
40# get_libdir:
41# Returns the libdir for the selected ABI. This is backwards compatible
42# and simply calls get_abi_LIBDIR() on newer profiles. You should use this
43# to determine where to install shared objects (ex: /usr/$(get_libdir))
44
45# get_abi_var <VAR> [<ABI>]:
46# returns the value of ${<VAR>_<ABI>} which should be set in make.defaults
47#
48# get_abi_CFLAGS:
49# get_abi_CDEFINE:
50# get_abi_LIBDIR:
51# Aliases for 'get_abi_var CFLAGS', etc.
52
53# get_ml_incdir [<include dir> [<ABI>]]
54# include dir defaults to /usr/include
55# ABI defaults to ${ABI} or ${DEFAULT_ABI}
56#
57# If a multilib include dir is associated with the passed include dir, then
58# we return it, otherwise, we just echo back the include dir. This is
59# neccessary when a built script greps header files rather than testing them
60# via #include (like perl) to figure out features.
61
62# prep_ml_includes:
63# Some includes (include/asm, glibc, etc) are ABI dependent. In this case,
64# We can install them in different locations for each ABI and create a common
65# header which includes the right one based on CDEFINE_${ABI}. If your
66# package installs ABI-specific headers, just add 'prep_ml_includes' to the
67# end of your src_install(). It takes a list of directories that include
68# files are installed in (default is /usr/include if none are passed).
69#
70# Example:
71# src_install() {
72# ...
73# prep_ml_includes /usr/qt/3/include
74# }
75
76# create_ml_includes <include dir> <symbol 1>:<dir 1> [<symbol 2>:<dir 2> ...]
77# If you need more control than prep_ml_includes can offer (like linux-headers
78# for the asm-* dirs, then use create_ml_includes. The firs argument is the
79# common dir. The remaining args are of the form <symbol>:<dir> where
80# <symbol> is what is put in the #ifdef for choosing that dir.
81#
82# Ideas for this code came from debian's sparc-linux headers package.
83#
84# Example:
85# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64
86# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64
87
88### END DOCUMENTATION ###
89 15
90# Defaults: 16# Defaults:
91export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"} 17export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"}
92export DEFAULT_ABI=${DEFAULT_ABI:-"default"} 18export DEFAULT_ABI=${DEFAULT_ABI:-"default"}
93# This causes econf to set --libdir=/usr/lib where it didn't before
94#export ABI=${ABI:-"default"}
95export CFLAGS_default 19export CFLAGS_default
96export LDFLAGS_default 20export LDFLAGS_default
97export CHOST_default=${CHOST_default:-${CHOST}} 21export CHOST_default=${CHOST_default:-${CHOST}}
22export CTARGET_default=${CTARGET_default:-${CTARGET:-${CHOST_default}}}
98export LIBDIR_default=${CONF_LIBDIR:-"lib"} 23export LIBDIR_default=${CONF_LIBDIR:-"lib"}
99export CDEFINE_default="__unix__" 24export CDEFINE_default="__unix__"
25export KERNEL_ABI=${KERNEL_ABI:-${DEFAULT_ABI}}
100 26
101# has_multilib_profile() 27# @FUNCTION: has_multilib_profile
28# @DESCRIPTION:
29# Return true if the current profile is a multilib profile and lists more than
30# one abi in ${MULTILIB_ABIS}. When has_multilib_profile returns true, that
31# profile should enable the 'multilib' use flag. This is so you can DEPEND on
32# a package only for multilib or not multilib.
102has_multilib_profile() { 33has_multilib_profile() {
103 [ -n "${MULTILIB_ABIS}" -a "${MULTILIB_ABIS}" != "${MULTILIB_ABIS/ /}" ] 34 [ -n "${MULTILIB_ABIS}" -a "${MULTILIB_ABIS}" != "${MULTILIB_ABIS/ /}" ]
104} 35}
105 36
37# @FUNCTION: get_libdir
38# @RETURN: the libdir for the selected ABI
39# @DESCRIPTION:
106# This function simply returns the desired lib directory. With portage 40# This function simply returns the desired lib directory. With portage
107# 2.0.51, we now have support for installing libraries to lib32/lib64 41# 2.0.51, we now have support for installing libraries to lib32/lib64
108# to accomidate the needs of multilib systems. It's no longer a good idea 42# to accomidate the needs of multilib systems. It's no longer a good idea
109# to assume all libraries will end up in lib. Replace any (sane) instances 43# to assume all libraries will end up in lib. Replace any (sane) instances
110# where lib is named directly with $(get_libdir) if possible. 44# where lib is named directly with $(get_libdir) if possible.
111#
112# Travis Tilley <lv@gentoo.org> (24 Aug 2004)
113# 45#
114# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004): 46# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004):
115# Added support for ${ABI} and ${DEFAULT_ABI}. If they're both not set, 47# Added support for ${ABI} and ${DEFAULT_ABI}. If they're both not set,
116# fall back on old behavior. Any profile that has these set should also 48# fall back on old behavior. Any profile that has these set should also
117# depend on a newer version of portage (not yet released) which uses these 49# depend on a newer version of portage (not yet released) which uses these
124 else 56 else
125 get_abi_LIBDIR 57 get_abi_LIBDIR
126 fi 58 fi
127} 59}
128 60
61# @FUNCTION: get_multilibdir
62# @RETURN: Returns the multilibdir
129get_multilibdir() { 63get_multilibdir() {
130 if has_multilib_profile; then 64 if has_multilib_profile; then
131 eerror "get_multilibdir called, but it shouldn't be needed with the new multilib approach. Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org" 65 eerror "get_multilibdir called, but it shouldn't be needed with the new multilib approach. Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org"
132 exit 1 66 exit 1
133 fi 67 fi
134 echo ${CONF_MULTILIBDIR:=lib32} 68 echo ${CONF_MULTILIBDIR:=lib32}
135} 69}
136 70
71# @FUNCTION: get_libdir_override
72# @DESCRIPTION:
137# Sometimes you need to override the value returned by get_libdir. A good 73# Sometimes you need to override the value returned by get_libdir. A good
138# example of this is xorg-x11, where lib32 isnt a supported configuration, 74# example of this is xorg-x11, where lib32 isnt a supported configuration,
139# and where lib64 -must- be used on amd64 (for applications that need lib 75# and where lib64 -must- be used on amd64 (for applications that need lib
140# to be 32bit, such as adobe acrobat). Note that this override also bypasses 76# to be 32bit, such as adobe acrobat). Note that this override also bypasses
141# portage version sanity checking. 77# portage version sanity checking.
142# get_libdir_override expects one argument, the result get_libdir should 78# get_libdir_override expects one argument, the result get_libdir should
143# return: 79# return:
144# 80#
145# get_libdir_override lib64 81# get_libdir_override lib64
146#
147# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
148get_libdir_override() { 82get_libdir_override() {
149 if has_multilib_profile; then 83 if has_multilib_profile; then
150 eerror "get_libdir_override called, but it shouldn't be needed with the new multilib approach. Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org" 84 eerror "get_libdir_override called, but it shouldn't be needed with the new multilib approach. Please file a bug at http://bugs.gentoo.org and assign it to eradicator@gentoo.org"
151 exit 1 85 exit 1
152 fi 86 fi
153 CONF_LIBDIR="$1" 87 CONF_LIBDIR="$1"
154 CONF_LIBDIR_OVERRIDE="$1" 88 CONF_LIBDIR_OVERRIDE="$1"
155 LIBDIR_default="$1" 89 LIBDIR_default="$1"
156} 90}
157 91
158# get_abi_var <VAR> [<ABI>] 92# @FUNCTION: get_abi_var
93# @USAGE: <VAR> [ABI]
159# returns the value of ${<VAR>_<ABI>} which should be set in make.defaults 94# @RETURN: returns the value of ${<VAR>_<ABI>} which should be set in make.defaults
160# 95# @DESCRIPTION:
161# ex: 96# ex:
162# CFLAGS=$(get_abi_var CFLAGS sparc32) # CFLAGS=-m32 97# CFLAGS=$(get_abi_var CFLAGS sparc32) # CFLAGS=-m32
163# 98#
164# Note that the prefered method is to set CC="$(tc-getCC) $(get_abi_CFLAGS)" 99# Note that the prefered method is to set CC="$(tc-getCC) $(get_abi_CFLAGS)"
165# This will hopefully be added to portage soon... 100# This will hopefully be added to portage soon...
166# 101#
167# If <ABI> is not specified, ${ABI} is used. 102# If <ABI> is not specified, ${ABI} is used.
168# If <ABI> is not specified and ${ABI} is not defined, ${DEFAULT_ABI} is used. 103# If <ABI> is not specified and ${ABI} is not defined, ${DEFAULT_ABI} is used.
169# If <ABI> is not specified and ${ABI} and ${DEFAULT_ABI} are not defined, we return an empty string. 104# If <ABI> is not specified and ${ABI} and ${DEFAULT_ABI} are not defined, we return an empty string.
170#
171# Jeremy Huddleston <eradicator@gentoo.org>
172get_abi_var() { 105get_abi_var() {
173 local flag=${1} 106 local flag=$1
174 local abi 107 local abi
175 if [ $# -gt 1 ]; then 108 if [ $# -gt 1 ]; then
176 abi=${2} 109 abi=${2}
177 elif [ -n "${ABI}" ]; then 110 elif [ -n "${ABI}" ]; then
178 abi=${ABI} 111 abi=${ABI}
184 117
185 local var="${flag}_${abi}" 118 local var="${flag}_${abi}"
186 echo ${!var} 119 echo ${!var}
187} 120}
188 121
122# @FUNCTION: get_abi_CFLAGS
123# @USAGE: [ABI]
124# @DESCRIPTION:
125# Alias for 'get_abi_var CFLAGS'
189get_abi_CFLAGS() { get_abi_var CFLAGS "${@}"; } 126get_abi_CFLAGS() { get_abi_var CFLAGS "$@"; }
127
128# @FUNCTION: get_abi_ASFLAGS
129# @USAGE: [ABI]
130# @DESCRIPTION:
131# Alias for 'get_abi_var ASFLAGS'
132get_abi_ASFLAGS() { get_abi_var ASFLAGS "$@"; }
133
134# @FUNCTION: get_abi_LDFLAGS
135# @USAGE: [ABI]
136# @DESCRIPTION:
137# Alias for 'get_abi_var LDFLAGS'
190get_abi_LDFLAGS() { get_abi_var LDFLAGS "${@}"; } 138get_abi_LDFLAGS() { get_abi_var LDFLAGS "$@"; }
139
140# @FUNCTION: get_abi_CHOST
141# @USAGE: [ABI]
142# @DESCRIPTION:
143# Alias for 'get_abi_var CHOST'
191get_abi_CHOST() { get_abi_var CHOST "${@}"; } 144get_abi_CHOST() { get_abi_var CHOST "$@"; }
145
146# @FUNCTION: get_abi_CTARGET
147# @USAGE: [ABI]
148# @DESCRIPTION:
149# Alias for 'get_abi_var CTARGET'
150get_abi_CTARGET() { get_abi_var CTARGET "$@"; }
151
152# @FUNCTION: get_abi_FAKE_TARGETS
153# @USAGE: [ABI]
154# @DESCRIPTION:
155# Alias for 'get_abi_var FAKE_TARGETS'
192get_abi_FAKE_TARGETS() { get_abi_var FAKE_TARGETS "${@}"; } 156get_abi_FAKE_TARGETS() { get_abi_var FAKE_TARGETS "$@"; }
157
158# @FUNCTION: get_abi_CDEFINE
159# @USAGE: [ABI]
160# @DESCRIPTION:
161# Alias for 'get_abi_var CDEFINE'
193get_abi_CDEFINE() { get_abi_var CDEFINE "${@}"; } 162get_abi_CDEFINE() { get_abi_var CDEFINE "$@"; }
163
164# @FUNCTION: get_abi_LIBDIR
165# @USAGE: [ABI]
166# @DESCRIPTION:
167# Alias for 'get_abi_var LIBDIR'
194get_abi_LIBDIR() { get_abi_var LIBDIR "${@}"; } 168get_abi_LIBDIR() { get_abi_var LIBDIR "$@"; }
195 169
170# @FUNCTION: get_install_abis
171# @DESCRIPTION:
196# Return a list of the ABIs we want to install for with 172# Return a list of the ABIs we want to install for with
197# the last one in the list being the default. 173# the last one in the list being the default.
198get_install_abis() { 174get_install_abis() {
199 local order="" 175 local order=""
200 176
201 if [ -z "${MULTILIB_ABIS}" ]; then 177 if [[ -z ${MULTILIB_ABIS} ]] ; then
202 echo "default" 178 echo "default"
203 return 0 179 return 0
204 fi 180 fi
205 181
206 if hasq multilib-pkg-force ${RESTRICT} || 182 if [[ ${EMULTILIB_PKG} == "true" ]] ; then
207 { hasq multilib-pkg ${FEATURES} && hasq multilib-pkg ${RESTRICT}; }; then
208 for x in ${MULTILIB_ABIS}; do 183 for x in ${MULTILIB_ABIS} ; do
209 if [ "${x}" != "${DEFAULT_ABI}" ]; then 184 if [[ ${x} != "${DEFAULT_ABI}" ]] ; then
210 hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}" 185 hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}"
211 fi 186 fi
212 done 187 done
213 hasq ${DEFAULT_ABI} ${ABI_DENY} || order="${ordera} ${DEFAULT_ABI}" 188 hasq ${DEFAULT_ABI} ${ABI_DENY} || order="${ordera} ${DEFAULT_ABI}"
214 189
215 if [ -n "${ABI_ALLOW}" ]; then 190 if [[ -n ${ABI_ALLOW} ]] ; then
216 local ordera="" 191 local ordera=""
217 for x in ${order}; do 192 for x in ${order} ; do
218 if hasq ${x} ${ABI_ALLOW}; then 193 if hasq ${x} ${ABI_ALLOW} ; then
219 ordera="${ordera} ${x}" 194 ordera="${ordera} ${x}"
220 fi 195 fi
221 done 196 done
222 order="${ordera}" 197 order=${ordera}
223 fi 198 fi
224 else 199 else
225 order="${DEFAULT_ABI}" 200 order=${DEFAULT_ABI}
226 fi 201 fi
227 202
228 if [ -z "${order}" ]; then 203 if [[ -z ${order} ]] ; then
229 die "The ABI list is empty. Are you using a proper multilib profile? Perhaps your USE flags or MULTILIB_ABIS are too restrictive for this package." 204 die "The ABI list is empty. Are you using a proper multilib profile? Perhaps your USE flags or MULTILIB_ABIS are too restrictive for this package."
230 fi 205 fi
231 206
232 echo ${order} 207 echo ${order}
233 return 0 208 return 0
234} 209}
235 210
211# @FUNCTION: get_all_abis
212# @DESCRIPTION:
236# Return a list of the ABIs supported by this profile. 213# Return a list of the ABIs supported by this profile.
237# the last one in the list being the default. 214# the last one in the list being the default.
238get_all_abis() { 215get_all_abis() {
239 local order="" 216 local order=""
240 217
241 if [ -z "${MULTILIB_ABIS}" ]; then 218 if [[ -z ${MULTILIB_ABIS} ]] ; then
242 echo "default" 219 echo "default"
243 return 0 220 return 0
244 fi 221 fi
245 222
246 for x in ${MULTILIB_ABIS}; do 223 for x in ${MULTILIB_ABIS}; do
247 if [ "${x}" != "${DEFAULT_ABI}" ]; then 224 if [[ ${x} != ${DEFAULT_ABI} ]] ; then
248 order="${order:+${order }}${x}" 225 order="${order:+${order} }${x}"
249 fi 226 fi
250 done 227 done
251 order="${order:+${order} }${DEFAULT_ABI}" 228 order="${order:+${order} }${DEFAULT_ABI}"
252 229
253 echo ${order} 230 echo ${order}
254 return 0 231 return 0
255} 232}
256 233
257# get_all_libdirs() 234# @FUNCTION: get_all_libdirs
235# @DESCRIPTION:
258# Returns a list of all the libdirs used by this profile. This includes 236# Returns a list of all the libdirs used by this profile. This includes
259# those that might not be touched by the current ebuild. 237# those that might not be touched by the current ebuild and always includes
238# "lib".
260get_all_libdirs() { 239get_all_libdirs() {
261 local libdirs="lib" 240 local libdirs="lib"
262 local abi 241 local abi
263 local dir 242 local dir
264 243
265 if has_multilib_profile; then
266 for abi in ${MULTILIB_ABIS}; do 244 for abi in ${MULTILIB_ABIS}; do
267 [ "$(get_abi_LIBDIR ${abi})" != "lib" ] && libdirs="${libdirs} $(get_abi_LIBDIR ${abi})" 245 [ "$(get_abi_LIBDIR ${abi})" != "lib" ] && libdirs="${libdirs} $(get_abi_LIBDIR ${abi})"
268 done 246 done
269 elif [ -n "${CONF_LIBDIR}" ]; then
270 for dir in ${CONF_LIBDIR} ${CONF_MULTILIBDIR:-lib32}; do
271 [ "${dir}" != "lib" ] && libdirs="${libdirs} ${dir}"
272 done
273 fi
274 247
275 echo "${libdirs}" 248 echo "${libdirs}"
276} 249}
277 250
251# @FUNCTION: is_final_abi
252# @DESCRIPTION:
278# Return true if ${ABI} is the last ABI on our list (or if we're not 253# Return true if ${ABI} is the last ABI on our list (or if we're not
279# using the new multilib configuration. This can be used to determine 254# using the new multilib configuration. This can be used to determine
280# if we're in the last (or only) run through src_{unpack,compile,install} 255# if we're in the last (or only) run through src_{unpack,compile,install}
281is_final_abi() { 256is_final_abi() {
282 has_multilib_profile || return 0 257 has_multilib_profile || return 0
283 local ALL_ABIS=$(get_install_abis) 258 local ALL_ABIS=$(get_install_abis)
284 local LAST_ABI=${ALL_ABIS/* /} 259 local LAST_ABI=${ALL_ABIS/* /}
285 [[ ${LAST_ABI} == ${ABI} ]] 260 [[ ${LAST_ABI} == ${ABI} ]]
286} 261}
287 262
263# @FUNCTION: number_abis
264# @DESCRIPTION:
288# echo the number of ABIs we will be installing for 265# echo the number of ABIs we will be installing for
289number_abis() { 266number_abis() {
290 get_install_abis | wc -w 267 get_install_abis | wc -w
291} 268}
292 269
293# get_ml_incdir [<include dir> [<ABI>]] 270# @FUNCTION: get_ml_incdir
271# @USAGE: [include_dir] [ABI]
272# @DESCRIPTION:
294# include dir defaults to /usr/include 273# include dir defaults to /usr/include
295# ABI defaults to ${ABI} or ${DEFAULT_ABI} 274# ABI defaults to ${ABI} or ${DEFAULT_ABI}
275#
276# If a multilib include dir is associated with the passed include dir, then
277# we return it, otherwise, we just echo back the include dir. This is
278# neccessary when a built script greps header files rather than testing them
279# via #include (like perl) to figure out features.
296get_ml_incdir() { 280get_ml_incdir() {
297 local dir=/usr/include 281 local dir=/usr/include
298 282
299 if [[ ${#} -gt 0 ]]; then 283 if [[ $# -gt 0 ]]; then
300 incdir=${1} 284 incdir=$1
301 shift 285 shift
302 fi 286 fi
303 287
304 if [[ -z "${MULTILIB_ABIS}" ]]; then 288 if [[ -z "${MULTILIB_ABIS}" ]]; then
305 echo ${incdir} 289 echo ${incdir}
306 return 0 290 return 0
307 fi 291 fi
308 292
309 local abi=${ABI-${DEFAULT_ABI}} 293 local abi=${ABI-${DEFAULT_ABI}}
310 if [[ ${#} -gt 0 ]]; then 294 if [[ $# -gt 0 ]]; then
311 abi=${1} 295 abi=$1
312 shift 296 shift
313 fi 297 fi
314 298
315 if [[ -d "${dir}/gentoo-multilib/${abi}" ]]; then 299 if [[ -d "${dir}/gentoo-multilib/${abi}" ]]; then
316 echo ${dir}/gentoo-multilib/${abi} 300 echo ${dir}/gentoo-multilib/${abi}
317 else 301 else
318 echo ${dir} 302 echo ${dir}
319 fi 303 fi
320} 304}
321 305
322# prep_ml_includes: 306# @FUNCTION: prep_ml_includes
323# 307# @DESCRIPTION:
324# Some includes (include/asm, glibc, etc) are ABI dependent. In this case, 308# Some includes (include/asm, glibc, etc) are ABI dependent. In this case,
325# We can install them in different locations for each ABI and create a common 309# We can install them in different locations for each ABI and create a common
326# header which includes the right one based on CDEFINE_${ABI}. If your 310# header which includes the right one based on CDEFINE_${ABI}. If your
327# package installs ABI-specific headers, just add 'prep_ml_includes' to the 311# package installs ABI-specific headers, just add 'prep_ml_includes' to the
328# end of your src_install(). It takes a list of directories that include 312# end of your src_install(). It takes a list of directories that include
329# files are installed in (default is /usr/include if none are passed). 313# files are installed in (default is /usr/include if none are passed).
330# 314#
331# Example: 315# Example:
332# src_install() { 316# src_install() {
333# ... 317# ...
334# prep_ml_includes /usr/qt/3/include 318# prep_ml_includes /usr/qt/3/include
335# } 319# }
336
337prep_ml_includes() { 320prep_ml_includes() {
338 if [ $(number_abis) -gt 1 ]; then 321 if [[ $(number_abis) -gt 1 ]] ; then
339 local dir 322 local dir
340 local dirs 323 local dirs
341 local base 324 local base
342 325
343 if [ ${#} -eq 0 ]; then 326 if [[ $# -eq 0 ]] ; then
344 dirs="/usr/include" 327 dirs=/usr/include
345 else 328 else
346 dirs="${@}" 329 dirs="$@"
347 fi 330 fi
348 331
349 for dir in ${dirs}; do 332 for dir in ${dirs} ; do
350 base=${T}/gentoo-multilib/${dir}/gentoo-multilib 333 base=${T}/gentoo-multilib/${dir}/gentoo-multilib
351 mkdir -p ${base} 334 mkdir -p "${base}"
352 [ -d ${base}/${ABI} ] && rm -rf ${base}/${ABI} 335 [[ -d ${base}/${ABI} ]] && rm -rf "${base}/${ABI}"
353 mv ${D}/${dir} ${base}/${ABI} 336 mv "${D}/${dir}" "${base}/${ABI}"
354 done 337 done
355 338
356 if is_final_abi; then 339 if is_final_abi; then
357 base=${T}/gentoo-multilib 340 base=${T}/gentoo-multilib
358 pushd ${base} 341 pushd "${base}"
359 find . | tar -c -T - -f - | tar -x --no-same-owner -f - -C ${D} 342 find . | tar -c -T - -f - | tar -x --no-same-owner -f - -C "${D}"
360 popd 343 popd
361 344
345 # This 'set' stuff is required by mips profiles to properly pass
346 # CDEFINE's (which have spaces) to sub-functions
347 set --
362 for dir in ${dirs}; do 348 for dir in ${dirs} ; do
363 local args=${dir} 349 set -- "$@" "${dir}"
364 local abi 350 local abi
365 for abi in $(get_install_abis); do 351 for abi in $(get_install_abis); do
366 args="${args} $(get_abi_CDEFINE ${abi}):${dir}/gentoo-multilib/${abi}" 352 set -- "$@" "$(get_abi_CDEFINE ${abi}):${dir}/gentoo-multilib/${abi}"
367 done 353 done
368 create_ml_includes ${args} 354 create_ml_includes "$@"
369 done 355 done
370 fi 356 fi
371 fi 357 fi
372} 358}
373 359
360# @FUNCTION: create_ml_includes
361# @USAGE: <include_dir> <symbol_1>:<dir_1> [<symbol_2>:<dir_2>...]
362# @DESCRIPTION:
374# If you need more control than prep_ml_includes can offer (like linux-headers 363# If you need more control than prep_ml_includes can offer (like linux-headers
375# for the asm-* dirs, then use create_ml_includes. The firs argument is the 364# for the asm-* dirs, then use create_ml_includes. The firs argument is the
376# common dir. The remaining args are of the form <symbol>:<dir> where 365# common dir. The remaining args are of the form <symbol>:<dir> where
377# <symbol> is what is put in the #ifdef for choosing that dir. 366# <symbol> is what is put in the #ifdef for choosing that dir.
378# 367#
379# Ideas for this code came from debian's sparc-linux headers package. 368# Ideas for this code came from debian's sparc-linux headers package.
380# 369#
381# Example: 370# Example:
382# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64 371# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64
383# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64 372# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64
373#
374# Warning: Be careful with the ordering here. The default ABI has to be the
375# last, because it is always defined (by GCC)
384create_ml_includes() { 376create_ml_includes() {
385 local dest="${1}" 377 local dest=$1
386 shift 378 shift
387 local mlinfo="${@}"
388 local basedirs=$(create_ml_includes-listdirs ${mlinfo}) 379 local basedirs=$(create_ml_includes-listdirs "$@")
389 380
390 create_ml_includes-makedestdirs ${dest} ${basedirs} 381 create_ml_includes-makedestdirs ${dest} ${basedirs}
391 382
392 local file 383 local file
393 for file in $(create_ml_includes-allfiles ${basedirs}); do 384 for file in $(create_ml_includes-allfiles ${basedirs}) ; do
394 local name="$(echo $file | tr a-z A-Z | sed 's:[^A-Z]:_:g')" 385 #local name=$(echo ${file} | tr '[:lower:]' '[:upper:]' | sed 's:[^[:upper:]]:_:g')
395 { 386 (
396 echo "/* Common header file autogenerated by create_ml_includes in multilib.eclass */" 387 echo "/* Autogenerated by create_ml_includes() in multilib.eclass */"
397 388
398 local dir 389 local dir
399 for dir in ${basedirs}; do 390 for dir in ${basedirs}; do
400 if [ -f "${D}/${dir}/${file}" ]; then 391 if [[ -f ${D}/${dir}/${file} ]] ; then
392 echo ""
401 local sym=$(create_ml_includes-sym_for_dir ${dir} ${mlinfo}) 393 local sym=$(create_ml_includes-sym_for_dir ${dir} "$@")
394 if [[ ${sym/=} != "${sym}" ]] ; then
395 echo "#if ${sym}"
402 if [[ ${sym::1} == "!" ]]; then 396 elif [[ ${sym::1} == "!" ]] ; then
403 echo "#ifndef ${sym:1}" 397 echo "#ifndef ${sym:1}"
404 else 398 else
405 echo "#ifdef ${sym}" 399 echo "#ifdef ${sym}"
406 fi 400 fi
407 echo "#include <$(create_ml_includes-absolute ${dir}/${file})>" 401 echo "# include <$(create_ml_includes-absolute ${dir}/${file})>"
408 echo "#endif /* ${sym} */" 402 echo "#endif /* ${sym} */"
409 echo ""
410 fi 403 fi
411 done 404 done
412 405
413 #echo "#endif /* __CREATE_ML_INCLUDES_STUB_${name}__ */" 406 #echo "#endif /* __CREATE_ML_INCLUDES_STUB_${name}__ */"
414 } > ${D}/${dest}/${file} 407 ) > "${D}/${dest}/${file}"
415 done 408 done
416} 409}
417 410
418# Helper function for create_ml_includes 411# Helper function for create_ml_includes
419create_ml_includes-absolute() { 412create_ml_includes-absolute() {
420 local dst="$(create_ml_includes-tidy_path ${1})" 413 local dst="$(create_ml_includes-tidy_path $1)"
421 414
422 dst=(${dst//\// }) 415 dst=(${dst//\// })
423 416
424 local i 417 local i
425 for ((i=0; i<${#dst[*]}; i++)); do 418 for ((i=0; i<${#dst[*]}; i++)); do
435 echo -n ${dst[i]} 428 echo -n ${dst[i]}
436} 429}
437 430
438# Helper function for create_ml_includes 431# Helper function for create_ml_includes
439create_ml_includes-tidy_path() { 432create_ml_includes-tidy_path() {
440 local removed="${1}" 433 local removed=$1
441 434
442 if [ -n "${removed}" ]; then 435 if [ -n "${removed}" ]; then
443 # Remove multiple slashes 436 # Remove multiple slashes
444 while [ "${removed}" != "${removed/\/\//\/}" ]; do 437 while [ "${removed}" != "${removed/\/\//\/}" ]; do
445 removed=${removed/\/\//\/} 438 removed=${removed/\/\//\/}
462 # Remove trailing .. 455 # Remove trailing ..
463 [ "${removed##*/}" = ".." ] && removed=${removed%/*/*} 456 [ "${removed##*/}" = ".." ] && removed=${removed%/*/*}
464 457
465 # Remove trailing / 458 # Remove trailing /
466 [ "${removed##*/}" = "" ] && removed=${removed%/*} 459 [ "${removed##*/}" = "" ] && removed=${removed%/*}
467 460
468 echo ${removed} 461 echo ${removed}
469 fi 462 fi
470} 463}
471 464
472# Helper function for create_ml_includes 465# Helper function for create_ml_includes
473create_ml_includes-listdirs() { 466create_ml_includes-listdirs() {
474 local dirs 467 local dirs
475 local data 468 local data
476 for data in ${@}; do 469 for data in "$@"; do
477 dirs="${dirs} ${data/*:/}" 470 dirs="${dirs} ${data/*:/}"
478 done 471 done
479 echo ${dirs:1} 472 echo ${dirs:1}
480} 473}
481 474
482# Helper function for create_ml_includes 475# Helper function for create_ml_includes
483create_ml_includes-makedestdirs() { 476create_ml_includes-makedestdirs() {
484 local dest=${1} 477 local dest=$1
485 shift 478 shift
486 local basedirs=${@} 479 local basedirs=$@
480 [[ -z ${ED} ]] && local ED=${D}
487 481
488 dodir ${dest} 482 dodir ${dest}
489 483
490 local basedir 484 local basedir
491 for basedir in ${basedirs}; do 485 for basedir in ${basedirs}; do
492 local dir 486 local dir
493 for dir in $(find ${D}/${basedir} -type d); do 487 for dir in $(find "${ED}"/${basedir} -type d); do
494 dodir ${dest}/${dir/${D}\/${basedir}/} 488 dodir ${dest}/${dir/${ED}\/${basedir}/}
495 done 489 done
496 done 490 done
497} 491}
498 492
499# Helper function for create_ml_includes 493# Helper function for create_ml_includes
500create_ml_includes-allfiles() { 494create_ml_includes-allfiles() {
501 local basedirs=${@} 495 [[ -z ${ED} ]] && local ED=${D}
502
503 local basedir 496 local basedir file
504 for basedir in ${basedirs}; do 497 for basedir in "$@" ; do
505 local file
506 for file in $(find ${D}/${basedir} -type f); do 498 for file in $(find "${ED}"/${basedir} -type f); do
507 echo ${file/${D}\/${basedir}\//} 499 echo ${file/${ED}\/${basedir}\//}
508 done 500 done
509 done | sort | uniq 501 done | sort | uniq
510} 502}
511 503
512# Helper function for create_ml_includes 504# Helper function for create_ml_includes
513create_ml_includes-sym_for_dir() { 505create_ml_includes-sym_for_dir() {
514 local dir="${1}" 506 local dir=$1
515 shift 507 shift
516 local data 508 local data
517 for data in ${@}; do 509 for data in "$@"; do
518 if [ "${dir}" = "${data/*:/}" ]; then 510 if [[ ${data} == *:${dir} ]] ; then
519 echo ${data/:*/} 511 echo ${data/:*/}
520 return 0 512 return 0
521 fi 513 fi
522 done 514 done
523 echo "Shouldn't be here -- create_ml_includes-sym_for_dir ${1} ${@}" 515 echo "Shouldn't be here -- create_ml_includes-sym_for_dir $1 $@"
524 # exit because we'll likely be called from a subshell 516 # exit because we'll likely be called from a subshell
525 exit 1 517 exit 1
526} 518}
519
520# @FUNCTION: get_libname
521# @USAGE: [version]
522# @DESCRIPTION:
523# Returns libname with proper suffix {.so,.dylib,.dll,etc} and optionally
524# supplied version for the current platform identified by CHOST.
525#
526# Example:
527# get_libname ${PV}
528# Returns: .so.${PV} (ELF) || .${PV}.dylib (MACH) || ...
529get_libname() {
530 local libname
531 local ver=$1
532 case ${CHOST} in
533 *-cygwin|mingw*|*-mingw*) libname="dll";;
534 *-darwin*) libname="dylib";;
535 *-mint*) libname="irrelevant";;
536 hppa*-hpux*) libname="sl";;
537 *) libname="so";;
538 esac
539
540 if [[ -z $* ]] ; then
541 echo ".${libname}"
542 else
543 for ver in "$@" ; do
544 case ${CHOST} in
545 *-darwin*) echo ".${ver}.${libname}";;
546 *-mint*) echo ".${libname}";;
547 *) echo ".${libname}.${ver}";;
548 esac
549 done
550 fi
551}
552
553# @FUNCTION: get_modname
554# @USAGE:
555# @DESCRIPTION:
556# Returns modulename with proper suffix {.so,.bundle,etc} for the current
557# platform identified by CHOST.
558#
559# Example:
560# libfoo$(get_modname)
561# Returns: libfoo.so (ELF) || libfoo.bundle (MACH) || ...
562get_modname() {
563 local modname
564 local ver=$1
565 case ${CHOST} in
566 *-darwin*) modname="bundle";;
567 *) modname="so";;
568 esac
569
570 echo ".${modname}"
571}
572
573# This is for the toolchain to setup profile variables when pulling in
574# a crosscompiler (and thus they aren't set in the profile)
575multilib_env() {
576 local CTARGET=${1:-${CTARGET}}
577
578 case ${CTARGET} in
579 x86_64*)
580 export CFLAGS_x86=${CFLAGS_x86--m32}
581 export CHOST_x86=${CTARGET/x86_64/i686}
582 export CTARGET_x86=${CHOST_x86}
583 export CDEFINE_x86="__i386__"
584 export LIBDIR_x86="lib32"
585
586 export CFLAGS_amd64=${CFLAGS_amd64--m64}
587 export CHOST_amd64=${CTARGET}
588 export CTARGET_amd64=${CHOST_amd64}
589 export CDEFINE_amd64="__x86_64__"
590 export LIBDIR_amd64="lib64"
591
592 export CFLAGS_x32=${CFLAGS_x32--mx32}
593 export CHOST_x32=${CTARGET}
594 export CTARGET_x32=${CHOST_x32}
595 export CDEFINE_x32="__i386__"
596 export LIBDIR_x32="libx32"
597
598 : ${MULTILIB_ABIS=amd64 x86}
599 : ${DEFAULT_ABI=amd64}
600 ;;
601 mips64*)
602 export CFLAGS_o32=${CFLAGS_o32--mabi=32}
603 export CHOST_o32=${CTARGET/mips64/mips}
604 export CTARGET_o32=${CHOST_o32}
605 export CDEFINE_o32="_MIPS_SIM == _ABIO32"
606 export LIBDIR_o32="lib"
607
608 export CFLAGS_n32=${CFLAGS_n32--mabi=n32}
609 export CHOST_n32=${CTARGET}
610 export CTARGET_n32=${CHOST_n32}
611 export CDEFINE_n32="_MIPS_SIM == _ABIN32"
612 export LIBDIR_n32="lib32"
613
614 export CFLAGS_n64=${CFLAGS_n64--mabi=64}
615 export CHOST_n64=${CTARGET}
616 export CTARGET_n64=${CHOST_n64}
617 export CDEFINE_n64="_MIPS_SIM == _ABI64"
618 export LIBDIR_n64="lib64"
619
620 : ${MULTILIB_ABIS=n64 n32 o32}
621 : ${DEFAULT_ABI=n32}
622 ;;
623 powerpc64*)
624 export CFLAGS_ppc=${CFLAGS_ppc--m32}
625 export CHOST_ppc=${CTARGET/powerpc64/powerpc}
626 export CTARGET_ppc=${CHOST_ppc}
627 export CDEFINE_ppc="!__powerpc64__"
628 export LIBDIR_ppc="lib"
629
630 export CFLAGS_ppc64=${CFLAGS_ppc64--m64}
631 export CHOST_ppc64=${CTARGET}
632 export CTARGET_ppc64=${CHOST_ppc64}
633 export CDEFINE_ppc64="__powerpc64__"
634 export LIBDIR_ppc64="lib64"
635
636 : ${MULTILIB_ABIS=ppc64 ppc}
637 : ${DEFAULT_ABI=ppc64}
638 ;;
639 s390x*)
640 export CFLAGS_s390=${CFLAGS_s390--m31} # the 31 is not a typo
641 export CHOST_s390=${CTARGET/s390x/s390}
642 export CTARGET_s390=${CHOST_s390}
643 export CDEFINE_s390="!__s390x__"
644 export LIBDIR_s390="lib"
645
646 export CFLAGS_s390x=${CFLAGS_s390x--m64}
647 export CHOST_s390x=${CTARGET}
648 export CTARGET_s390x=${CHOST_s390x}
649 export CDEFINE_s390x="__s390x__"
650 export LIBDIR_s390x="lib64"
651
652 : ${MULTILIB_ABIS=s390x s390}
653 : ${DEFAULT_ABI=s390x}
654 ;;
655 sparc*)
656 export CFLAGS_sparc32=${CFLAGS_sparc32}
657 export CHOST_sparc32=${CTARGET/sparc64/sparc}
658 export CTARGET_sparc32=${CHOST_sparc32}
659 export CDEFINE_sparc32="!__arch64__"
660 export LIBDIR_sparc32="lib"
661
662 export CFLAGS_sparc64=${CFLAGS_sparc64--m64}
663 export CHOST_sparc64=${CTARGET}
664 export CTARGET_sparc64=${CHOST_sparc64}
665 export CDEFINE_sparc64="__arch64__"
666 export LIBDIR_sparc64="lib64"
667
668 : ${MULTILIB_ABIS=sparc64 sparc32}
669 : ${DEFAULT_ABI=sparc64}
670 ;;
671 *)
672 : ${MULTILIB_ABIS=default}
673 : ${DEFAULT_ABI=default}
674 ;;
675 esac
676
677 export MULTILIB_ABIS MULTILIB_ABI
678}
679
680# @FUNCTION: multilib_toolchain_setup
681# @DESCRIPTION:
682# Hide multilib details here for packages which are forced to be compiled for a
683# specific ABI when run on another ABI (like x86-specific packages on amd64)
684multilib_toolchain_setup() {
685 local v vv
686
687 export ABI=$1
688
689 # First restore any saved state we have laying around.
690 if [[ ${__DEFAULT_ABI_SAVED} == "true" ]] ; then
691 for v in CHOST CBUILD AS CC CXX LD ; do
692 vv="__abi_saved_${v}"
693 export ${v}="${!vv}"
694 unset ${vv}
695 done
696 unset __DEFAULT_ABI_SAVED
697 fi
698
699 # We want to avoid the behind-the-back magic of gcc-config as it
700 # screws up ccache and distcc. See #196243 for more info.
701 if [[ ${ABI} != ${DEFAULT_ABI} ]] ; then
702 # Back that multilib-ass up so we can restore it later
703 for v in CHOST CBUILD AS CC CXX LD ; do
704 export __abi_saved_${v}="${!v}"
705 done
706 export __DEFAULT_ABI_SAVED="true"
707
708 # Set the CHOST native first so that we pick up the native
709 # toolchain and not a cross-compiler by accident #202811.
710 export CHOST=$(get_abi_CHOST ${DEFAULT_ABI})
711 export AS="$(tc-getAS) $(get_abi_ASFLAGS)"
712 export CC="$(tc-getCC) $(get_abi_CFLAGS)"
713 export CXX="$(tc-getCXX) $(get_abi_CFLAGS)"
714 export LD="$(tc-getLD) $(get_abi_LDFLAGS)"
715 export CHOST=$(get_abi_CHOST $1)
716 export CBUILD=$(get_abi_CHOST $1)
717 fi
718}

Legend:
Removed from v.1.28  
changed lines
  Added in v.1.82

  ViewVC Help
Powered by ViewVC 1.1.20