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

Diff of /eclass/autotools.eclass

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

Revision 1.46 Revision 1.66
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2007 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.eclass,v 1.46 2006/09/23 19:43:07 flameeyes Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/autotools.eclass,v 1.66 2007/05/30 15:45:01 cardoe Exp $
4# 4#
5# Author: Diego Pettenò <flameeyes@gentoo.org> 5# Maintainer: base-system@gentoo.org
6# Enhancements: Martin Schlemmer <azarah@gentoo.org>
7# 6#
8# This eclass is for handling autotooled software packages that 7# This eclass is for handling autotooled software packages that
9# needs to regenerate their build scripts. 8# needs to regenerate their build scripts.
10# 9#
11# NB: If you add anything, please comment it! 10# NB: If you add anything, please comment it!
12 11
13inherit eutils libtool 12inherit eutils libtool
14 13
15[[ ${WANT_AUTOMAKE} == "latest" ]] && export WANT_AUTOMAKE=1.9 14[[ -z ${WANT_AUTOCONF} ]] && WANT_AUTOCONF="latest"
16[[ ${WANT_AUTOCONF} == "latest" ]] && export WANT_AUTOCONF=2.5 15[[ -z ${WANT_AUTOMAKE} ]] && WANT_AUTOMAKE="latest"
17 16
18_automake_atom="sys-devel/automake" 17_automake_atom="sys-devel/automake"
19_autoconf_atom="sys-devel/autoconf" 18_autoconf_atom="sys-devel/autoconf"
19if [[ -n ${WANT_AUTOMAKE} ]]; then
20 case ${WANT_AUTOMAKE} in
21 # workaround while we have different versions of automake in arch and ~arch
22 none) _automake_atom="" ;; # some packages don't require automake at all
23 latest) _automake_atom="=sys-devel/automake-1.10*" ;;
20[[ -n ${WANT_AUTOMAKE} ]] && _automake_atom="=sys-devel/automake-${WANT_AUTOMAKE}*" 24 *) _automake_atom="=sys-devel/automake-${WANT_AUTOMAKE}*" ;;
25 esac
26 [[ ${WANT_AUTOMAKE} == "latest" ]] && WANT_AUTOMAKE="1.10"
27 export WANT_AUTOMAKE
28fi
29
21if [[ -n ${WANT_AUTOCONF} ]] ; then 30if [[ -n ${WANT_AUTOCONF} ]] ; then
22 case ${WANT_AUTOCONF} in 31 case ${WANT_AUTOCONF} in
23 2.1) _autoconf_atom="=sys-devel/autoconf-${WANT_AUTOCONF}*" ;; 32 2.1) _autoconf_atom="=sys-devel/autoconf-${WANT_AUTOCONF}*" ;;
24 2.5) _autoconf_atom=">=sys-devel/autoconf-2.59" ;; 33 latest | 2.5) _autoconf_atom=">=sys-devel/autoconf-2.59" ;;
25 esac 34 esac
35 [[ ${WANT_AUTOCONF} == "latest" ]] && WANT_AUTOCONF="2.5"
36 export WANT_AUTOCONF
26fi 37fi
27DEPEND="${_automake_atom} 38DEPEND="${_automake_atom}
28 ${_autoconf_atom} 39 ${_autoconf_atom}
29 sys-devel/libtool" 40 sys-devel/libtool"
30RDEPEND="" 41RDEPEND=""
33# Variables: 44# Variables:
34# 45#
35# AT_M4DIR - Additional director(y|ies) aclocal should search 46# AT_M4DIR - Additional director(y|ies) aclocal should search
36# AM_OPTS - Additional options to pass to automake during 47# AM_OPTS - Additional options to pass to automake during
37# eautoreconf call. 48# eautoreconf call.
49# AT_NOELIBTOOLIZE - Don't run elibtoolize command if set to 'yes',
50# useful when elibtoolize needs to be ran with
51# particular options
38 52
39# Functions: 53# Functions:
40# 54#
41# eautoreconf() - Should do a full autoreconf - normally what most people 55# eautoreconf() - Should do a full autoreconf - normally what most people
42# will be interested in. Also should handle additional 56# will be interested in. Also should handle additional
48# eautoconf - Runs autoconf. 62# eautoconf - Runs autoconf.
49# eautoheader - Runs autoheader. 63# eautoheader - Runs autoheader.
50# eautomake - Runs automake 64# eautomake - Runs automake
51# 65#
52 66
53# XXX: M4DIR should be depreciated 67# XXX: M4DIR should be deprecated
54AT_M4DIR=${AT_M4DIR:-${M4DIR}} 68AT_M4DIR=${AT_M4DIR:-${M4DIR}}
55AT_GNUCONF_UPDATE="no" 69AT_GNUCONF_UPDATE="no"
56 70
57 71
58# This function mimes the behavior of autoreconf, but uses the different 72# This function mimes the behavior of autoreconf, but uses the different
135} 149}
136 150
137eautoheader() { 151eautoheader() {
138 # Check if we should run autoheader 152 # Check if we should run autoheader
139 [[ -n $(autotools_check_macro "AC_CONFIG_HEADERS") ]] || return 0 153 [[ -n $(autotools_check_macro "AC_CONFIG_HEADERS") ]] || return 0
140 autotools_run_tool autoheader "$@" 154 NO_FAIL=1 autotools_run_tool autoheader "$@"
141} 155}
142 156
143eautoconf() { 157eautoconf() {
144 if [[ ! -f configure.ac && ! -f configure.in ]] ; then 158 if [[ ! -f configure.ac && ! -f configure.in ]] ; then
145 echo 159 echo
153 167
154eautomake() { 168eautomake() {
155 local extra_opts 169 local extra_opts
156 170
157 [[ -f Makefile.am ]] || return 0 171 [[ -f Makefile.am ]] || return 0
158
159 if [[ -n ${WANT_AUTOMAKE} ]]; then
160 export WANT_AUTOMAKE # let the automake wrapper pick it up
161 einfo "Required automake ${WANT_AUTOMAKE}. Using $(automake --version | head -n 1)."
162 fi
163 172
164 if [[ -z ${FROM_EAUTORECONF} && -f Makefile.in ]]; then 173 if [[ -z ${FROM_EAUTORECONF} && -f Makefile.in ]]; then
165 local used_automake 174 local used_automake
166 local installed_automake 175 local installed_automake
167 176
183 192
184 # --force-missing seems not to be recognized by some flavours of automake 193 # --force-missing seems not to be recognized by some flavours of automake
185 autotools_run_tool automake --add-missing --copy ${extra_opts} "$@" 194 autotools_run_tool automake --add-missing --copy ${extra_opts} "$@"
186} 195}
187 196
188
189
190# Internal function to run an autotools' tool 197# Internal function to run an autotools' tool
191autotools_run_tool() { 198autotools_run_tool() {
192 local STDERR_TARGET="${T}/$$.out" 199 local STDERR_TARGET="${T}/$$.out"
193 local PATCH_TARGET="${T}/$$.patch"
194 local ris 200 local ris
195 201
196 echo "***** $1 *****" > ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 202 echo "***** $1 *****" > ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/}
197 echo >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 203 echo >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/}
198 204
199 ebegin "Running $@" 205 ebegin "Running $@"
200 $@ >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 2>&1 206 $@ >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 2>&1
201 ris=$? 207 ris=$?
202 eend ${ris} 208 eend ${ris}
203 209
204 if [[ ${ris} != 0 ]]; then 210 if [[ ${ris} != 0 && ${NO_FAIL} != 1 ]]; then
205 echo 211 echo
206 eerror "Failed Running $1 !" 212 eerror "Failed Running $1 !"
207 eerror 213 eerror
208 eerror "Include in your bugreport the contents of:" 214 eerror "Include in your bugreport the contents of:"
209 eerror 215 eerror

Legend:
Removed from v.1.46  
changed lines
  Added in v.1.66

  ViewVC Help
Powered by ViewVC 1.1.20