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

Diff of /eclass/multilib.eclass

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

Revision 1.21 Revision 1.93
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2011 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.21 2005/02/13 14:05:54 eradicator Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/multilib.eclass,v 1.93 2011/10/14 22:54:35 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
10ECLASS=multilib 13___ECLASS_RECUR_MULTILIB="yes"
11INHERITED="$INHERITED $ECLASS" 14[[ -z ${___ECLASS_RECUR_TOOLCHAIN_FUNCS} ]] && inherit toolchain-funcs
12
13DESCRIPTION="Based on the ${ECLASS} eclass"
14
15# has_multilib_profile:
16# Return true if the current profile is a multilib profile and lists more than
17# one abi in ${MULTILIB_ABIS}. You might want to use this like
18# 'use multilib || has_multilib_profile' until all profiles utilizing the
19# 'multilib' use flag are removed from portage
20
21# is_final_abi:
22# Return true if ${ABI} is the final abi to be installed (and thus we are
23# on our last run through a src_* function.
24
25# number_abis:
26# echo the number of ABIs we will be installing for
27
28# get_install_abis:
29# Return a list of the ABIs we want to install for with
30# the last one in the list being the default.
31
32# get_all_abis:
33# Return a list of the ABIs supported by this profile.
34# the last one in the list being the default.
35
36# get_all_libdirs:
37# Returns a list of all the libdirs used by this profile. This includes
38# those that might not be touched by the current ebuild and always includes
39# "lib".
40
41# get_libdir:
42# Returns the libdir for the selected ABI. This is backwards compatible
43# and simply calls get_abi_LIBDIR() on newer profiles. You should use this
44# to determine where to install shared objects (ex: /usr/$(get_libdir))
45
46# get_abi_var <VAR> [<ABI>]:
47# returns the value of ${<VAR>_<ABI>} which should be set in make.defaults
48#
49# get_abi_CFLAGS:
50# get_abi_CDEFINE:
51# get_abi_LIBDIR:
52# Aliases for 'get_abi_var CFLAGS', etc.
53
54# get_ml_incdir [<include dir> [<ABI>]]
55# include dir defaults to /usr/include
56# ABI defaults to ${ABI} or ${DEFAULT_ABI}
57#
58# If a multilib include dir is associated with the passed include dir, then
59# we return it, otherwise, we just echo back the include dir. This is
60# neccessary when a built script greps header files rather than testing them
61# via #include (like perl) to figure out features.
62
63# prep_ml_includes:
64# Some includes (include/asm, glibc, etc) are ABI dependent. In this case,
65# We can install them in different locations for each ABI and create a common
66# header which includes the right one based on CDEFINE_${ABI}. If your
67# package installs ABI-specific headers, just add 'prep_ml_includes' to the
68# end of your src_install(). It takes a list of directories that include
69# files are installed in (default is /usr/include if none are passed).
70#
71# Example:
72# src_install() {
73# ...
74# prep_ml_includes /usr/qt/3/include
75# }
76
77# create_ml_includes <include dir> <symbol 1>:<dir 1> [<symbol 2>:<dir 2> ...]
78# If you need more control than prep_ml_includes can offer (like linux-headers
79# for the asm-* dirs, then use create_ml_includes. The firs argument is the
80# common dir. The remaining args are of the form <symbol>:<dir> where
81# <symbol> is what is put in the #ifdef for choosing that dir.
82#
83# Ideas for this code came from debian's sparc-linux headers package.
84#
85# Example:
86# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64
87# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64
88
89### END DOCUMENTATION ###
90 15
91# Defaults: 16# Defaults:
92export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"} 17export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"}
93export DEFAULT_ABI=${DEFAULT_ABI:-"default"} 18export DEFAULT_ABI=${DEFAULT_ABI:-"default"}
94export ABI=${ABI:-"default"}
95export CFLAGS_default="" 19export CFLAGS_default
96export LDFLAGS_default="" 20export LDFLAGS_default
97export 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 KERNEL_ABI=${KERNEL_ABI:-${DEFAULT_ABI}}
100 25
101# has_multilib_profile() 26# @FUNCTION: has_multilib_profile
27# @DESCRIPTION:
28# Return true if the current profile is a multilib profile and lists more than
29# one abi in ${MULTILIB_ABIS}. When has_multilib_profile returns true, that
30# profile should enable the 'multilib' use flag. This is so you can DEPEND on
31# a package only for multilib or not multilib.
102has_multilib_profile() { 32has_multilib_profile() {
103 [ -n "${MULTILIB_ABIS}" -a "${MULTILIB_ABIS}" != "${MULTILIB_ABIS/ /}" ] 33 [ -n "${MULTILIB_ABIS}" -a "${MULTILIB_ABIS}" != "${MULTILIB_ABIS/ /}" ]
104} 34}
105 35
36# @FUNCTION: get_libdir
37# @RETURN: the libdir for the selected ABI
38# @DESCRIPTION:
106# This function simply returns the desired lib directory. With portage 39# This function simply returns the desired lib directory. With portage
107# 2.0.51, we now have support for installing libraries to lib32/lib64 40# 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 41# 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 42# to assume all libraries will end up in lib. Replace any (sane) instances
110# where lib is named directly with $(get_libdir) if possible. 43# where lib is named directly with $(get_libdir) if possible.
111#
112# Travis Tilley <lv@gentoo.org> (24 Aug 2004)
113# 44#
114# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004): 45# Jeremy Huddleston <eradicator@gentoo.org> (23 Dec 2004):
115# Added support for ${ABI} and ${DEFAULT_ABI}. If they're both not set, 46# 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 47# 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 48# depend on a newer version of portage (not yet released) which uses these
124 else 55 else
125 get_abi_LIBDIR 56 get_abi_LIBDIR
126 fi 57 fi
127} 58}
128 59
129get_multilibdir() { 60# @FUNCTION: get_abi_var
130 if has_multilib_profile; then 61# @USAGE: <VAR> [ABI]
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"
132 exit 1
133 fi
134 echo ${CONF_MULTILIBDIR:=lib32}
135}
136
137# 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,
139# 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
141# portage version sanity checking.
142# get_libdir_override expects one argument, the result get_libdir should
143# return:
144#
145# get_libdir_override lib64
146#
147# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
148get_libdir_override() {
149 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"
151 exit 1
152 fi
153 CONF_LIBDIR="$1"
154 CONF_LIBDIR_OVERRIDE="$1"
155 LIBDIR_default="$1"
156}
157
158# get_abi_var <VAR> [<ABI>]
159# returns the value of ${<VAR>_<ABI>} which should be set in make.defaults 62# @RETURN: returns the value of ${<VAR>_<ABI>} which should be set in make.defaults
160# 63# @INTERNAL
64# @DESCRIPTION:
161# ex: 65# ex:
162# CFLAGS=$(get_abi_var CFLAGS sparc32) # CFLAGS=-m32 66# CFLAGS=$(get_abi_var CFLAGS sparc32) # CFLAGS=-m32
163# 67#
164# Note that the prefered method is to set CC="$(tc-getCC) $(get_abi_CFLAGS)" 68# Note that the prefered method is to set CC="$(tc-getCC) $(get_abi_CFLAGS)"
165# This will hopefully be added to portage soon... 69# This will hopefully be added to portage soon...
166# 70#
167# If <ABI> is not specified, ${ABI} is used. 71# If <ABI> is not specified, ${ABI} is used.
168# If <ABI> is not specified and ${ABI} is not defined, ${DEFAULT_ABI} is used. 72# 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. 73# 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() { 74get_abi_var() {
173 local flag=${1} 75 local flag=$1
174 local abi 76 local abi
175 if [ $# -gt 1 ]; then 77 if [ $# -gt 1 ]; then
176 abi=${2} 78 abi=${2}
177 elif [ -n "${ABI}" ]; then 79 elif [ -n "${ABI}" ]; then
178 abi=${ABI} 80 abi=${ABI}
184 86
185 local var="${flag}_${abi}" 87 local var="${flag}_${abi}"
186 echo ${!var} 88 echo ${!var}
187} 89}
188 90
91# @FUNCTION: get_abi_CFLAGS
92# @USAGE: [ABI]
93# @DESCRIPTION:
94# Alias for 'get_abi_var CFLAGS'
189get_abi_CFLAGS() { get_abi_var CFLAGS "${@}"; } 95get_abi_CFLAGS() { get_abi_var CFLAGS "$@"; }
96
97# @FUNCTION: get_abi_LDFLAGS
98# @USAGE: [ABI]
99# @DESCRIPTION:
100# Alias for 'get_abi_var LDFLAGS'
190get_abi_LDFLAGS() { get_abi_var LDFLAGS "${@}"; } 101get_abi_LDFLAGS() { get_abi_var LDFLAGS "$@"; }
102
103# @FUNCTION: get_abi_CHOST
104# @USAGE: [ABI]
105# @DESCRIPTION:
106# Alias for 'get_abi_var CHOST'
191get_abi_CHOST() { get_abi_var CHOST "${@}"; } 107get_abi_CHOST() { get_abi_var CHOST "$@"; }
108
109# @FUNCTION: get_abi_CTARGET
110# @USAGE: [ABI]
111# @DESCRIPTION:
112# Alias for 'get_abi_var CTARGET'
192get_abi_CDEFINE() { get_abi_var CDEFINE "${@}"; } 113get_abi_CTARGET() { get_abi_var CTARGET "$@"; }
114
115# @FUNCTION: get_abi_FAKE_TARGETS
116# @USAGE: [ABI]
117# @DESCRIPTION:
118# Alias for 'get_abi_var FAKE_TARGETS'
119get_abi_FAKE_TARGETS() { get_abi_var FAKE_TARGETS "$@"; }
120
121# @FUNCTION: get_abi_LIBDIR
122# @USAGE: [ABI]
123# @DESCRIPTION:
124# Alias for 'get_abi_var LIBDIR'
193get_abi_LIBDIR() { get_abi_var LIBDIR "${@}"; } 125get_abi_LIBDIR() { get_abi_var LIBDIR "$@"; }
194 126
127# @FUNCTION: get_install_abis
128# @DESCRIPTION:
195# Return a list of the ABIs we want to install for with 129# Return a list of the ABIs we want to install for with
196# the last one in the list being the default. 130# the last one in the list being the default.
197get_install_abis() { 131get_install_abis() {
198 local order="" 132 local order=""
199 133
200 if [ -z "${MULTILIB_ABIS}" ]; then 134 if [[ -z ${MULTILIB_ABIS} ]] ; then
201 echo "default" 135 echo "default"
202 return 0 136 return 0
203 fi 137 fi
204 138
205 if hasq multilib-pkg-force ${RESTRICT} || 139 if [[ ${EMULTILIB_PKG} == "true" ]] ; then
206 { hasq multilib-pkg ${FEATURES} && hasq multilib-pkg ${RESTRICT}; }; then
207 for x in ${MULTILIB_ABIS}; do 140 for x in ${MULTILIB_ABIS} ; do
208 if [ "${x}" != "${DEFAULT_ABI}" ]; then 141 if [[ ${x} != "${DEFAULT_ABI}" ]] ; then
209 hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}" 142 has ${x} ${ABI_DENY} || order="${order} ${x}"
210 fi 143 fi
211 done 144 done
212 hasq ${DEFAULT_ABI} ${ABI_DENY} || order="${ordera} ${DEFAULT_ABI}" 145 has ${DEFAULT_ABI} ${ABI_DENY} || order="${order} ${DEFAULT_ABI}"
213 146
214 if [ -n "${ABI_ALLOW}" ]; then 147 if [[ -n ${ABI_ALLOW} ]] ; then
215 local ordera="" 148 local ordera=""
216 for x in ${order}; do 149 for x in ${order} ; do
217 if hasq ${x} ${ABI_ALLOW}; then 150 if has ${x} ${ABI_ALLOW} ; then
218 ordera="${ordera} ${x}" 151 ordera="${ordera} ${x}"
219 fi 152 fi
220 done 153 done
221 order="${ordera}" 154 order=${ordera}
222 fi 155 fi
223 else 156 else
224 order="${DEFAULT_ABI}" 157 order=${DEFAULT_ABI}
225 fi 158 fi
226 159
227 if [ -z "${order}" ]; then 160 if [[ -z ${order} ]] ; then
228 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." 161 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."
229 fi 162 fi
230 163
231 echo ${order} 164 echo ${order}
232 return 0 165 return 0
233} 166}
234 167
168# @FUNCTION: get_all_abis
169# @DESCRIPTION:
235# Return a list of the ABIs supported by this profile. 170# Return a list of the ABIs supported by this profile.
236# the last one in the list being the default. 171# the last one in the list being the default.
237get_all_abis() { 172get_all_abis() {
238 local order="" 173 local order=""
239 174
240 if [ -z "${MULTILIB_ABIS}" ]; then 175 if [[ -z ${MULTILIB_ABIS} ]] ; then
241 echo "default" 176 echo "default"
242 return 0 177 return 0
243 fi 178 fi
244 179
245 for x in ${MULTILIB_ABIS}; do 180 for x in ${MULTILIB_ABIS}; do
246 if [ "${x}" != "${DEFAULT_ABI}" ]; then 181 if [[ ${x} != ${DEFAULT_ABI} ]] ; then
247 order="${order:+${order }}${x}" 182 order="${order:+${order} }${x}"
248 fi 183 fi
249 done 184 done
250 order="${order:+${order} }${DEFAULT_ABI}" 185 order="${order:+${order} }${DEFAULT_ABI}"
251 186
252 echo ${order} 187 echo ${order}
253 return 0 188 return 0
254} 189}
255 190
256# get_all_libdirs() 191# @FUNCTION: get_all_libdirs
192# @DESCRIPTION:
257# Returns a list of all the libdirs used by this profile. This includes 193# Returns a list of all the libdirs used by this profile. This includes
258# those that might not be touched by the current ebuild. 194# those that might not be touched by the current ebuild and always includes
195# "lib".
259get_all_libdirs() { 196get_all_libdirs() {
260 local libdirs="lib" 197 local libdirs
261 local abi 198 local abi
262 local dir 199 local dir
263 200
264 if has_multilib_profile; then
265 for abi in ${MULTILIB_ABIS}; do 201 for abi in ${MULTILIB_ABIS}; do
266 [ "$(get_abi_LIBDIR ${abi})" != "lib" ] && libdirs="${libdirs} $(get_abi_LIBDIR ${abi})" 202 libdirs+=" $(get_abi_LIBDIR ${abi})"
267 done 203 done
268 elif [ -n "${CONF_LIBDIR}" ]; then 204 [[ " ${libdirs} " != *" lib "* ]] && libdirs+=" lib"
269 for dir in ${CONF_LIBDIR} ${CONF_MULTILIBDIR:-lib32}; do
270 [ "${dir}" != "lib" ] && libdirs="${libdirs} ${dir}"
271 done
272 fi
273 205
274 echo "${libdirs}" 206 echo "${libdirs}"
275} 207}
276 208
209# @FUNCTION: is_final_abi
210# @DESCRIPTION:
277# Return true if ${ABI} is the last ABI on our list (or if we're not 211# Return true if ${ABI} is the last ABI on our list (or if we're not
278# using the new multilib configuration. This can be used to determine 212# using the new multilib configuration. This can be used to determine
279# if we're in the last (or only) run through src_{unpack,compile,install} 213# if we're in the last (or only) run through src_{unpack,compile,install}
280is_final_abi() { 214is_final_abi() {
281 ! has_multilib_profile && return 0 215 has_multilib_profile || return 0
282 local ALL_ABIS=$(get_install_abis) 216 set -- $(get_install_abis)
283 local LAST_ABI=${ALL_ABIS/* /} 217 local LAST_ABI=$#
284 [ "${LAST_ABI}" = "${ABI}" ] 218 [[ ${!LAST_ABI} == ${ABI} ]]
285} 219}
286 220
221# @FUNCTION: number_abis
222# @DESCRIPTION:
287# echo the number of ABIs we will be installing for 223# echo the number of ABIs we will be installing for
288number_abis() { 224number_abis() {
289 get_install_abis | wc -w 225 set -- `get_install_abis`
226 echo $#
290} 227}
291 228
292# get_ml_incdir [<include dir> [<ABI>]] 229# @FUNCTION: get_libname
293# include dir defaults to /usr/include 230# @USAGE: [version]
294# ABI defaults to ${ABI} or ${DEFAULT_ABI} 231# @DESCRIPTION:
295get_ml_incdir() { 232# Returns libname with proper suffix {.so,.dylib,.dll,etc} and optionally
296 local dir=/usr/include 233# supplied version for the current platform identified by CHOST.
297
298 if [[ ${#} -gt 0 ]]; then
299 incdir=${1}
300 shift
301 fi
302
303 if [[ -z "${MULTILIB_ABIS}" ]]; then
304 echo ${incdir}
305 return 0
306 fi
307
308 local abi=${ABI:-${DEFAULT_ABI}}
309 if [[ ${#} -gt 0 ]]; then
310 abi=${1}
311 shift
312 fi
313
314 if [[ -d "${dir}/gentoo-multilib/${abi}" ]]; then
315 echo ${dir}/gentoo-multilib/${abi}
316 else
317 echo ${dir}
318 fi
319}
320
321# prep_ml_includes:
322#
323# Some includes (include/asm, glibc, etc) are ABI dependent. In this case,
324# We can install them in different locations for each ABI and create a common
325# header which includes the right one based on CDEFINE_${ABI}. If your
326# package installs ABI-specific headers, just add 'prep_ml_includes' to the
327# end of your src_install(). It takes a list of directories that include
328# files are installed in (default is /usr/include if none are passed).
329# 234#
330# Example: 235# Example:
331# src_install() { 236# get_libname ${PV}
332# ... 237# Returns: .so.${PV} (ELF) || .${PV}.dylib (MACH) || ...
333# prep_ml_includes /usr/qt/3/include 238get_libname() {
334# }
335
336prep_ml_includes() {
337 if [ $(number_abis) -gt 1 ]; then
338 local dir
339 local dirs
340 local base 239 local libname
240 local ver=$1
241 case ${CHOST} in
242 *-cygwin|mingw*|*-mingw*) libname="dll";;
243 *-darwin*) libname="dylib";;
244 *-mint*) libname="irrelevant";;
245 hppa*-hpux*) libname="sl";;
246 *) libname="so";;
247 esac
341 248
342 if [ ${#} -eq 0 ]; then 249 if [[ -z $* ]] ; then
343 dirs="/usr/include" 250 echo ".${libname}"
344 else 251 else
345 dirs="${@}" 252 for ver in "$@" ; do
346 fi 253 case ${CHOST} in
347 254 *-darwin*) echo ".${ver}.${libname}";;
348 for dir in ${dirs}; do 255 *-mint*) echo ".${libname}";;
349 base=${T}/gentoo-multilib/${dir}/gentoo-multilib 256 *) echo ".${libname}.${ver}";;
350 mkdir -p ${base} 257 esac
351 [ -d ${base}/${ABI} ] && rm -rf ${base}/${ABI}
352 mv ${D}/${dir} ${base}/${ABI}
353 done 258 done
354
355 if is_final_abi; then
356 base=${T}/gentoo-multilib
357 pushd ${base}
358 find . | tar -c -T - -f - | tar -x --no-same-owner -f - -C ${D}
359 popd
360
361 for dir in ${dirs}; do
362 local args=${dir}
363 local abi
364 for abi in $(get_install_abis); do
365 args="${args} $(get_abi_CDEFINE ${abi}):${dir}/gentoo-multilib/${abi}"
366 done
367 create_ml_includes ${args}
368 done
369 fi 259 fi
370 fi
371} 260}
372 261
373# If you need more control than prep_ml_includes can offer (like linux-headers 262# @FUNCTION: get_modname
374# for the asm-* dirs, then use create_ml_includes. The firs argument is the 263# @USAGE:
375# common dir. The remaining args are of the form <symbol>:<dir> where 264# @DESCRIPTION:
376# <symbol> is what is put in the #ifdef for choosing that dir. 265# Returns modulename with proper suffix {.so,.bundle,etc} for the current
377# 266# platform identified by CHOST.
378# Ideas for this code came from debian's sparc-linux headers package.
379# 267#
380# Example: 268# Example:
381# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64 269# libfoo$(get_modname)
382# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64 270# Returns: libfoo.so (ELF) || libfoo.bundle (MACH) || ...
383create_ml_includes() { 271get_modname() {
384 local dest="${1}" 272 local modname
385 shift 273 local ver=$1
386 local mlinfo="${@}" 274 case ${CHOST} in
387 local basedirs=$(create_ml_includes-listdirs ${mlinfo}) 275 *-darwin*) modname="bundle";;
276 *) modname="so";;
277 esac
388 278
389 create_ml_includes-makedestdirs ${dest} ${basedirs} 279 echo ".${modname}"
280}
390 281
391 local file 282# This is for the toolchain to setup profile variables when pulling in
392 for file in $(create_ml_includes-allfiles ${basedirs}); do 283# a crosscompiler (and thus they aren't set in the profile)
393 local name="$(echo $file | tr a-z A-Z | sed 's:[^A-Z]:_:g')" 284multilib_env() {
394 { 285 local CTARGET=${1:-${CTARGET}}
395 echo "/* Common header file autogenerated by create_ml_includes in multilib.eclass */"
396 #echo "#ifndef __CREATE_ML_INCLUDES_STUB_${name}__"
397 #echo "#define __CREATE_ML_INCLUDES_STUB_${name}__"
398 #echo ""
399 286
400 local dir 287 case ${CTARGET} in
401 for dir in ${basedirs}; do 288 x86_64*)
402 if [ -f "${D}/${dir}/${file}" ]; then 289 export CFLAGS_x86=${CFLAGS_x86--m32}
403 echo "#ifdef $(create_ml_includes-sym_for_dir ${dir} ${mlinfo})" 290 export CHOST_x86=${CTARGET/x86_64/i686}
404 echo "#include \"$(create_ml_includes-relative_between ${dest}/$(dirname ${file}) ${dir}/${file})\"" 291 export CTARGET_x86=${CHOST_x86}
405 echo "#endif /* $(create_ml_includes-sym_for_dir ${dir} ${mlinfo}) */" 292 if [[ ${SYMLINK_LIB} == "yes" ]] ; then
406 echo "" 293 export LIBDIR_x86="lib32"
294 else
295 export LIBDIR_x86="lib"
407 fi 296 fi
408 done
409 297
410 #echo "#endif /* __CREATE_ML_INCLUDES_STUB_${name}__ */" 298 export CFLAGS_amd64=${CFLAGS_amd64--m64}
411 } > ${D}/${dest}/${file} 299 export CHOST_amd64=${CTARGET}
412 done 300 export CTARGET_amd64=${CHOST_amd64}
413} 301 export LIBDIR_amd64="lib64"
414 302
415# Helper function for create_ml_includes 303 export CFLAGS_x32=${CFLAGS_x32--mx32}
416create_ml_includes-relative_between() { 304 export CHOST_x32=${CTARGET}
417 local src="$(create_ml_includes-tidy_path ${1})" 305 export CTARGET_x32=${CHOST_x32}
418 local dst="$(create_ml_includes-tidy_path ${2})" 306 export LIBDIR_x32="libx32"
419 307
420 src=(${src//\// }) 308 : ${MULTILIB_ABIS=amd64 x86}
421 dst=(${dst//\// }) 309 : ${DEFAULT_ABI=amd64}
310 ;;
311 mips64*)
312 export CFLAGS_o32=${CFLAGS_o32--mabi=32}
313 export CHOST_o32=${CTARGET/mips64/mips}
314 export CTARGET_o32=${CHOST_o32}
315 export LIBDIR_o32="lib"
422 316
423 local i 317 export CFLAGS_n32=${CFLAGS_n32--mabi=n32}
424 for ((i=0; i<${#src[*]}; i++)); do 318 export CHOST_n32=${CTARGET}
425 [ "${dst[i]}" != "${src[i]}" ] && break 319 export CTARGET_n32=${CHOST_n32}
426 done 320 export LIBDIR_n32="lib32"
427 321
428 local common=$i 322 export CFLAGS_n64=${CFLAGS_n64--mabi=64}
323 export CHOST_n64=${CTARGET}
324 export CTARGET_n64=${CHOST_n64}
325 export LIBDIR_n64="lib64"
429 326
430 for ((i=${#src[*]}; i>common; i--)); do 327 : ${MULTILIB_ABIS=n64 n32 o32}
431 echo -n ../ 328 : ${DEFAULT_ABI=n32}
432 done 329 ;;
330 powerpc64*)
331 export CFLAGS_ppc=${CFLAGS_ppc--m32}
332 export CHOST_ppc=${CTARGET/powerpc64/powerpc}
333 export CTARGET_ppc=${CHOST_ppc}
334 export LIBDIR_ppc="lib"
433 335
434 for ((i=common; i<${#dst[*]}-1; i++)); do 336 export CFLAGS_ppc64=${CFLAGS_ppc64--m64}
435 echo -n ${dst[i]}/ 337 export CHOST_ppc64=${CTARGET}
436 done 338 export CTARGET_ppc64=${CHOST_ppc64}
339 export LIBDIR_ppc64="lib64"
437 340
438 echo -n ${dst[i]} 341 : ${MULTILIB_ABIS=ppc64 ppc}
439} 342 : ${DEFAULT_ABI=ppc64}
343 ;;
344 s390x*)
345 export CFLAGS_s390=${CFLAGS_s390--m31} # the 31 is not a typo
346 export CHOST_s390=${CTARGET/s390x/s390}
347 export CTARGET_s390=${CHOST_s390}
348 export LIBDIR_s390="lib"
440 349
441# Helper function for create_ml_includes 350 export CFLAGS_s390x=${CFLAGS_s390x--m64}
442create_ml_includes-tidy_path() { 351 export CHOST_s390x=${CTARGET}
443 local removed="${1}" 352 export CTARGET_s390x=${CHOST_s390x}
353 export LIBDIR_s390x="lib64"
444 354
445 if [ -n "${removed}" ]; then 355 : ${MULTILIB_ABIS=s390x s390}
446 # Remove multiple slashes 356 : ${DEFAULT_ABI=s390x}
447 while [ "${removed}" != "${removed/\/\//\/}" ]; do 357 ;;
448 removed=${removed/\/\//\/} 358 sparc*)
359 export CFLAGS_sparc32=${CFLAGS_sparc32}
360 export CHOST_sparc32=${CTARGET/sparc64/sparc}
361 export CTARGET_sparc32=${CHOST_sparc32}
362 export LIBDIR_sparc32="lib"
363
364 export CFLAGS_sparc64=${CFLAGS_sparc64--m64}
365 export CHOST_sparc64=${CTARGET}
366 export CTARGET_sparc64=${CHOST_sparc64}
367 export LIBDIR_sparc64="lib64"
368
369 : ${MULTILIB_ABIS=sparc64 sparc32}
370 : ${DEFAULT_ABI=sparc64}
371 ;;
372 *)
373 : ${MULTILIB_ABIS=default}
374 : ${DEFAULT_ABI=default}
375 ;;
376 esac
377
378 export MULTILIB_ABIS DEFAULT_ABI
379}
380
381# @FUNCTION: multilib_toolchain_setup
382# @DESCRIPTION:
383# Hide multilib details here for packages which are forced to be compiled for a
384# specific ABI when run on another ABI (like x86-specific packages on amd64)
385multilib_toolchain_setup() {
386 local v vv
387
388 export ABI=$1
389
390 # First restore any saved state we have laying around.
391 if [[ ${__DEFAULT_ABI_SAVED} == "true" ]] ; then
392 for v in CHOST CBUILD AS CC CXX LD ; do
393 vv="__abi_saved_${v}"
394 export ${v}="${!vv}"
395 unset ${vv}
449 done 396 done
397 unset __DEFAULT_ABI_SAVED
398 fi
450 399
451 # Remove . directories 400 # We want to avoid the behind-the-back magic of gcc-config as it
452 while [ "${removed}" != "${removed//\/.\//\/}" ]; do 401 # screws up ccache and distcc. See #196243 for more info.
453 removed=${removed//\/.\//\/} 402 if [[ ${ABI} != ${DEFAULT_ABI} ]] ; then
403 # Back that multilib-ass up so we can restore it later
404 for v in CHOST CBUILD AS CC CXX LD ; do
405 export __abi_saved_${v}="${!v}"
454 done 406 done
455 [ "${removed##*/}" = "." ] && removed=${removed%/*} 407 export __DEFAULT_ABI_SAVED="true"
456 408
457 # Removed .. directories 409 # Set the CHOST native first so that we pick up the native
458 while [ "${removed}" != "${removed//\/..\/}" ]; do 410 # toolchain and not a cross-compiler by accident #202811.
459 local p1="${removed%%\/..\/*}" 411 export CHOST=$(get_abi_CHOST ${DEFAULT_ABI})
460 local p2="${removed#*\/..\/}" 412 export AS="$(tc-getAS) $(get_abi_ASFLAGS)"
461 413 export CC="$(tc-getCC) $(get_abi_CFLAGS)"
462 removed="${p1%\/*}/${p2}" 414 export CXX="$(tc-getCXX) $(get_abi_CFLAGS)"
463 done 415 export LD="$(tc-getLD) $(get_abi_LDFLAGS)"
464 416 export CHOST=$(get_abi_CHOST $1)
465 # Remove trailing .. 417 export CBUILD=$(get_abi_CHOST $1)
466 [ "${removed##*/}" = ".." ] && removed=${removed%/*/*}
467
468 # Remove trailing /
469 [ "${removed##*/}" = "" ] && removed=${removed%/*}
470
471 echo ${removed}
472 fi
473}
474
475# Helper function for create_ml_includes
476create_ml_includes-listdirs() {
477 local dirs
478 local data
479 for data in ${@}; do
480 dirs="${dirs} ${data/*:/}"
481 done
482 echo ${dirs:1}
483}
484
485# Helper function for create_ml_includes
486create_ml_includes-makedestdirs() {
487 local dest=${1}
488 shift
489 local basedirs=${@}
490
491 dodir ${dest}
492
493 local basedir
494 for basedir in ${basedirs}; do
495 local dir
496 for dir in $(find ${D}/${basedir} -type d); do
497 dodir ${dest}/${dir/${D}\/${basedir}/}
498 done
499 done
500}
501
502# Helper function for create_ml_includes
503create_ml_includes-allfiles() {
504 local basedirs=${@}
505
506 local basedir
507 for basedir in ${basedirs}; do
508 local file
509 for file in $(find ${D}/${basedir} -type f); do
510 echo ${file/${D}\/${basedir}\//}
511 done
512 done | sort | uniq
513}
514
515# Helper function for create_ml_includes
516create_ml_includes-sym_for_dir() {
517 local dir="${1}"
518 shift
519 local data
520 for data in ${@}; do
521 if [ "${dir}" = "${data/*:/}" ]; then
522 echo ${data/:*/}
523 return 0
524 fi 418 fi
525 done
526 echo "Shouldn't be here -- create_ml_includes-sym_for_dir ${1} ${@}"
527 # exit because we'll likely be called from a subshell
528 exit 1
529} 419}

Legend:
Removed from v.1.21  
changed lines
  Added in v.1.93

  ViewVC Help
Powered by ViewVC 1.1.20