| # Copyright 1999-2010 Gentoo Foundation |
| # Distributed under the terms of the GNU General Public License v2 |
| # $Header: /var/cvsroot/gentoo-x86/eclass/autotools.eclass,v 1.101 2010/08/21 19:39:52 vapier Exp $ |
| |
| # @ECLASS: autotools.eclass |
| # @MAINTAINER: |
| # base-system@gentoo.org |
| # @BLURB: Regenerates auto* build scripts |
| # @DESCRIPTION: |
| # This eclass is for safely handling autotooled software packages that need to |
| # regenerate their build scripts. All functions will abort in case of errors. |
| # |
| # NB: If you add anything, please comment it! |
| |
| inherit eutils libtool |
| |
| # @ECLASS-VARIABLE: WANT_AUTOCONF |
| # @DESCRIPTION: |
| # The major version of autoconf your package needs |
| : ${WANT_AUTOCONF:=latest} |
| |
| # @ECLASS-VARIABLE: WANT_AUTOMAKE |
| # @DESCRIPTION: |
| # The major version of automake your package needs |
| : ${WANT_AUTOMAKE:=latest} |
| |
| # @ECLASS-VARIABLE: _LATEST_AUTOMAKE |
| # @INTERNAL |
| # @DESCRIPTION: |
| # CONSTANT! |
| # The latest major version/slot of automake available on each arch. |
| # If a newer version is stable on any arch, and is NOT reflected in this list, |
| # then circular dependencies may arise during emerge @system bootstraps. |
| # Do NOT change this variable in your ebuilds! |
| _LATEST_AUTOMAKE='1.11' |
| |
| _automake_atom="sys-devel/automake" |
| _autoconf_atom="sys-devel/autoconf" |
| if [[ -n ${WANT_AUTOMAKE} ]]; then |
| case ${WANT_AUTOMAKE} in |
| none) _automake_atom="" ;; # some packages don't require automake at all |
| # if you change the "latest" version here, change also autotools_run_tool |
| # this MUST reflect the latest stable major version for each arch! |
| latest) _automake_atom="|| ( `printf '=sys-devel/automake-%s* ' ${_LATEST_AUTOMAKE}` )" ;; |
| *) _automake_atom="=sys-devel/automake-${WANT_AUTOMAKE}*" ;; |
| esac |
| export WANT_AUTOMAKE |
| fi |
| |
| if [[ -n ${WANT_AUTOCONF} ]] ; then |
| case ${WANT_AUTOCONF} in |
| none) _autoconf_atom="" ;; # some packages don't require autoconf at all |
| 2.1) _autoconf_atom="=sys-devel/autoconf-${WANT_AUTOCONF}*" ;; |
| # if you change the “latest” version here, change also autotools_run_tool |
| latest|2.5) _autoconf_atom=">=sys-devel/autoconf-2.61" ;; |
| *) _autoconf_atom="INCORRECT-WANT_AUTOCONF-SETTING-IN-EBUILD" ;; |
| esac |
| export WANT_AUTOCONF |
| fi |
| |
| AUTOTOOLS_DEPEND="${_automake_atom} ${_autoconf_atom}" |
| [[ ${CATEGORY}/${PN} != "sys-devel/libtool" ]] && AUTOTOOLS_DEPEND="${AUTOTOOLS_DEPEND} >=sys-devel/libtool-2.2.6b" |
| RDEPEND="" |
| |
| # @ECLASS-VARIABLE: AUTOTOOLS_AUTO_DEPEND |
| # @DESCRIPTION: |
| # Set to 'no' to disable automatically adding to DEPEND. This lets |
| # ebuilds former conditional depends by using ${AUTOTOOLS_DEPEND} in |
| # their own DEPEND string. |
| : ${AUTOTOOLS_AUTO_DEPEND:=yes} |
| if [[ ${AUTOTOOLS_AUTO_DEPEND} != "no" ]] ; then |
| DEPEND=${AUTOTOOLS_DEPEND} |
| fi |
| |
| unset _automake_atom _autoconf_atom |
| |
| # @ECLASS-VARIABLE: AM_OPTS |
| # @DEFAULT_UNSET |
| # @DESCRIPTION: |
| # Additional options to pass to automake during |
| # eautoreconf call. |
| |
| # @ECLASS-VARIABLE: AT_NOELIBTOOLIZE |
| # @DEFAULT_UNSET |
| # @DESCRIPTION: |
| # Don't run elibtoolize command if set to 'yes', |
| # useful when elibtoolize needs to be ran with |
| # particular options |
| |
| # XXX: M4DIR should be deprecated |
| # @ECLASS-VARIABLE: AT_M4DIR |
| # @DESCRIPTION: |
| # Additional director(y|ies) aclocal should search |
| : ${AT_M4DIR:=${M4DIR}} |
| |
| # @FUNCTION: eautoreconf |
| # @DESCRIPTION: |
| # This function mimes the behavior of autoreconf, but uses the different |
| # eauto* functions to run the tools. It doesn't accept parameters, but |
| # the directory with include files can be specified with AT_M4DIR variable. |
| # |
| # Should do a full autoreconf - normally what most people will be interested in. |
| # Also should handle additional directories specified by AC_CONFIG_SUBDIRS. |
| eautoreconf() { |
| local x auxdir g |
| |
| if [[ -z ${AT_NO_RECURSIVE} ]]; then |
| # Take care of subdirs |
| for x in $(autotools_get_subdirs); do |
| if [[ -d ${x} ]] ; then |
| pushd "${x}" >/dev/null |
| AT_NOELIBTOOLIZE="yes" eautoreconf |
| popd >/dev/null |
| fi |
| done |
| fi |
| |
| auxdir=$(autotools_get_auxdir) |
| |
| einfo "Running eautoreconf in '${PWD}' ..." |
| [[ -n ${auxdir} ]] && mkdir -p ${auxdir} |
| eaclocal |
| [[ ${CHOST} == *-darwin* ]] && g=g |
| if ${LIBTOOLIZE:-${g}libtoolize} -n --install >& /dev/null ; then |
| _elibtoolize --copy --force --install |
| else |
| _elibtoolize --copy --force |
| fi |
| eautoconf |
| eautoheader |
| FROM_EAUTORECONF="yes" eautomake ${AM_OPTS} |
| |
| [[ ${AT_NOELIBTOOLIZE} == "yes" ]] && return 0 |
| |
| # Call it here to prevent failures due to elibtoolize called _before_ |
| # eautoreconf. We set $S because elibtoolize runs on that #265319 |
| S=${PWD} elibtoolize |
| |
| return 0 |
| } |
| |
| # @FUNCTION: eaclocal |
| # @DESCRIPTION: |
| # These functions runs the autotools using autotools_run_tool with the |
| # specified parametes. The name of the tool run is the same of the function |
| # without e prefix. |
| # They also force installing the support files for safety. |
| # Respects AT_M4DIR for additional directories to search for macro's. |
| eaclocal() { |
| local aclocal_opts |
| |
| local amflags_file |
| for amflags_file in GNUmakefile.am Makefile.am GNUmakefile.in Makefile.in ; do |
| [[ -e ${amflags_file} ]] || continue |
| aclocal_opts=$(sed -n '/^ACLOCAL_AMFLAGS[[:space:]]*=/s:[^=]*=::p' ${amflags_file}) |
| eval aclocal_opts=\"${aclocal_opts}\" |
| break |
| done |
| |
| if [[ -n ${AT_M4DIR} ]] ; then |
| for x in ${AT_M4DIR} ; do |
| case "${x}" in |
| "-I") |
| # We handle it below |
| ;; |
| *) |
| [[ ! -d ${x} ]] && ewarn "eaclocal: '${x}' does not exist" |
| aclocal_opts="${aclocal_opts} -I ${x}" |
| ;; |
| esac |
| done |
| fi |
| |
| [[ ! -f aclocal.m4 || -n $(grep -e 'generated.*by aclocal' aclocal.m4) ]] && \ |
| autotools_run_tool aclocal "$@" ${aclocal_opts} -I"${ROOT}"/usr/share/aclocal |
| } |
| |
| # @FUNCTION: _elibtoolize |
| # @DESCRIPTION: |
| # Runs libtoolize. Note the '_' prefix .. to not collide with elibtoolize() from |
| # libtool.eclass. |
| _elibtoolize() { |
| local opts g= |
| |
| # Check if we should run libtoolize (AM_PROG_LIBTOOL is an older macro, |
| # check for both it and the current AC_PROG_LIBTOOL) |
| [[ -n $(autotools_check_macro AC_PROG_LIBTOOL AM_PROG_LIBTOOL LT_INIT) ]] || return 0 |
| |
| [[ -f GNUmakefile.am || -f Makefile.am ]] && opts="--automake" |
| |
| [[ ${CHOST} == *-darwin* ]] && g=g |
| autotools_run_tool ${LIBTOOLIZE:-${g}libtoolize} "$@" ${opts} |
| |
| # Need to rerun aclocal |
| eaclocal |
| } |
| |
| # @FUNCTION: eautoheader |
| # @DESCRIPTION: |
| # Runs autoheader. |
| eautoheader() { |
| # Check if we should run autoheader |
| [[ -n $(autotools_check_macro "AC_CONFIG_HEADERS") ]] || return 0 |
| NO_FAIL=1 autotools_run_tool autoheader "$@" |
| } |
| |
| # @FUNCTION: eautoconf |
| # @DESCRIPTION: |
| # Runs autoconf. |
| eautoconf() { |
| if [[ ! -f configure.ac && ! -f configure.in ]] ; then |
| echo |
| eerror "No configure.{ac,in} present in '${PWD}'!" |
| echo |
| die "No configure.{ac,in} present!" |
| fi |
| |
| autotools_run_tool autoconf "$@" |
| } |
| |
| # @FUNCTION: eautomake |
| # @DESCRIPTION: |
| # Runs automake. |
| eautomake() { |
| local extra_opts |
| local makefile_name |
| |
| # Run automake if: |
| # - a Makefile.am type file exists |
| # - a Makefile.in type file exists and the configure |
| # script is using the AM_INIT_AUTOMAKE directive |
| for makefile_name in {GNUmakefile,{M,m}akefile}.{am,in} "" ; do |
| [[ -f ${makefile_name} ]] && break |
| done |
| [[ -z ${makefile_name} ]] && return 0 |
| |
| if [[ ${makefile_name} == *.in ]] ; then |
| if ! grep -qs AM_INIT_AUTOMAKE configure.?? ; then |
| return 0 |
| fi |
| |
| elif [[ -z ${FROM_EAUTORECONF} && -f ${makefile_name%.am}.in ]]; then |
| local used_automake |
| local installed_automake |
| |
| installed_automake=$(WANT_AUTOMAKE= automake --version | head -n 1 | \ |
| sed -e 's:.*(GNU automake) ::') |
| used_automake=$(head -n 1 < ${makefile_name%.am}.in | \ |
| sed -e 's:.*by automake \(.*\) from .*:\1:') |
| |
| if [[ ${installed_automake} != ${used_automake} ]]; then |
| einfo "Automake used for the package (${used_automake}) differs from" |
| einfo "the installed version (${installed_automake})." |
| eautoreconf |
| return 0 |
| fi |
| fi |
| |
| [[ -f INSTALL && -f AUTHORS && -f ChangeLog && -f NEWS ]] \ |
| || extra_opts="${extra_opts} --foreign" |
| |
| # --force-missing seems not to be recognized by some flavours of automake |
| autotools_run_tool automake --add-missing --copy ${extra_opts} "$@" |
| } |
| |
| # @FUNCTION: eautopoint |
| # @DESCRIPTION: |
| # Runs autopoint (from the gettext package). |
| eautopoint() { |
| autotools_run_tool autopoint "$@" |
| } |
| |
| # Internal function to run an autotools' tool |
| autotools_run_tool() { |
| if [[ ${EBUILD_PHASE} != "unpack" && ${EBUILD_PHASE} != "prepare" ]]; then |
| ewarn "QA Warning: running $1 in ${EBUILD_PHASE} phase" |
| fi |
| |
| # We do the “latest” → version switch here because it solves |
| # possible order problems, see bug #270010 as an example. |
| if [[ ${WANT_AUTOMAKE} == "latest" ]]; then |
| local pv |
| for pv in ${_LATEST_AUTOMAKE} ; do |
| # has_version respects ROOT, but in this case, we don't want it to, |
| # thus "ROOT=/" prefix: |
| ROOT=/ has_version "=sys-devel/automake-${pv}*" && export WANT_AUTOMAKE="$pv" |
| done |
| [[ ${WANT_AUTOMAKE} == "latest" ]] && \ |
| die "Cannot find the latest automake! Tried ${_LATEST_AUTOMAKE}" |
| fi |
| [[ ${WANT_AUTOCONF} == "latest" ]] && export WANT_AUTOCONF=2.5 |
| |
| local STDERR_TARGET="${T}/$1.out" |
| # most of the time, there will only be one run, but if there are |
| # more, make sure we get unique log filenames |
| if [[ -e ${STDERR_TARGET} ]] ; then |
| STDERR_TARGET="${T}/$1-$$.out" |
| fi |
| |
| printf "***** $1 *****\n***** PWD: ${PWD}\n***** $*\n\n" > "${STDERR_TARGET}" |
| |
| ebegin "Running $@" |
| "$@" >> "${STDERR_TARGET}" 2>&1 |
| eend $? |
| |
| if [[ $? != 0 && ${NO_FAIL} != 1 ]] ; then |
| echo |
| eerror "Failed Running $1 !" |
| eerror |
| eerror "Include in your bugreport the contents of:" |
| eerror |
| eerror " ${STDERR_TARGET}" |
| echo |
| die "Failed Running $1 !" |
| fi |
| } |
| |
| # Internal function to check for support |
| autotools_check_macro() { |
| [[ -f configure.ac || -f configure.in ]] || return 0 |
| local macro |
| for macro ; do |
| WANT_AUTOCONF="2.5" autoconf --trace="${macro}" 2>/dev/null |
| done |
| return 0 |
| } |
| |
| # Internal function to get additional subdirs to configure |
| autotools_get_subdirs() { |
| local subdirs_scan_out |
| |
| subdirs_scan_out=$(autotools_check_macro "AC_CONFIG_SUBDIRS") |
| [[ -n ${subdirs_scan_out} ]] || return 0 |
| |
| echo "${subdirs_scan_out}" | gawk \ |
| '($0 !~ /^[[:space:]]*(#|dnl)/) { |
| if (match($0, /AC_CONFIG_SUBDIRS:(.*)$/, res)) |
| print res[1] |
| }' | uniq |
| |
| return 0 |
| } |
| |
| autotools_get_auxdir() { |
| local auxdir_scan_out |
| |
| auxdir_scan_out=$(autotools_check_macro "AC_CONFIG_AUX_DIR") |
| [[ -n ${auxdir_scan_out} ]] || return 0 |
| |
| echo ${auxdir_scan_out} | gawk \ |
| '($0 !~ /^[[:space:]]*(#|dnl)/) { |
| if (match($0, /AC_CONFIG_AUX_DIR:(.*)$/, res)) |
| print res[1] |
| }' | uniq |
| |
| return 0 |
| } |