X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=bootstrap;h=e7c2edf3c1df72fdcdd93eb8bb4ab157f7854117;hb=82eff37f6fbf853b4f32bdc0ef822192c0a31b91;hp=45a4b7969d7e3b880b71c9872e0c7bb6c1bb9d1f;hpb=01f19e973bfc7636b2ca9c54482d3ccf490ed7dd;p=chaz%2Ftar diff --git a/bootstrap b/bootstrap index 45a4b79..e7c2edf 100755 --- a/bootstrap +++ b/bootstrap @@ -2,7 +2,7 @@ # Bootstrap 'tar' from CVS. -# Copyright (C) 2003 Free Software Foundation, Inc. +# Copyright (C) 2003, 2004 Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -21,36 +21,113 @@ # Written by Paul Eggert. +# URL of our text domain page in Translation Project +TP_URL="http://www2.iro.umontreal.ca/~gnutra/po/maint/tar/" + +usage() { + cat <LINGUAS + ) || exit +} # Parse options. -for option; do +DOWNLOAD_PO=yes +for option +do case $option in --help) - echo "$0: usage: $0 [--gnulib-srcdir=DIR]" + usage exit;; --gnulib-srcdir=*) - GNULIB_SRCDIR=`expr "$1" : '--gnulib-srcdir=\(.*\)'`;; + GNULIB_SRCDIR=`expr "$option" : '--gnulib-srcdir=\(.*\)'`;; + --cvs-auth=*) + CVS_AUTH=`expr "$option" : '--cvs-auth=\(.*\)'`;; + --cvs-user=*) + CVS_USER=`expr "$option" : '--cvs-user=\(.*\)'`;; + --no-po) + DOWNLOAD_PO=no;; + --update-po) + DOWNLOAD_PO=only;; *) echo >&2 "$0: $option: unknown option" exit 1;; esac done +if [ "$DOWNLOAD_PO" = "only" ]; then + update_po + exit 0 +fi echo "$0: Bootstrapping CVS tar..." +build_cvs_prefix() { + CVS_PREFIX=:${1}: + if [ "${2}" != - ]; then + CVS_PREFIX=${CVS_PREFIX}${2}@ + fi + if [ "$1" = "ext" ]; then + if [ -z "${CVS_RSH}" ]; then + CVS_RSH=ssh + export CVS_RSH + fi + fi +} # Get gnulib files. -echo "$0: getting gnulib files..." - case ${GNULIB_SRCDIR--} in -) if [ ! -d gnulib ]; then + echo "$0: getting gnulib files..." + trap exit 1 2 13 15 trap 'rm -fr gnulib; exit 1' 0 - cvs -q -d savannah.gnu.org:/cvsroot/gnulib co gnulib || exit + + case "${CVS_AUTH--}" in + -) build_cvs_prefix ext anoncvs;; + pserver) build_cvs_prefix $CVS_AUTH ${CVS_USER:-anoncvs};; + gserver|server) + build_cvs_prefix $CVS_AUTH ${CVS_USER--};; + ext) build_cvs_prefix $CVS_AUTH ${CVS_USER--};; + *) echo "$0: Unknown CVS access method" >&2 + exit 1;; + esac + if [ "${CVS_AUTH--}" = "pserver" ]; then + cvs -d ${CVS_PREFIX}subversions.gnu.org:/cvsroot/gnulib login || exit + fi + cvs -q -d ${CVS_PREFIX}subversions.gnu.org:/cvsroot/gnulib co gnulib || exit + trap 0 fi GNULIB_SRCDIR=gnulib @@ -61,6 +138,7 @@ esac gnulib_modules=' alloca argmatch +argp backupfile dirname error @@ -72,7 +150,9 @@ full-write getdate getline getopt +getpagesize gettext +gettime hash human lchown @@ -86,8 +166,10 @@ safe-read save-cwd savedir stdbool +stpcpy strtol strtoul +timespec unlocked-io utime xalloc @@ -120,14 +202,17 @@ for gnulib_file in $gnulib_files; do case $gnulib_file in m4/codeset.m4) continue;; - m4/glibc21.m4) continue;; m4/intdiv0.m4) continue;; - m4/inttypes_h.m4) continue;; - m4/inttypes.m4) continue;; m4/inttypes-pri.m4) continue;; m4/isc-posix.m4) continue;; m4/lcmessage.m4) continue;; m4/onceonly_2_57.m4) dest=m4/onceonly.m4;; + # These will be overwritten by autopoint, which still uses + # old jm_.* macro names, so we have to keep both copies. + m4/ulonglong.m4) dest=m4/ulonglong_gl.m4;; + m4/inttypes_h.m4) dest=m4/inttypes_h_gl.m4;; + m4/stdint_h.m4) dest=m4/stdint_h_gl.m4;; + m4/uintmax_t.m4) dest=m4/uintmax_t_gl.m4;; esac rm -f $dest && @@ -135,17 +220,36 @@ for gnulib_file in $gnulib_files; do cp -p $GNULIB_SRCDIR/$gnulib_file $dest || exit done +if [ -d patches ]; then + echo "$0: Patching gnulib" + for file in patches/*.diff + do + patch -p0 < $file + done +fi -# Get translations. +echo "$0: Creating m4/gnulib.m4" +(echo "# This file is generated automatically. Please, do not edit." + echo "#" + echo "AC_DEFUN([tar_GNULIB],[" + for gnulib_module in $gnulib_modules; do + echo "# $gnulib_module" + $GNULIB_SRCDIR/gnulib-tool --extract-autoconf-snippet $gnulib_module + done | sed '/AM_GNU_GETTEXT/d' + echo "])") > ./m4/gnulib.m4 -echo "$0: getting translations into po..." -(cd po && - rm -f dummy `ls | sed -n '/\.gmo$/p; /\.po/p'` && - wget -nv -nd -r -l 1 -A .po -C off \ - http://www.iro.umontreal.ca/contrib/po/maint/tar/ && - ls *.po | sed 's/\.po$//' >LINGUAS -) || exit +echo "$0: Creating lib/Makefile.am" +(cat lib/Makefile.tmpl + + for gnulib_module in $gnulib_modules; do + echo "# $gnulib_module" + $GNULIB_SRCDIR/gnulib-tool --extract-automake-snippet $gnulib_module + done | sed 's/lib_SOURCES/libtar_a_SOURCES/g' ) > lib/Makefile.am +# Get translations. +if test "$DOWNLOAD_PO" = "yes"; then + update_po +fi # Reconfigure, getting other files.