diff options
author | 2012-10-08 18:44:30 +0000 | |
---|---|---|
committer | 2012-10-08 18:44:30 +0000 | |
commit | 7aef0335c9261a1e88252a34a3ac5e2893a50f4e (patch) | |
tree | a7af654213e3f09fc6bdafa181d8bf2da64a9023 /eclass/autotools-multilib.eclass | |
parent | Add in IPv6 and Kerberos support from uw-imap. (diff) | |
download | gentoo-2-7aef0335c9261a1e88252a34a3ac5e2893a50f4e.tar.gz gentoo-2-7aef0335c9261a1e88252a34a3ac5e2893a50f4e.tar.bz2 gentoo-2-7aef0335c9261a1e88252a34a3ac5e2893a50f4e.zip |
Introduce autotools-multilib, to simplify building multilib packages with autotools-utils.
Diffstat (limited to 'eclass/autotools-multilib.eclass')
-rw-r--r-- | eclass/autotools-multilib.eclass | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/eclass/autotools-multilib.eclass b/eclass/autotools-multilib.eclass new file mode 100644 index 000000000000..f6d1feb3051c --- /dev/null +++ b/eclass/autotools-multilib.eclass @@ -0,0 +1,72 @@ +# Copyright 1999-2012 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/eclass/autotools-multilib.eclass,v 1.1 2012/10/08 18:44:30 mgorny Exp $ + +# @ECLASS: autotools-multilib.eclass +# @MAINTAINER: +# Michał Górny <mgorny@gentoo.org> +# @BLURB: autotools-utils wrapper for multilib builds +# @DESCRIPTION: +# The autotools-multilib.eclass is an autotools-utils.eclass(5) wrapper +# introducing support for building for more than one ABI (multilib). +# +# Inheriting this eclass sets IUSE=multilib and exports autotools-utils +# phase function wrappers which build the package for each supported ABI +# if the flag is enabled. Otherwise, it works like regular +# autotools-utils. +# +# Note that the multilib support requires out-of-source builds to be +# enabled. Thus, it is impossible to use AUTOTOOLS_IN_SOURCE_BUILD with +# it. + +case ${EAPI:-0} in + 2|3|4) ;; + *) die "EAPI=${EAPI} is not supported" ;; +esac + +if [[ ${AUTOTOOLS_IN_SOURCE_BUILD} ]]; then + die "${ECLASS}: multilib support requires out-of-source builds." +fi + +inherit autotools-utils multilib + +EXPORT_FUNCTIONS src_configure src_compile src_test src_install + +IUSE=multilib + +# @FUNCTION: autotools-multilib_foreach_abi +# @USAGE: argv... +# @DESCRIPTION: +# If multilib support is enabled, sets the toolchain up for each +# supported ABI along with the ABI variable and correct +# AUTOTOOLS_BUILD_DIR, and runs the given commands with them. +# +# If multilib support is disabled, it just runs the commands. No setup +# is done. +autotools-multilib_foreach_abi() { + if use multilib; then + local ABI + for ABI in $(get_all_abis); do + multilib_toolchain_setup "${ABI}" + AUTOTOOLS_BUILD_DIR=${S%%/}-${ABI} "${@}" + done + else + "${@}" + fi +} + +autotools-multilib_src_configure() { + autotools-multilib_foreach_abi autotools-utils_src_configure +} + +autotools-multilib_src_compile() { + autotools-multilib_foreach_abi autotools-utils_src_compile +} + +autotools-multilib_src_test() { + autotools-multilib_foreach_abi autotools-utils_src_test +} + +autotools-multilib_src_install() { + autotools-multilib_foreach_abi autotools-utils_src_install +} |