summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2006-11-05 08:44:41 +0000
committerMike Frysinger <vapier@gentoo.org>2006-11-05 08:44:41 +0000
commitb9e6d2091ba231df0256dc2106a6ea8c5e3afb48 (patch)
tree849794377b7007d111580db5ceeacafa11679fb1 /sys-devel/autoconf-wrapper
parentunloved (diff)
downloadhistorical-b9e6d2091ba231df0256dc2106a6ea8c5e3afb48.tar.gz
historical-b9e6d2091ba231df0256dc2106a6ea8c5e3afb48.tar.bz2
historical-b9e6d2091ba231df0256dc2106a6ea8c5e3afb48.zip
Add a more flexible wrapper using stuff from automake-wrapper-3 and allow WANT_AUTOCONF to be a space delimited list.
Package-Manager: portage-2.1.2_rc1-r2
Diffstat (limited to 'sys-devel/autoconf-wrapper')
-rw-r--r--sys-devel/autoconf-wrapper/ChangeLog9
-rw-r--r--sys-devel/autoconf-wrapper/autoconf-wrapper-4.ebuild27
-rwxr-xr-xsys-devel/autoconf-wrapper/files/ac-wrapper-4.sh164
-rw-r--r--sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.21
-rw-r--r--sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2-r21
-rw-r--r--sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-40
6 files changed, 199 insertions, 3 deletions
diff --git a/sys-devel/autoconf-wrapper/ChangeLog b/sys-devel/autoconf-wrapper/ChangeLog
index aa081936a60a..3fa492c122aa 100644
--- a/sys-devel/autoconf-wrapper/ChangeLog
+++ b/sys-devel/autoconf-wrapper/ChangeLog
@@ -1,6 +1,13 @@
# ChangeLog for sys-devel/autoconf-wrapper
# Copyright 1999-2006 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/autoconf-wrapper/ChangeLog,v 1.37 2006/11/03 18:39:27 grobian Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/autoconf-wrapper/ChangeLog,v 1.38 2006/11/05 08:44:41 vapier Exp $
+
+*autoconf-wrapper-4 (05 Nov 2006)
+
+ 05 Nov 2006; Mike Frysinger <vapier@gentoo.org> +files/ac-wrapper-4.sh,
+ +autoconf-wrapper-4.ebuild:
+ Add a more flexible wrapper using stuff from automake-wrapper-3 and allow
+ WANT_AUTOCONF to be a space delimited list.
03 Nov 2006; Fabian Groffen <grobian@gentoo.org>
autoconf-wrapper-3.2.ebuild, autoconf-wrapper-3.2-r2.ebuild:
diff --git a/sys-devel/autoconf-wrapper/autoconf-wrapper-4.ebuild b/sys-devel/autoconf-wrapper/autoconf-wrapper-4.ebuild
new file mode 100644
index 000000000000..1ec5ad3c8810
--- /dev/null
+++ b/sys-devel/autoconf-wrapper/autoconf-wrapper-4.ebuild
@@ -0,0 +1,27 @@
+# Copyright 1999-2006 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/autoconf-wrapper/autoconf-wrapper-4.ebuild,v 1.1 2006/11/05 08:44:41 vapier Exp $
+
+inherit multilib
+
+DESCRIPTION="wrapper for autoconf to manage multiple autoconf versions"
+HOMEPAGE="http://www.gentoo.org/"
+SRC_URI=""
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~sparc-fbsd ~x86 ~x86-fbsd"
+IUSE=""
+
+S=${WORKDIR}
+
+src_install() {
+ exeinto /usr/$(get_libdir)/misc
+ newexe "${FILESDIR}"/ac-wrapper-${PV}.sh ac-wrapper.sh || die
+
+ dodir /usr/bin
+ local x=
+ for x in auto{conf,header,m4te,reconf,scan,update} ifnames ; do
+ dosym ../$(get_libdir)/misc/ac-wrapper.sh /usr/bin/${x} || die
+ done
+}
diff --git a/sys-devel/autoconf-wrapper/files/ac-wrapper-4.sh b/sys-devel/autoconf-wrapper/files/ac-wrapper-4.sh
new file mode 100755
index 000000000000..37b94930e223
--- /dev/null
+++ b/sys-devel/autoconf-wrapper/files/ac-wrapper-4.sh
@@ -0,0 +1,164 @@
+#!/bin/bash
+# Copyright 1999-2006 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/autoconf-wrapper/files/ac-wrapper-4.sh,v 1.1 2006/11/05 08:44:41 vapier Exp $
+
+# Based on the ac-wrapper.pl script provided by MandrakeSoft
+# Rewritten in bash by Gregorio Guidi
+#
+# Executes the correct autoconf version.
+#
+# - defaults to newest version available (hopefully autoconf-2.60)
+# - runs autoconf 2.13 if:
+# - envvar WANT_AUTOCONF is set to `2.1'
+# -or-
+# - `ac{local,include}.m4' or `configure.{in,ac}' have AC_PREREQ(2.1) (not higher)
+# -or-
+# - `configure' is already present and was generated by autoconf 2.13
+
+if [[ ${0##*/} == "ac-wrapper.sh" ]] ; then
+ echo "Don't call this script directly" >&2
+ exit 1
+fi
+
+if [[ ${WANT_AUTOCONF} == "2.1" && ${0##*/} == "autom4te" ]] ; then
+ echo "ac-wrapper: Autoconf 2.13 doesn't contain autom4te." >&2
+ echo " Either unset WANT_AUTOCONF or don't execute anything" >&2
+ echo " that would use autom4te." >&2
+ exit 1
+fi
+
+#
+# Set up bindings between actual version and WANT_AUTOCONF
+#
+vers="2.60:2.5 2.59:2.5 2.13:2.1"
+
+binary=""
+for v in ${vers} ; do
+ auto_ver=${v%:*} # aka 2.60
+ want_ver=${v#*:} # aka 2.5
+ eval binary_${want_ver/./_}="${0}-${auto_ver}"
+
+ if [ -z "${binary}" ] && [ -x "${0}-${auto_ver}" ] ; then
+ binary="${0}-${auto_ver}"
+ fi
+done
+if [ -z "${binary}" ] ; then
+ echo "ac-wrapper: Unable to locate any usuable version of autoconf." >&2
+ echo " I tried these versions: ${vers}" >&2
+ echo " With a base name of '${0}'." >&2
+ exit 1
+fi
+
+#
+# Check the WANT_AUTOCONF setting. We accept a whitespace delimited
+# list of autoconf versions.
+#
+if [ -n "${WANT_AUTOCONF}" ] ; then
+ for v in ${vers} x ; do
+ if [ "${v}" = "x" ] ; then
+ echo "ac-wrapper: warning: invalid WANT_AUTOCONF '${WANT_AUTOCONF}'; ignoring." >&2
+ unset WANT_AUTOCONF
+ break
+ fi
+
+ want_ver=${v#*:}
+ for wx in ${WANT_AUTOCONF} ; do
+ if [ "${wx}" = "${want_ver}" ] ; then
+ binary="binary_${want_ver/./_}"
+ binary="${!binary}"
+ break
+ fi
+ done
+ done
+fi
+
+#
+# autodetect helpers
+#
+acprereq_version() {
+ gawk \
+ '($0 !~ /^[[:space:]]*(#|dnl)/) {
+ if (match($0, "AC_PREREQ\\(\\[?([0-9]\\.[0-9])", res))
+ VERSIONS[COUNT++] = res[1]
+ }
+
+ END {
+ asort(VERSIONS)
+ print VERSIONS[COUNT]
+ }' "$@"
+}
+
+generated_version() {
+ gawk \
+ '{
+ if (match($0,
+ "^# Generated (by (GNU )?Autoconf|automatically using autoconf version) ([0-9].[0-9])",
+ res)) {
+ print res[3]
+ exit
+ }
+ }' "$@"
+}
+
+#
+# autodetect routine
+#
+if [[ ${WANT_AUTOCONF} == "2.1" ]] && [ -f "configure.ac" ] ; then
+ echo "ac-wrapper: Since configure.ac is present, aclocal always use" >&2
+ echo " autoconf 2.59+, which conflicts with your choice and" >&2
+ echo " causes error. You have two options:" >&2
+ echo " 1. Try execute command again after removing configure.ac" >&2
+ echo " 2. Don't set WANT_AUTOCONF" >&2
+ exit 1
+fi
+
+if [[ ${WANT_AUTOCONF} != "2.5" ]] && [[ -n ${WANT_AUTOMAKE} ]] ; then
+ # Automake-1.7 and better require autoconf-2.5x so if WANT_AUTOMAKE
+ # is set to an older version, let's do some sanity checks.
+ case "${WANT_AUTOMAKE}" in
+ 1.[456])
+ acfiles=$(ls ac{local,include}.m4 configure.{in,ac} 2>/dev/null)
+ [[ -n ${acfiles} ]] && confversion=$(acprereq_version ${acfiles})
+
+ [[ -z ${confversion} && -r "configure" ]] \
+ && confversion=$(generated_version configure)
+
+ if [[ ${confversion} == "2.1" && ! -f "configure.ac" ]] ; then
+ binary="${binary_2_1}"
+ fi
+ esac
+fi
+
+if [[ -n ${WANT_ACWRAPPER_DEBUG} ]] ; then
+ if [[ -n ${WANT_AUTOCONF} ]] ; then
+ echo "ac-wrapper: DEBUG: WANT_AUTOCONF is set to ${WANT_AUTOCONF}" >&2
+ fi
+ echo "ac-wrapper: DEBUG: will execute <${binary}>" >&2
+fi
+
+#
+# for further consistency
+#
+for v in ${vers} ; do
+ want_ver=${v#*:}
+ mybin="binary_${want_ver/./_}"
+ if [ "${binary}" = "${!mybin}" ] ; then
+ export WANT_AUTOMAKE="${want_ver}"
+ fi
+done
+
+#
+# Now try to run the binary
+#
+if [[ ! -x ${binary} ]] ; then
+ # this shouldn't happen
+ echo "ac-wrapper: ${binary} is missing or not executable." >&2
+ echo " Please try emerging the correct version of autoconf." >&2
+ exit 1
+fi
+
+exec "${binary}" "$@"
+
+echo "ac-wrapper: was unable to exec ${binary} !?" >&2
+exit 1
diff --git a/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2 b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2
index 8b137891791f..e69de29bb2d1 100644
--- a/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2
+++ b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2
@@ -1 +0,0 @@
-
diff --git a/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2-r2 b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2-r2
index 8b137891791f..e69de29bb2d1 100644
--- a/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2-r2
+++ b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-3.2-r2
@@ -1 +0,0 @@
-
diff --git a/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-4 b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-4
new file mode 100644
index 000000000000..e69de29bb2d1
--- /dev/null
+++ b/sys-devel/autoconf-wrapper/files/digest-autoconf-wrapper-4