From af3e4d067ace861eb50f5e78ffb8e63e6756881a Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sat, 3 May 2014 00:09:16 -0700 Subject: [PATCH] Make it easier on maintainers who use their own Automake. * autogen.sh (ACLOCAL_PATH, AUTORECONF_ENV): New vars. Set them to avoid problems when maintainers prepend their own Automake installations to their PATH. Report an error if pkg.m4 can't be found. --- ChangeLog | 8 ++++++++ autogen.sh | 45 ++++++++++++++++++++++++++++++++++++++++++--- etc/PROBLEMS | 20 ++++++++++---------- 3 files changed, 60 insertions(+), 13 deletions(-) diff --git a/ChangeLog b/ChangeLog index 648017a6dd..23aae9e7af 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2014-05-03 Paul Eggert + + Make it easier on maintainers who use their own Automake. + * autogen.sh (ACLOCAL_PATH, AUTORECONF_ENV): New vars. + Set them to avoid problems when maintainers prepend their own + Automake installations to their PATH. Report an error if pkg.m4 + can't be found. + 2014-05-02 Glenn Morris * configure.ac (PKG_CONFIG_PATH): Declare with AC_ARG_VAR. diff --git a/autogen.sh b/autogen.sh index 84230b5601..c2a2c7af04 100755 --- a/autogen.sh +++ b/autogen.sh @@ -195,7 +195,7 @@ this script. If you know that the required versions are in your PATH, but this script has made an error, then you can simply run -autoreconf -i -I m4 +autoreconf -fi -I m4 instead of this script. @@ -205,12 +205,51 @@ EOF exit 1 fi -echo "Your system has the required tools, running autoreconf..." +# If automake is installed in a nonstandard location, find the standard +# location if possible and append it to ACLOCAL_PATH. That way, it will +# find the pkg.m4 that is installed in the standard location. +echo "Checking for pkg.m4..." +AUTORECONF_ENV= +ac_dir=`aclocal --print-ac-dir` && test -r "$ac_dir/pkg.m4" || { + oIFS=$IFS + IFS=: + before_first_aclocal=true + for dir in $PATH; do + if test -x "$dir/aclocal"; then + if $before_first_aclocal; then + before_first_aclocal=false + elif ac_dir=`"$dir/aclocal" --print-ac-dir` && test -r "$ac_dir/pkg.m4" + then + case $ACLOCAL_PATH in + '') ACLOCAL_PATH=$ac_dir;; + ?*) ACLOCAL_PATH=$ACLOCAL_PATH:$ac_dir;; + esac + export ACLOCAL_PATH + AUTORECONF_ENV="ACLOCAL_PATH='$ACLOCAL_PATH' " + break + fi + fi + done + IFS=$oIFS + + if test -z "$AUTORECONF_ENV"; then + cat <