/[gentoo-x86]/eclass/autotools-utils.eclass
Gentoo

Diff of /eclass/autotools-utils.eclass

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

Revision 1.21 Revision 1.29
1# Copyright 1999-2010 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/autotools-utils.eclass,v 1.21 2011/09/18 07:57:34 mgorny Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/autotools-utils.eclass,v 1.29 2011/11/27 09:57:20 mgorny Exp $
4 4
5# @ECLASS: autotools-utils.eclass 5# @ECLASS: autotools-utils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Maciej Mrozowski <reavertm@gentoo.org> 7# Maciej Mrozowski <reavertm@gentoo.org>
8# Michał Górny <mgorny@gentoo.org> 8# Michał Górny <mgorny@gentoo.org>
9# @BLURB: common ebuild functions for autotools-based packages 9# @BLURB: common ebuild functions for autotools-based packages
10# @DESCRIPTION: 10# @DESCRIPTION:
11# autotools-utils.eclass is autotools.eclass(5) and base.eclass(5) wrapper 11# autotools-utils.eclass is autotools.eclass(5) and base.eclass(5) wrapper
12# providing all inherited features along with econf arguments as Bash array, 12# providing all inherited features along with econf arguments as Bash array,
13# out of source build with overridable build dir location, static archives 13# out of source build with overridable build dir location, static archives
14# handling, libtool files removal, enable/disable debug handling. 14# handling, libtool files removal.
15#
16# Please note note that autotools-utils does not support mixing of its phase
17# functions with regular econf/emake calls. If necessary, please call
18# autotools-utils_src_compile instead of the latter.
15# 19#
16# @EXAMPLE: 20# @EXAMPLE:
17# Typical ebuild using autotools-utils.eclass: 21# Typical ebuild using autotools-utils.eclass:
18# 22#
19# @CODE 23# @CODE
56# "${FILESDIR}/${P}-unbundle_libpng.patch" 60# "${FILESDIR}/${P}-unbundle_libpng.patch"
57# ) 61# )
58# 62#
59# src_configure() { 63# src_configure() {
60# local myeconfargs=( 64# local myeconfargs=(
65# $(use_enable debug)
61# $(use_with qt4) 66# $(use_with qt4)
62# $(use_enable threads multithreading) 67# $(use_enable threads multithreading)
63# $(use_with tiff) 68# $(use_with tiff)
64# ) 69# )
65# autotools-utils_src_configure 70# autotools-utils_src_configure
86case ${EAPI:-0} in 91case ${EAPI:-0} in
87 2|3|4) ;; 92 2|3|4) ;;
88 *) die "EAPI=${EAPI} is not supported" ;; 93 *) die "EAPI=${EAPI} is not supported" ;;
89esac 94esac
90 95
91inherit autotools base eutils 96inherit autotools base eutils libtool
92 97
93EXPORT_FUNCTIONS src_prepare src_configure src_compile src_install src_test 98EXPORT_FUNCTIONS src_prepare src_configure src_compile src_install src_test
94 99
95# @ECLASS-VARIABLE: AUTOTOOLS_BUILD_DIR 100# @ECLASS-VARIABLE: AUTOTOOLS_BUILD_DIR
96# @DESCRIPTION: 101# @DESCRIPTION:
198 if [[ ${removing} ]]; then 203 if [[ ${removing} ]]; then
199 einfo "Removing unnecessary ${f#${D%/}} (${removing})" 204 einfo "Removing unnecessary ${f#${D%/}} (${removing})"
200 rm -f "${f}" || die 205 rm -f "${f}" || die
201 fi 206 fi
202 done 207 done
208
209 # check for invalid eclass use
210 # this is the most commonly used function, so do it here
211 _check_build_dir
212 if [[ ! -d "${AUTOTOOLS_BUILD_DIR}" ]]; then
213 eqawarn "autotools-utils used but autotools-utils_src_configure was never called."
214 eqawarn "This is not supported and never was. Please report a bug against"
215 eqawarn "the offending ebuild. This will become a fatal error in a near future."
216 fi
203} 217}
204 218
205# @FUNCTION: autotools-utils_src_prepare 219# @FUNCTION: autotools-utils_src_prepare
206# @DESCRIPTION: 220# @DESCRIPTION:
207# The src_prepare function. 221# The src_prepare function.
209# Supporting PATCHES array and user patches. See base.eclass(5) for reference. 223# Supporting PATCHES array and user patches. See base.eclass(5) for reference.
210autotools-utils_src_prepare() { 224autotools-utils_src_prepare() {
211 debug-print-function ${FUNCNAME} "$@" 225 debug-print-function ${FUNCNAME} "$@"
212 226
213 base_src_prepare 227 base_src_prepare
228 elibtoolize --patch-only
214} 229}
215 230
216# @FUNCTION: autotools-utils_src_configure 231# @FUNCTION: autotools-utils_src_configure
217# @DESCRIPTION: 232# @DESCRIPTION:
218# The src_configure function. For out of source build it creates build 233# The src_configure function. For out of source build it creates build
223# IUSE="static-libs" passes --enable-shared and either --disable-static/--enable-static 238# IUSE="static-libs" passes --enable-shared and either --disable-static/--enable-static
224# to econf respectively. 239# to econf respectively.
225autotools-utils_src_configure() { 240autotools-utils_src_configure() {
226 debug-print-function ${FUNCNAME} "$@" 241 debug-print-function ${FUNCNAME} "$@"
227 242
243 [[ -z ${myeconfargs+1} || $(declare -p myeconfargs) == 'declare -a'* ]] \
244 || die 'autotools-utils.eclass: myeconfargs has to be an array.'
245
228 # Common args 246 # Common args
229 local econfargs=() 247 local econfargs=()
230 248
231 # Handle debug found in IUSE
232 if has debug ${IUSE//+}; then
233 local debugarg=$(use_enable debug)
234 if ! has "${debugarg}" "${myeconfargs[@]}"; then
235 eqawarn 'Implicit $(use_enable debug) for IUSE="debug" is no longer supported.'
236 eqawarn 'Please add the necessary arg to myeconfargs if requested.'
237 eqawarn 'The autotools-utils eclass will stop warning about it on Oct 15th.'
238 fi
239 fi
240
241 # Handle static-libs found in IUSE, disable them by default 249 # Handle static-libs found in IUSE, disable them by default
242 if has static-libs ${IUSE//+}; then 250 if in_iuse static-libs; then
243 econfargs+=( 251 econfargs+=(
244 --enable-shared 252 --enable-shared
245 $(use_enable static-libs static) 253 $(use_enable static-libs static)
246 ) 254 )
247 fi 255 fi

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

  ViewVC Help
Powered by ViewVC 1.1.20