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

Diff of /eclass/multilib.eclass

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

Revision 1.27 Revision 1.32
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2004 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.27 2005/04/12 19:52:21 eradicator Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/multilib.eclass,v 1.32 2005/08/22 16:20:30 swegener Exp $
4# 4#
5# Author: Jeremy Huddleston <eradicator@gentoo.org> 5# Author: Jeremy Huddleston <eradicator@gentoo.org>
6# 6#
7# This eclass is for all functions pertaining to handling multilib. 7# This eclass is for all functions pertaining to handling multilib.
8# configurations. 8# configurations.
9 9
10ECLASS=multilib
11INHERITED="$INHERITED $ECLASS"
12 10
13DESCRIPTION="Based on the ${ECLASS} eclass" 11DESCRIPTION="Based on the ${ECLASS} eclass"
14 12
15# has_multilib_profile: 13# has_multilib_profile:
16# Return true if the current profile is a multilib profile and lists more than 14# Return true if the current profile is a multilib profile and lists more than
83# Ideas for this code came from debian's sparc-linux headers package. 81# Ideas for this code came from debian's sparc-linux headers package.
84# 82#
85# Example: 83# Example:
86# create_ml_includes /usr/include/asm __sparc__:/usr/include/asm-sparc __sparc64__:/usr/include/asm-sparc64 84# 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 85# create_ml_includes /usr/include/asm __i386__:/usr/include/asm-i386 __x86_64__:/usr/include/asm-x86_64
86
87# get_libname [version]
88# returns libname with proper suffix {.so,.dylib} and optionally supplied version
89# for ELF/MACH-O shared objects
90#
91# Example:
92# get_libname libfoo ${PV}
93# Returns: libfoo.so.${PV} (ELF) || libfoo.${PV}.dylib (MACH)
88 94
89### END DOCUMENTATION ### 95### END DOCUMENTATION ###
90 96
91# Defaults: 97# Defaults:
92export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"} 98export MULTILIB_ABIS=${MULTILIB_ABIS:-"default"}
192get_abi_CHOST() { get_abi_var CHOST "${@}"; } 198get_abi_CHOST() { get_abi_var CHOST "${@}"; }
193get_abi_FAKE_TARGETS() { get_abi_var FAKE_TARGETS "${@}"; } 199get_abi_FAKE_TARGETS() { get_abi_var FAKE_TARGETS "${@}"; }
194get_abi_CDEFINE() { get_abi_var CDEFINE "${@}"; } 200get_abi_CDEFINE() { get_abi_var CDEFINE "${@}"; }
195get_abi_LIBDIR() { get_abi_var LIBDIR "${@}"; } 201get_abi_LIBDIR() { get_abi_var LIBDIR "${@}"; }
196 202
197# Return a list of the ABIs we want to install for with 203# Return a list of the ABIs we want to install for with
198# the last one in the list being the default. 204# the last one in the list being the default.
199get_install_abis() { 205get_install_abis() {
200 local order="" 206 local order=""
201 207
202 if [ -z "${MULTILIB_ABIS}" ]; then 208 if [ -z "${MULTILIB_ABIS}" ]; then
203 echo "default" 209 echo "default"
204 return 0 210 return 0
205 fi 211 fi
206 212
207 if hasq multilib-pkg-force ${RESTRICT} || 213 if hasq multilib-pkg-force ${RESTRICT} ||
208 { hasq multilib-pkg ${FEATURES} && hasq multilib-pkg ${RESTRICT}; }; then 214 { hasq multilib-pkg ${FEATURES} && hasq multilib-pkg ${RESTRICT}; }; then
209 for x in ${MULTILIB_ABIS}; do 215 for x in ${MULTILIB_ABIS}; do
210 if [ "${x}" != "${DEFAULT_ABI}" ]; then 216 if [ "${x}" != "${DEFAULT_ABI}" ]; then
211 hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}" 217 hasq ${x} ${ABI_DENY} || ordera="${ordera} ${x}"
212 fi 218 fi
463 # Remove trailing .. 469 # Remove trailing ..
464 [ "${removed##*/}" = ".." ] && removed=${removed%/*/*} 470 [ "${removed##*/}" = ".." ] && removed=${removed%/*/*}
465 471
466 # Remove trailing / 472 # Remove trailing /
467 [ "${removed##*/}" = "" ] && removed=${removed%/*} 473 [ "${removed##*/}" = "" ] && removed=${removed%/*}
468 474
469 echo ${removed} 475 echo ${removed}
470 fi 476 fi
471} 477}
472 478
473# Helper function for create_ml_includes 479# Helper function for create_ml_includes
523 done 529 done
524 echo "Shouldn't be here -- create_ml_includes-sym_for_dir ${1} ${@}" 530 echo "Shouldn't be here -- create_ml_includes-sym_for_dir ${1} ${@}"
525 # exit because we'll likely be called from a subshell 531 # exit because we'll likely be called from a subshell
526 exit 1 532 exit 1
527} 533}
534
535get_libname() {
536 local ver=$1
537 if use userland_Darwin ; then
538 if [ -z ${ver} ] ; then
539 echo ".dylib"
540 else
541 echo ".${ver}.dylib"
542 fi
543 else
544 if [ -z ${ver} ] ; then
545 echo ".so"
546 else
547 echo ".so.${ver}"
548 fi
549 fi
550}
551

Legend:
Removed from v.1.27  
changed lines
  Added in v.1.32

  ViewVC Help
Powered by ViewVC 1.1.20