From 402266252bc387658a990bbcf398ee769c59aba6 Mon Sep 17 00:00:00 2001 From: Paulo Erichsen Date: Tue, 27 Feb 2024 11:17:43 -0700 Subject: [PATCH] bootstrap and autogen: add the --no-git option Some users already have gnulib downloaded. Added the --no-git option to allow users to skip re-downloading gnulib. --- autogen.sh | 8 +++++++- bootstrap | 57 +++++++++++++++++++++++++++++++++--------------------- 2 files changed, 42 insertions(+), 23 deletions(-) diff --git a/autogen.sh b/autogen.sh index 24f864e6b..bec86eed0 100755 --- a/autogen.sh +++ b/autogen.sh @@ -13,6 +13,8 @@ Options: have gnulib sources on your machine, and do not want to waste your bandwidth downloading them again. + --no-git Do not use git to update gnulib. Requires that + --gnulib-srcdir point to a correct gnulib snapshot --help Print this message any other option Pass to the 'configure' script verbatim @@ -30,6 +32,8 @@ test -z "$srcdir" && srcdir=. THEDIR=`pwd` cd $srcdir +no_git= + # Split out options for bootstrap and for configure declare -a CF_ARGS for option @@ -40,6 +44,8 @@ do exit;; --gnulib-srcdir=*) GNULIB_SRCDIR=$option;; + --no-git) + no_git=" --no-git";; *) CF_ARGS[${#CF_ARGS[@]}]=$option;; esac @@ -83,7 +89,7 @@ fi mkdir -p $BUILD_AUX $LIBTOOLIZE --copy --force -./bootstrap $GNULIB_SRCDIR +./bootstrap$no_git $GNULIB_SRCDIR aclocal -I gnulib/m4 autoheader automake --add-missing diff --git a/bootstrap b/bootstrap index a84eb3912..8706e4167 100755 --- a/bootstrap +++ b/bootstrap @@ -11,6 +11,8 @@ Options: have gnulib sources on your machine, and do not want to waste your bandwidth downloading them again. + --no-git Do not use git to update gnulib. Requires that + --gnulib-srcdir point to a correct gnulib snapshot If the file bootstrap.conf exists in the current working directory, its contents are read as shell variables to configure the bootstrap. @@ -19,6 +21,9 @@ Running without arguments will suffice in most cases. " } +# Use git to update gnulib sources +use_git=true + for option do case $option in @@ -27,38 +32,46 @@ do exit;; --gnulib-srcdir=*) GNULIB_SRCDIR=${option#--gnulib-srcdir=};; + --no-git) + use_git=false;; *) echo >&2 "$0: $option: unknown option" exit 1;; esac done -# Get gnulib files. +if [ "$use_git" = false ] && [ ! -d "$GNULIB_SRCDIR" ]; then + echo >&2 "$0: Error: --no-git requires --gnulib-srcdir: $GNULIB_SRCDIR" + exit 1 +fi -case ${GNULIB_SRCDIR--} in --) - echo "$0: getting gnulib files..." - git submodule init || exit $? - git submodule update || exit $? - GNULIB_SRCDIR=.gnulib - ;; -*) - # Redirect the gnulib submodule to the directory on the command line - # if possible. - if test -d "$GNULIB_SRCDIR"/.git && \ - git config --file .gitmodules submodule.gnulib.url >/dev/null; then - git submodule init - GNULIB_SRCDIR=`cd $GNULIB_SRCDIR && pwd` - git config --replace-all submodule.gnulib.url $GNULIB_SRCDIR +# Get gnulib files. +if [ "$use_git" = true ]; then + case ${GNULIB_SRCDIR--} in + -) echo "$0: getting gnulib files..." + git submodule init || exit $? git submodule update || exit $? GNULIB_SRCDIR=.gnulib - else - echo >&2 "$0: invalid gnulib srcdir: $GNULIB_SRCDIR" - exit 1 - fi - ;; -esac + ;; + *) + # Redirect the gnulib submodule to the directory on the command line + # if possible. + if test -d "$GNULIB_SRCDIR"/.git && \ + git config --file .gitmodules submodule.gnulib.url >/dev/null; then + git submodule init + GNULIB_SRCDIR=`cd $GNULIB_SRCDIR && pwd` + git config --replace-all submodule.gnulib.url $GNULIB_SRCDIR + echo "$0: getting gnulib files..." + git submodule update || exit $? + GNULIB_SRCDIR=.gnulib + else + echo >&2 "$0: invalid gnulib srcdir: $GNULIB_SRCDIR" + exit 1 + fi + ;; + esac +fi gnulib_tool=$GNULIB_SRCDIR/gnulib-tool <$gnulib_tool || exit