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

Diff of /eclass/autotools.eclass

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

Revision 1.45 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.45 2006/09/22 22:25:06 vapier 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"
41RDEPEND=""
30unset _automake_atom _autoconf_atom 42unset _automake_atom _autoconf_atom
31 43
32# Variables: 44# Variables:
33# 45#
34# AT_M4DIR - Additional director(y|ies) aclocal should search 46# AT_M4DIR - Additional director(y|ies) aclocal should search
35# AM_OPTS - Additional options to pass to automake during 47# AM_OPTS - Additional options to pass to automake during
36# 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
37 52
38# Functions: 53# Functions:
39# 54#
40# eautoreconf() - Should do a full autoreconf - normally what most people 55# eautoreconf() - Should do a full autoreconf - normally what most people
41# will be interested in. Also should handle additional 56# will be interested in. Also should handle additional
47# eautoconf - Runs autoconf. 62# eautoconf - Runs autoconf.
48# eautoheader - Runs autoheader. 63# eautoheader - Runs autoheader.
49# eautomake - Runs automake 64# eautomake - Runs automake
50# 65#
51 66
52# XXX: M4DIR should be depreciated 67# XXX: M4DIR should be deprecated
53AT_M4DIR=${AT_M4DIR:-${M4DIR}} 68AT_M4DIR=${AT_M4DIR:-${M4DIR}}
54AT_GNUCONF_UPDATE="no" 69AT_GNUCONF_UPDATE="no"
55 70
56 71
57# This function mimes the behavior of autoreconf, but uses the different 72# This function mimes the behavior of autoreconf, but uses the different
134} 149}
135 150
136eautoheader() { 151eautoheader() {
137 # Check if we should run autoheader 152 # Check if we should run autoheader
138 [[ -n $(autotools_check_macro "AC_CONFIG_HEADERS") ]] || return 0 153 [[ -n $(autotools_check_macro "AC_CONFIG_HEADERS") ]] || return 0
139 autotools_run_tool autoheader "$@" 154 NO_FAIL=1 autotools_run_tool autoheader "$@"
140} 155}
141 156
142eautoconf() { 157eautoconf() {
143 if [[ ! -f configure.ac && ! -f configure.in ]] ; then 158 if [[ ! -f configure.ac && ! -f configure.in ]] ; then
144 echo 159 echo
152 167
153eautomake() { 168eautomake() {
154 local extra_opts 169 local extra_opts
155 170
156 [[ -f Makefile.am ]] || return 0 171 [[ -f Makefile.am ]] || return 0
157
158 if [[ -n ${WANT_AUTOMAKE} ]]; then
159 export WANT_AUTOMAKE # let the automake wrapper pick it up
160 einfo "Required automake ${WANT_AUTOMAKE}. Using $(automake --version | head -n 1)."
161 fi
162 172
163 if [[ -z ${FROM_EAUTORECONF} && -f Makefile.in ]]; then 173 if [[ -z ${FROM_EAUTORECONF} && -f Makefile.in ]]; then
164 local used_automake 174 local used_automake
165 local installed_automake 175 local installed_automake
166 176
182 192
183 # --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
184 autotools_run_tool automake --add-missing --copy ${extra_opts} "$@" 194 autotools_run_tool automake --add-missing --copy ${extra_opts} "$@"
185} 195}
186 196
187
188
189# Internal function to run an autotools' tool 197# Internal function to run an autotools' tool
190autotools_run_tool() { 198autotools_run_tool() {
191 local STDERR_TARGET="${T}/$$.out" 199 local STDERR_TARGET="${T}/$$.out"
192 local PATCH_TARGET="${T}/$$.patch"
193 local ris 200 local ris
194 201
195 echo "***** $1 *****" > ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 202 echo "***** $1 *****" > ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/}
196 echo >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 203 echo >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/}
197 204
198 ebegin "Running $@" 205 ebegin "Running $@"
199 $@ >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 2>&1 206 $@ >> ${STDERR_TARGET%/*}/$1-${STDERR_TARGET##*/} 2>&1
200 ris=$? 207 ris=$?
201 eend ${ris} 208 eend ${ris}
202 209
203 if [[ ${ris} != 0 ]]; then 210 if [[ ${ris} != 0 && ${NO_FAIL} != 1 ]]; then
204 echo 211 echo
205 eerror "Failed Running $1 !" 212 eerror "Failed Running $1 !"
206 eerror 213 eerror
207 eerror "Include in your bugreport the contents of:" 214 eerror "Include in your bugreport the contents of:"
208 eerror 215 eerror

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

  ViewVC Help
Powered by ViewVC 1.1.20