summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichał Górny <mgorny@gentoo.org>2014-05-09 10:48:59 +0000
committerMichał Górny <mgorny@gentoo.org>2014-05-09 10:48:59 +0000
commitef53e493751b6311204342626fd4c1bb9fa0e5df (patch)
tree1cc1da0af3f157ad7e8764072a521ecc5b9258eb /eclass/cmake-multilib.eclass
parentStable for amd64 wrt bug #505912 (diff)
downloadgentoo-2-ef53e493751b6311204342626fd4c1bb9fa0e5df.tar.gz
gentoo-2-ef53e493751b6311204342626fd4c1bb9fa0e5df.tar.bz2
gentoo-2-ef53e493751b6311204342626fd4c1bb9fa0e5df.zip
Use multilib-minimal for phase functions.
Diffstat (limited to 'eclass/cmake-multilib.eclass')
-rw-r--r--eclass/cmake-multilib.eclass58
1 files changed, 36 insertions, 22 deletions
diff --git a/eclass/cmake-multilib.eclass b/eclass/cmake-multilib.eclass
index e7c9059e396b..7bdab6081ec1 100644
--- a/eclass/cmake-multilib.eclass
+++ b/eclass/cmake-multilib.eclass
@@ -1,6 +1,6 @@
# Copyright 1999-2014 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-multilib.eclass,v 1.6 2014/04/29 20:54:54 mgorny Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-multilib.eclass,v 1.7 2014/05/09 10:48:59 mgorny Exp $
# @ECLASS: cmake-multilib.eclass
# @MAINTAINER:
@@ -9,16 +9,15 @@
# Author: Michał Górny <mgorny@gentoo.org>
# @BLURB: cmake-utils wrapper for multilib builds
# @DESCRIPTION:
-# The cmake-multilib.eclass is a cmake-utils.eclass(5) wrapper
-# introducing support for building for more than one ABI (multilib).
+# The cmake-multilib.eclass provides a glue between cmake-utils.eclass(5)
+# and multilib-minimal.eclass(5), aiming to provide a convenient way
+# to build packages using cmake for multiple ABIs.
#
-# Inheriting this eclass sets IUSE and exports cmake-utils phase
-# function wrappers which build the package for each supported ABI
-# if the appropriate flag is enabled.
-#
-# Note that the multilib support requires out-of-source builds to be
-# enabled. Thus, it is impossible to use CMAKE_IN_SOURCE_BUILD with
-# it.
+# Inheriting this eclass sets IUSE and exports default multilib_src_*()
+# sub-phases that call cmake-utils phase functions for each ABI enabled.
+# The multilib_src_*() functions can be defined in ebuild just like
+# in multilib-minimal, yet they ought to call appropriate cmake-utils
+# phase rather than 'default'.
# EAPI=5 is required for meaningful MULTILIB_USEDEP.
case ${EAPI:-0} in
@@ -30,31 +29,46 @@ if [[ ${CMAKE_IN_SOURCE_BUILD} ]]; then
die "${ECLASS}: multilib support requires out-of-source builds."
fi
-inherit cmake-utils multilib-build
+inherit cmake-utils multilib-minimal
EXPORT_FUNCTIONS src_configure src_compile src_test src_install
cmake-multilib_src_configure() {
- multilib_parallel_foreach_abi cmake-utils_src_configure "${@}"
+ local _cmake_args=( "${@}" )
+
+ multilib-minimal_src_configure
+}
+
+multilib_src_configure() {
+ cmake-utils_src_configure "${_cmake_args[@]}"
}
cmake-multilib_src_compile() {
- multilib_foreach_abi cmake-utils_src_compile "${@}"
+ local _cmake_args=( "${@}" )
+
+ multilib-minimal_src_compile
+}
+
+multilib_src_compile() {
+ cmake-utils_src_compile "${_cmake_args[@]}"
}
cmake-multilib_src_test() {
- multilib_foreach_abi cmake-utils_src_test "${@}"
+ local _cmake_args=( "${@}" )
+
+ multilib-minimal_src_test
+}
+
+multilib_src_test() {
+ cmake-utils_src_test "${_cmake_args[@]}"
}
cmake-multilib_src_install() {
- cmake-multilib_secure_install() {
- cmake-utils_src_install "${@}"
+ local _cmake_args=( "${@}" )
- multilib_prepare_wrappers
- # Make sure all headers are the same for each ABI.
- multilib_check_headers
- }
+ multilib-minimal_src_install
+}
- multilib_foreach_abi cmake-multilib_secure_install "${@}"
- multilib_install_wrappers
+multilib_src_install() {
+ cmake-utils_src_install "${_cmake_args[@]}"
}