[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [bug-gnulib] gnulib-tool change for Autoconf 2.60 and onceonly
From: |
Bruno Haible |
Subject: |
Re: [bug-gnulib] gnulib-tool change for Autoconf 2.60 and onceonly |
Date: |
Sat, 29 Jul 2006 15:13:56 +0200 |
User-agent: |
KMail/1.9.1 |
Eric Blake wrote:
> Would it be worth grepping configure.ac, and if you detect AC_PREREQ([2.60]),
> having that imply --assume-autoconf=2.60?
Implemented:
2006-07-29 Bruno Haible <address@hidden>
* gnulib-tool (SORT): New variable.
(func_usage): Undocument --assume-autoconf option.
Remove --assume-autoconf option handling.
(autoconf_minversion): Determine from the contents of configure.ac.
(func_import): Remove autoconf_minversion handling.
Suggested by Eric Blake.
*** gnulib-tool 29 Jul 2006 13:10:38 -0000 1.124
--- gnulib-tool 29 Jul 2006 13:14:23 -0000
***************
*** 53,58 ****
--- 53,64 ----
AUTORECONF="${AUTOCONFPATH}autoreconf"
fi
+ # GNU sort is needed. Set SORT to its location (not needed if it's called
+ # 'sort' and already in the PATH).
+ if test -z "$SORT"; then
+ SORT=sort
+ fi
+
# func_usage
# outputs to stdout the --help usage message.
func_usage ()
***************
*** 105,114 ****
For --import, this specifies where your
configure.ac can be found. Defaults to current
directory.
- --assume-autoconf=VERSION
- Assume a given autoconf version (or newer).
- If VERSION is 'latest-stable', assume the latest
- stable version.
Options for --import:
--lib=LIBRARY Specify the library name. Defaults to 'libgnu'.
--- 111,116 ----
***************
*** 408,423 ****
--macro-prefix=* )
macro_prefix=`echo "X$1" | sed -e 's/^X--macro-prefix=//'`
shift ;;
- --assume-autoconf )
- shift
- if test $# = 0; then
- func_fatal_error "missing argument for --assume-autoconf"
- fi
- autoconf_minversion="$1"
- shift ;;
- --assume-autoconf=* )
- autoconf_minversion=`echo "X$1" | sed -e 's/^X--assume-autoconf=//'`
- shift ;;
--no-changelog | --no-changelo | --no-changel | --no-change |
--no-chang | --no-chan | --no-cha | --no-ch | --no-c )
do_changelog=false
shift ;;
--- 410,415 ----
***************
*** 457,463 ****
if test -n "$supplied_libname" || test -n "$sourcebase" || test -n
"$m4base" \
|| test -n "$docbase" || test -n "$testsbase" || test -n "$auxdir" \
|| test -n "$inctests" || test -n "$avoidlist" || test -n "$lgpl" \
! || test -n "$macro_prefix" || test -n "$autoconf_minversion"; then
echo "gnulib-tool: invalid options for 'update' mode" 1>&2
echo "Try 'gnulib-tool --help' for more information." 1>&2
echo "If you really want to modify the gnulib configuration of your
project," 1>&2
--- 449,455 ----
if test -n "$supplied_libname" || test -n "$sourcebase" || test -n
"$m4base" \
|| test -n "$docbase" || test -n "$testsbase" || test -n "$auxdir" \
|| test -n "$inctests" || test -n "$avoidlist" || test -n "$lgpl" \
! || test -n "$macro_prefix"; then
echo "gnulib-tool: invalid options for 'update' mode" 1>&2
echo "Try 'gnulib-tool --help' for more information." 1>&2
echo "If you really want to modify the gnulib configuration of your
project," 1>&2
***************
*** 467,476 ****
do_changelog=false
fi
DEFAULT_AUTOCONF_MINVERSION="2.59"
case "$autoconf_minversion" in
1.* | 2.[0-4]* | 2.5[0-8]*)
! func_fatal_error "minimum supported autoconf version is 2.59" ;;
esac
# Remove trailing slashes from the directory names. This is necessary for
--- 459,476 ----
do_changelog=false
fi
+ # Determine the minimum supported autoconf version from the project's
+ # configure.ac.
DEFAULT_AUTOCONF_MINVERSION="2.59"
+ if test -f configure.ac; then
+ autoconf_minversion=`$AUTOCONF --trace=AC_PREREQ:'$1' | $SORT -g | uniq |
tail -1`
+ fi
+ if test -z "$autoconf_minversion"; then
+ autoconf_minversion=$DEFAULT_AUTOCONF_MINVERSION
+ fi
case "$autoconf_minversion" in
1.* | 2.[0-4]* | 2.5[0-8]*)
! func_fatal_error "minimum supported autoconf version is 2.59. Try
adding AC_PREREQ([$DEFAULT_AUTOCONF_MINVERSION]) to your configure.ac." ;;
esac
# Remove trailing slashes from the directory names. This is necessary for
***************
*** 949,955 ****
cached_lgpl=
cached_libtool=
cached_macro_prefix=
- cached_autoconf_minversion=
cached_files=
if test -f "$destdir"/$m4base/gnulib-cache.m4; then
my_sed_traces='
--- 949,954 ----
***************
*** 985,993 ****
}
/gl_MACRO_PREFIX(/ {
s,^.*gl_MACRO_PREFIX([[ ]*\([^])]*\).*$,cached_macro_prefix="\1",p
- }
- /gl_AUTOCONF_MINVERSION(/ {
- s,^.*gl_AUTOCONF_MINVERSION([[
]*\([^])]*\).*$,cached_autoconf_minversion="\1",p
}'
eval `sed -n -e "$my_sed_traces" < "$destdir"/$m4base/gnulib-cache.m4`
if test -f "$destdir"/$m4base/gnulib-comp.m4; then
--- 984,989 ----
***************
*** 1070,1082 ****
func_fatal_error "missing --macro-prefix option"
fi
fi
- # The autoconf_minversion defaults to the cached one.
- if test -z "$autoconf_minversion"; then
- autoconf_minversion="$cached_autoconf_minversion"
- if test -z "$autoconf_minversion"; then
- autoconf_minversion="$DEFAULT_AUTOCONF_MINVERSION"
- fi
- fi
# Canonicalize the list of specified modules.
specified_modules=`for m in $specified_modules; do echo $m; done | LC_ALL=C
sort | LC_ALL=C uniq`
--- 1066,1071 ----
***************
*** 1324,1330 ****
actioncmd="$actioncmd --libtool"
fi
actioncmd="$actioncmd --macro-prefix=$macro_prefix"
- actioncmd="$actioncmd --assume-autoconf=$autoconf_minversion"
actioncmd="$actioncmd `echo $specified_modules`"
# Create lib/Makefile.am.
--- 1313,1318 ----
***************
*** 1378,1384 ****
test -z "$lgpl" || echo "gl_LGPL"
test -z "$libtool" || echo "gl_LIBTOOL"
echo "gl_MACRO_PREFIX([$macro_prefix])"
- echo "gl_AUTOCONF_MINVERSION([$autoconf_minversion])"
) > "$tmpfile"
if test -f "$destdir"/$m4base/gnulib-cache.m4; then
if cmp "$destdir"/$m4base/gnulib-cache.m4 "$tmpfile" > /dev/null; then
--- 1366,1371 ----
***************
*** 1957,1963 ****
test -n "$docbase" || docbase="doc"
test -n "$testsbase" || testsbase="tests"
test -n "$macro_prefix" || macro_prefix="gl"
- test -n "$autoconf_minversion" ||
autoconf_minversion="$DEFAULT_AUTOCONF_MINVERSION"
fi
func_import "$*"
else
--- 1944,1949 ----
***************
*** 1998,2004 ****
test -n "$docbase" || docbase="doc"
test -n "$testsbase" || testsbase="tests"
test -n "$macro_prefix" || macro_prefix="gl"
- test -n "$autoconf_version" ||
autoconf_version="$DEFAULT_AUTOCONF_MINVERSION"
func_import "$*"
else
if test $m4dirs_count = 1; then
--- 1984,1989 ----