Detect EOF when deleting from archive.
[tar.git] / bootstrap
blobc6c4901d3fac27444323847550687b83c821e75e
1 #! /bin/sh
2 # DO NOT EDIT! GENERATED AUTOMATICALLY!
4 # Bootstrap this package from checked-out sources.
6 scriptversion=2022-12-27.07; # UTC
8 # Copyright (C) 2003-2023 Free Software Foundation, Inc.
10 # This program is free software: you can redistribute it and/or modify
11 # it under the terms of the GNU General Public License as published by
12 # the Free Software Foundation, either version 3 of the License, or
13 # (at your option) any later version.
15 # This program is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 # GNU General Public License for more details.
20 # You should have received a copy of the GNU General Public License
21 # along with this program. If not, see <https://www.gnu.org/licenses/>.
23 # Originally written by Paul Eggert. The canonical version of this
24 # script is maintained as top/bootstrap in gnulib. However, to be
25 # useful to your package, you should place a copy of it under version
26 # control in the top-level directory of your package. The intent is
27 # that all customization can be done with a bootstrap.conf file also
28 # maintained in your version control; gnulib comes with a template
29 # build-aux/bootstrap.conf to get you started.
31 # Please report bugs or propose patches to bug-gnulib@gnu.org.
33 me="$0"
34 medir=`dirname "$me"`
36 # Read the function library and the configuration.
38 # A library of shell functions for autopull.sh, autogen.sh, and bootstrap.
40 scriptlibversion=2023-01-06.19; # UTC
42 # Copyright (C) 2003-2023 Free Software Foundation, Inc.
44 # This program is free software: you can redistribute it and/or modify
45 # it under the terms of the GNU General Public License as published by
46 # the Free Software Foundation, either version 3 of the License, or
47 # (at your option) any later version.
49 # This program is distributed in the hope that it will be useful,
50 # but WITHOUT ANY WARRANTY; without even the implied warranty of
51 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
52 # GNU General Public License for more details.
54 # You should have received a copy of the GNU General Public License
55 # along with this program. If not, see <https://www.gnu.org/licenses/>.
57 # Originally written by Paul Eggert. The canonical version of this
58 # script is maintained as top/bootstrap-funclib.sh in gnulib. However,
59 # to be useful to your package, you should place a copy of it under
60 # version control in the top-level directory of your package. The
61 # intent is that all customization can be done with a bootstrap.conf
62 # file also maintained in your version control; gnulib comes with a
63 # template build-aux/bootstrap.conf to get you started.
65 nl='
68 # Ensure file names are sorted consistently across platforms.
69 LC_ALL=C
70 export LC_ALL
72 # Honor $PERL, but work even if there is none.
73 PERL="${PERL-perl}"
75 default_gnulib_url=https://git.savannah.gnu.org/git/gnulib.git
77 # Copyright year, for the --version output.
78 copyright_year=`echo "$scriptlibversion" | sed -e 's/[^0-9].*//'`
79 copyright="Copyright (C) ${copyright_year} Free Software Foundation, Inc.
80 License GPLv3+: GNU GPL version 3 or later <https://gnu.org/licenses/gpl.html>.
81 This is free software: you are free to change and redistribute it.
82 There is NO WARRANTY, to the extent permitted by law."
84 # warnf_ FORMAT-STRING ARG1...
85 warnf_ ()
87 warnf_format_=$1
88 shift
89 nl='
91 case $* in
92 *$nl*) me_=$(printf "$me"|tr "$nl|" '??')
93 printf "$warnf_format_" "$@" | sed "s|^|$me_: |" ;;
94 *) printf "$me: $warnf_format_" "$@" ;;
95 esac >&2
98 # warn_ WORD1...
99 warn_ ()
101 # If IFS does not start with ' ', set it and emit the warning in a subshell.
102 case $IFS in
103 ' '*) warnf_ '%s\n' "$*";;
104 *) (IFS=' '; warn_ "$@");;
105 esac
108 # die WORD1...
109 die() { warn_ "$@"; exit 1; }
111 # ------------------------------ Configuration. ------------------------------
113 # Directory that contains package-specific gnulib modules and/or overrides.
114 local_gl_dir=gl
116 # Name of the Makefile.am
117 # XXX Not used.
118 gnulib_mk=gnulib.mk
120 # List of gnulib modules needed.
121 gnulib_modules=
123 # Any gnulib files needed that are not in modules.
124 gnulib_files=
126 # A function to be called for each unrecognized option. Returns 0 if
127 # the option in $1 has been processed by the function. Returns 1 if
128 # the option has not been processed by the function. Override it via
129 # your own definition in bootstrap.conf
130 bootstrap_option_hook() { return 1; }
132 # A function to be called in order to print the --help information
133 # corresponding to user-defined command-line options.
134 bootstrap_print_option_usage_hook() { :; }
136 # A function to be called at the end of autopull.sh.
137 # Override it via your own definition in bootstrap.conf.
138 bootstrap_post_pull_hook() { :; }
140 # A function to be called right after gnulib-tool is run.
141 # Override it via your own definition in bootstrap.conf.
142 bootstrap_post_import_hook() { :; }
144 # A function to be called after everything else in this script.
145 # Override it via your own definition in bootstrap.conf.
146 bootstrap_epilogue() { :; }
148 # The command to download all .po files for a specified domain into a
149 # specified directory. Fill in the first %s with the destination
150 # directory and the second with the domain name.
151 po_download_command_format=\
152 "wget --mirror --level=1 -nd -nv -A.po -P '%s' \
153 https://translationproject.org/latest/%s/"
155 # Prefer a non-empty tarname (4th argument of AC_INIT if given), else
156 # fall back to the package name (1st argument with munging).
157 extract_package_name='
158 /^AC_INIT(\[*/{
159 s///
160 /^[^,]*,[^,]*,[^,]*,[ []*\([^][ ,)]\)/{
161 s//\1/
162 s/[],)].*//
166 s/[],)].*//
167 s/^GNU //
168 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
169 s/[^abcdefghijklmnopqrstuvwxyz0123456789_]/-/g
173 package=$(${AUTOCONF:-autoconf} --trace AC_INIT:\$4 configure.ac 2>/dev/null)
174 if test -z "$package"; then
175 package=$(sed -n "$extract_package_name" configure.ac) \
176 || die 'cannot find package name in configure.ac'
178 gnulib_name=lib$package
180 build_aux=build-aux
181 source_base=lib
182 m4_base=m4
183 doc_base=doc
184 tests_base=tests
185 gnulib_extra_files="
186 build-aux/install-sh
187 build-aux/mdate-sh
188 build-aux/texinfo.tex
189 build-aux/depcomp
190 build-aux/config.guess
191 build-aux/config.sub
192 doc/INSTALL
195 # Additional gnulib-tool options to use. Use "\newline" to break lines.
196 gnulib_tool_option_extras=
198 # Other locale categories that need message catalogs.
199 EXTRA_LOCALE_CATEGORIES=
201 # Additional xgettext options to use. Use "\\\newline" to break lines.
202 XGETTEXT_OPTIONS='\\\
203 --flag=_:1:pass-c-format\\\
204 --flag=N_:1:pass-c-format\\\
205 --flag=error:3:c-format --flag=error_at_line:5:c-format\\\
208 # Package bug report address and copyright holder for gettext files
209 COPYRIGHT_HOLDER='Free Software Foundation, Inc.'
210 MSGID_BUGS_ADDRESS=bug-$package@gnu.org
212 # Files we don't want to import.
213 # XXX Not used.
214 excluded_files=
216 # File that should exist in the top directory of a checked out hierarchy,
217 # but not in a distribution tarball.
218 checkout_only_file=README-hacking
220 # Set this to '.cvsignore .gitignore' in bootstrap.conf if you want
221 # those files to be generated in directories like lib/, m4/, and po/.
222 # Or set it to 'auto' to make this script select which to use based
223 # on which version control system (if any) is used in the source directory.
224 vc_ignore=auto
226 # Set this to true in bootstrap.conf to enable --bootstrap-sync by
227 # default.
228 bootstrap_sync=false
230 # Override the default configuration, if necessary.
231 # Make sure that bootstrap.conf is sourced from the current directory
232 # if we were invoked as "sh bootstrap".
233 conffile=`dirname "$me"`/bootstrap.conf
234 test -r "$conffile" && . "$conffile"
236 # ------------------------- Build-time prerequisites -------------------------
238 check_exists() {
239 if test "$1" = "--verbose"; then
240 ($2 --version </dev/null) >/dev/null 2>&1
241 if test $? -ge 126; then
242 # If not found, run with diagnostics as one may be
243 # presented with env variables to set to find the right version
244 ($2 --version </dev/null)
246 else
247 ($1 --version </dev/null) >/dev/null 2>&1
250 test $? -lt 126
253 # Note this deviates from the version comparison in automake
254 # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
255 # but this should suffice as we won't be specifying old
256 # version formats or redundant trailing .0 in bootstrap.conf.
257 # If we did want full compatibility then we should probably
258 # use m4_version_compare from autoconf.
259 sort_ver() { # sort -V is not generally available
260 ver1="$1"
261 ver2="$2"
263 # split on '.' and compare each component
265 while : ; do
266 p1=$(echo "$ver1" | cut -d. -f$i)
267 p2=$(echo "$ver2" | cut -d. -f$i)
268 if [ ! "$p1" ]; then
269 echo "$1 $2"
270 break
271 elif [ ! "$p2" ]; then
272 echo "$2 $1"
273 break
274 elif [ ! "$p1" = "$p2" ]; then
275 if [ "$p1" -gt "$p2" ] 2>/dev/null; then # numeric comparison
276 echo "$2 $1"
277 elif [ "$p2" -gt "$p1" ] 2>/dev/null; then # numeric comparison
278 echo "$1 $2"
279 else # numeric, then lexicographic comparison
280 lp=$(printf "%s\n%s\n" "$p1" "$p2" | LANG=C sort -n | tail -n1)
281 if [ "$lp" = "$p2" ]; then
282 echo "$1 $2"
283 else
284 echo "$2 $1"
287 break
289 i=$(($i+1))
290 done
293 get_version_sed='
294 # Move version to start of line.
295 s/.*[v ]\([0-9]\)/\1/
297 # Skip lines that do not start with version.
298 /^[0-9]/!d
300 # Remove characters after the version.
301 s/[^.a-z0-9-].*//
303 # The first component must be digits only.
304 s/^\([0-9]*\)[a-z-].*/\1/
306 #the following essentially does s/5.005/5.5/
307 s/\.0*\([1-9]\)/.\1/g
311 get_version() {
312 app=$1
314 $app --version >/dev/null 2>&1 || { $app --version; return 1; }
316 $app --version 2>&1 | sed -n "$get_version_sed"
319 check_versions() {
320 ret=0
322 while read app req_ver; do
323 # We only need libtoolize from the libtool package.
324 if test "$app" = libtool; then
325 app=libtoolize
327 # Exempt git if git is not needed.
328 if test "$app" = git; then
329 $check_git || continue
331 # Honor $APP variables ($TAR, $AUTOCONF, etc.)
332 appvar=$(echo $app | LC_ALL=C tr '[a-z]-' '[A-Z]_')
333 test "$appvar" = TAR && appvar=AMTAR
334 case $appvar in
335 GZIP) ;; # Do not use $GZIP: it contains gzip options.
336 PERL::*) ;; # Keep perl modules as-is
337 *) eval "app=\${$appvar-$app}" ;;
338 esac
340 # Handle the still-experimental Automake-NG programs specially.
341 # They remain named as the mainstream Automake programs ("automake",
342 # and "aclocal") to avoid gratuitous incompatibilities with
343 # pre-existing usages (by, say, autoreconf, or custom autogen.sh
344 # scripts), but correctly identify themselves (as being part of
345 # "GNU automake-ng") when asked their version.
346 case $app in
347 automake-ng|aclocal-ng)
348 app=${app%-ng}
349 ($app --version | grep '(GNU automake-ng)') >/dev/null 2>&1 || {
350 warn_ "Error: '$app' not found or not from Automake-NG"
351 ret=1
352 continue
353 } ;;
354 # Another check is for perl modules. These can be written as
355 # e.g. perl::XML::XPath in case of XML::XPath module, etc.
356 perl::*)
357 # Extract module name
358 app="${app#perl::}"
359 if ! $PERL -m"$app" -e 'exit 0' >/dev/null 2>&1; then
360 warn_ "Error: perl module '$app' not found"
361 ret=1
363 continue
365 esac
366 if [ "$req_ver" = "-" ]; then
367 # Merely require app to exist; not all prereq apps are well-behaved
368 # so we have to rely on $? rather than get_version.
369 if ! check_exists --verbose $app; then
370 warn_ "Error: '$app' not found"
371 ret=1
373 else
374 # Require app to produce a new enough version string.
375 inst_ver=$(get_version $app)
376 if [ ! "$inst_ver" ]; then
377 warn_ "Error: '$app' not found"
378 ret=1
379 else
380 latest_ver=$(sort_ver $req_ver $inst_ver | cut -d' ' -f2)
381 if [ ! "$latest_ver" = "$inst_ver" ]; then
382 warnf_ '%s\n' \
383 "Error: '$app' version == $inst_ver is too old" \
384 " '$app' version >= $req_ver is required"
385 ret=1
389 done
391 return $ret
394 print_versions() {
395 echo "Program Min_version"
396 echo "----------------------"
397 printf %s "$buildreq"
398 echo "----------------------"
399 # can't depend on column -t
402 # check_build_prerequisites check_git
403 check_build_prerequisites()
405 check_git="$1"
407 # gnulib-tool requires at least automake and autoconf.
408 # If either is not listed, add it (with minimum version) as a prerequisite.
409 case $buildreq in
410 *automake*) ;;
411 *) buildreq="automake 1.9
412 $buildreq" ;;
413 esac
414 case $buildreq in
415 *autoconf*) ;;
416 *) buildreq="autoconf 2.59
417 $buildreq" ;;
418 esac
420 # When we can deduce that gnulib-tool will require patch,
421 # and when patch is not already listed as a prerequisite, add it, too.
422 if test -d "$local_gl_dir" \
423 && ! find "$local_gl_dir" -name '*.diff' -exec false {} +; then
424 case $buildreq in
425 *patch*) ;;
426 *) buildreq="patch -
427 $buildreq" ;;
428 esac
431 if ! printf '%s' "$buildreq" | check_versions; then
432 echo >&2
433 if test -f README-prereq; then
434 die "See README-prereq for how to get the prerequisite programs"
435 else
436 die "Please install the prerequisite programs"
440 # Warn the user if autom4te appears to be broken; this causes known
441 # issues with at least gettext 0.18.3.
442 probe=$(echo 'm4_quote([hi])' | autom4te -l M4sugar -t 'm4_quote:$%' -)
443 if test "x$probe" != xhi; then
444 warn_ "WARNING: your autom4te wrapper eats stdin;"
445 warn_ "if bootstrap fails, consider upgrading your autotools"
449 # find_tool ENVVAR NAMES...
450 # -------------------------
451 # Search for a required program. Use the value of ENVVAR, if set,
452 # otherwise find the first of the NAMES that can be run.
453 # If found, set ENVVAR to the program name, die otherwise.
455 # FIXME: code duplication, see also gnu-web-doc-update.
456 find_tool ()
458 find_tool_envvar=$1
459 shift
460 find_tool_names=$@
461 eval "find_tool_res=\$$find_tool_envvar"
462 if test x"$find_tool_res" = x; then
463 for i; do
464 if check_exists $i; then
465 find_tool_res=$i
466 break
468 done
470 if test x"$find_tool_res" = x; then
471 warn_ "one of these is required: $find_tool_names;"
472 die "alternatively set $find_tool_envvar to a compatible tool"
474 eval "$find_tool_envvar=\$find_tool_res"
475 eval "export $find_tool_envvar"
478 # --------------------- Preparing GNULIB_SRCDIR for use. ---------------------
479 # This is part of autopull.sh, but bootstrap needs it too, for self-upgrading.
481 cleanup_gnulib() {
482 status=$?
483 # XXX It's a bad idea to erase the submodule directory if it contains local
484 # modifications.
485 rm -fr "$gnulib_path"
486 exit $status
489 git_modules_config () {
490 test -f .gitmodules && git config --file .gitmodules "$@"
493 prepare_GNULIB_SRCDIR ()
495 if test -n "$GNULIB_SRCDIR"; then
496 # Use GNULIB_SRCDIR directly.
497 # We already checked that $GNULIB_SRCDIR references a directory.
498 # Verify that it contains a gnulib checkout.
499 test -f "$GNULIB_SRCDIR/gnulib-tool" \
500 || die "Error: --gnulib-srcdir or \$GNULIB_SRCDIR is specified, but does not contain gnulib-tool"
501 elif $use_git; then
502 gnulib_path=$(git_modules_config submodule.gnulib.path)
503 test -z "$gnulib_path" && gnulib_path=gnulib
505 # Get gnulib files. Populate $gnulib_path, possibly updating a
506 # submodule, for use in the rest of the script.
508 if test -n "$GNULIB_REFDIR" && test -d "$GNULIB_REFDIR"/.git \
509 && git_modules_config submodule.gnulib.url >/dev/null; then
510 # Use GNULIB_REFDIR as a reference.
511 echo "$0: getting gnulib files..."
512 if git submodule -h|grep -- --reference > /dev/null; then
513 # Prefer the one-liner available in git 1.6.4 or newer.
514 git submodule update --init --reference "$GNULIB_REFDIR" \
515 "$gnulib_path" || exit $?
516 else
517 # This fallback allows at least git 1.5.5.
518 if test -f "$gnulib_path"/gnulib-tool; then
519 # Since file already exists, assume submodule init already complete.
520 git submodule update -- "$gnulib_path" || exit $?
521 else
522 # Older git can't clone into an empty directory.
523 rmdir "$gnulib_path" 2>/dev/null
524 git clone --reference "$GNULIB_REFDIR" \
525 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
526 && git submodule init -- "$gnulib_path" \
527 && git submodule update -- "$gnulib_path" \
528 || exit $?
531 else
532 # GNULIB_REFDIR is not set or not usable. Ignore it.
533 if git_modules_config submodule.gnulib.url >/dev/null; then
534 echo "$0: getting gnulib files..."
535 git submodule init -- "$gnulib_path" || exit $?
536 git submodule update -- "$gnulib_path" || exit $?
538 elif [ ! -d "$gnulib_path" ]; then
539 echo "$0: getting gnulib files..."
541 trap cleanup_gnulib HUP INT PIPE TERM
543 shallow=
544 if test -z "$GNULIB_REVISION"; then
545 if git clone -h 2>&1 | grep -- --depth > /dev/null; then
546 shallow='--depth 2'
548 git clone $shallow ${GNULIB_URL:-$default_gnulib_url} "$gnulib_path" \
549 || cleanup_gnulib
550 else
551 if git fetch -h 2>&1 | grep -- --depth > /dev/null; then
552 shallow='--depth 2'
554 mkdir -p "$gnulib_path"
555 # Only want a shallow checkout of $GNULIB_REVISION, but git does not
556 # support cloning by commit hash. So attempt a shallow fetch by commit
557 # hash to minimize the amount of data downloaded and changes needed to
558 # be processed, which can drastically reduce download and processing
559 # time for checkout. If the fetch by commit fails, a shallow fetch can
560 # not be performed because we do not know what the depth of the commit
561 # is without fetching all commits. So fallback to fetching all commits.
562 git -C "$gnulib_path" init
563 git -C "$gnulib_path" remote add origin \
564 ${GNULIB_URL:-$default_gnulib_url}
565 git -C "$gnulib_path" fetch $shallow origin "$GNULIB_REVISION" \
566 || git -C "$gnulib_path" fetch origin \
567 || cleanup_gnulib
568 git -C "$gnulib_path" reset --hard FETCH_HEAD
571 trap - HUP INT PIPE TERM
574 GNULIB_SRCDIR=$gnulib_path
575 # Verify that the submodule contains a gnulib checkout.
576 test -f "$gnulib_path/gnulib-tool" \
577 || die "Error: $gnulib_path is supposed to contain a gnulib checkout, but does not contain gnulib-tool"
580 # XXX Should this be done if $use_git is false?
581 if test -d "$GNULIB_SRCDIR"/.git && test -n "$GNULIB_REVISION" \
582 && ! git_modules_config submodule.gnulib.url >/dev/null; then
583 (cd "$GNULIB_SRCDIR" && git checkout "$GNULIB_REVISION") || cleanup_gnulib
586 # $GNULIB_SRCDIR now points to the version of gnulib to use, and
587 # we no longer need to use git or $gnulib_path below here.
590 # -------- Upgrading bootstrap to the version found in GNULIB_SRCDIR. --------
592 upgrade_bootstrap ()
594 if test -f "$medir"/bootstrap-funclib.sh; then
595 update_lib=true
596 { cmp -s "$medir"/bootstrap "$GNULIB_SRCDIR/top/bootstrap" \
597 && cmp -s "$medir"/bootstrap-funclib.sh "$GNULIB_SRCDIR/top/bootstrap-funclib.sh" \
598 && cmp -s "$medir"/autopull.sh "$GNULIB_SRCDIR/top/autopull.sh" \
599 && cmp -s "$medir"/autogen.sh "$GNULIB_SRCDIR/top/autogen.sh"; \
601 else
602 update_lib=false
603 cmp -s "$medir"/bootstrap "$GNULIB_SRCDIR/build-aux/bootstrap"
604 fi || {
605 if $update_lib; then
606 echo "$0: updating bootstrap & companions and restarting..."
607 else
608 echo "$0: updating bootstrap and restarting..."
610 case $(sh -c 'echo "$1"' -- a) in
611 a) ignored=--;;
612 *) ignored=ignored;;
613 esac
614 exec sh -c \
615 '{ if '$update_lib' && test -f "$1"; then cp "$1" "$3"; else cp "$2" "$3"; fi; } && { if '$update_lib' && test -f "$4"; then cp "$4" "$5"; else rm -f "$5"; fi; } && { if '$update_lib' && test -f "$6"; then cp "$6" "$7"; else rm -f "$7"; fi; } && { if '$update_lib' && test -f "$8"; then cp "$8" "$9"; else rm -f "$9"; fi; } && shift && shift && shift && shift && shift && shift && shift && shift && shift && exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
616 $ignored \
617 "$GNULIB_SRCDIR/top/bootstrap" "$GNULIB_SRCDIR/build-aux/bootstrap" "$medir/bootstrap" \
618 "$GNULIB_SRCDIR/top/bootstrap-funclib.sh" "$medir/bootstrap-funclib.sh" \
619 "$GNULIB_SRCDIR/top/autopull.sh" "$medir/autopull.sh" \
620 "$GNULIB_SRCDIR/top/autogen.sh" "$medir/autogen.sh" \
621 "$0" "$@" --no-bootstrap-sync
625 # ----------------------------------------------------------------------------
627 if test x"$gnulib_modules$gnulib_files$gnulib_extra_files" = x; then
628 use_gnulib=false
629 else
630 use_gnulib=true
633 # -------- Fetch auxiliary files from the network. --------------------------
635 autopull_usage() {
636 cat <<EOF
637 Usage: $me [OPTION]...
638 Bootstrap this package from the checked-out sources.
640 Optional environment variables:
641 GNULIB_SRCDIR Specifies the local directory where gnulib
642 sources reside. Use this if you already
643 have gnulib sources on your machine, and
644 you want to use these sources.
645 GNULIB_REFDIR Specifies the local directory where a gnulib
646 repository (with a .git subdirectory) resides.
647 Use this if you already have gnulib sources
648 and history on your machine, and do not want
649 to waste your bandwidth downloading them again.
650 GNULIB_URL Cloneable URL of the gnulib repository.
652 Options:
653 --bootstrap-sync if this bootstrap script is not identical to
654 the version in the local gnulib sources,
655 update this script, and then restart it with
656 /bin/sh or the shell \$CONFIG_SHELL
657 --no-bootstrap-sync do not check whether bootstrap is out of sync
658 --force attempt to bootstrap even if the sources seem
659 not to have been checked out
660 --no-git do not use git to update gnulib. Requires that
661 \$GNULIB_SRCDIR or the --gnulib-srcdir option
662 points to a gnulib repository with the correct
663 revision
664 --skip-po do not download po files
666 bootstrap_print_option_usage_hook
667 cat <<EOF
668 If the file bootstrap.conf exists in the same directory as this script, its
669 contents are read as shell variables to configure the bootstrap.
671 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
672 are honored.
674 Gnulib sources can be fetched in various ways:
676 * If the environment variable GNULIB_SRCDIR is set (either as an
677 environment variable or via the --gnulib-srcdir option), then sources
678 are fetched from that local directory. If it is a git repository and
679 the configuration variable GNULIB_REVISION is set in bootstrap.conf,
680 then that revision is checked out.
682 * Otherwise, if this package is in a git repository with a 'gnulib'
683 submodule configured, then that submodule is initialized and updated
684 and sources are fetched from there. If GNULIB_REFDIR is set (either
685 as an environment variable or via the --gnulib-refdir option) and is
686 a git repository, then it is used as a reference.
688 * Otherwise, if the 'gnulib' directory does not exist, Gnulib sources
689 are cloned into that directory using git from \$GNULIB_URL, defaulting
690 to $default_gnulib_url.
691 If the configuration variable GNULIB_REVISION is set in bootstrap.conf,
692 then that revision is checked out.
694 * Otherwise, the existing Gnulib sources in the 'gnulib' directory are
695 used. If it is a git repository and the configuration variable
696 GNULIB_REVISION is set in bootstrap.conf, then that revision is
697 checked out.
699 If you maintain a package and want to pin a particular revision of the
700 Gnulib sources that has been tested with your package, then there are
701 two possible approaches: either configure a 'gnulib' submodule with the
702 appropriate revision, or set GNULIB_REVISION (and if necessary
703 GNULIB_URL) in bootstrap.conf.
705 Running without arguments will suffice in most cases.
709 # Fetch auxiliary files that are omitted from the version control
710 # repository of this package.
711 autopull()
713 # Ensure that CDPATH is not set. Otherwise, the output from cd
714 # would cause trouble in at least one use below.
715 (unset CDPATH) >/dev/null 2>&1 && unset CDPATH
717 # Parse options.
719 # Use git to update gnulib sources
720 use_git=true
722 for option
724 case $option in
725 --help)
726 autopull_usage
727 return;;
728 --version)
729 set -e
730 echo "autopull.sh $scriptlibversion"
731 echo "$copyright"
732 return 0
734 --skip-po)
735 SKIP_PO=t;;
736 --force)
737 checkout_only_file=;;
738 --bootstrap-sync)
739 bootstrap_sync=true;;
740 --no-bootstrap-sync)
741 bootstrap_sync=false;;
742 --no-git)
743 use_git=false;;
745 bootstrap_option_hook $option || die "$option: unknown option";;
746 esac
747 done
749 $use_git || test -n "$GNULIB_SRCDIR" \
750 || die "Error: --no-git requires \$GNULIB_SRCDIR environment variable or --gnulib-srcdir option"
751 test -z "$GNULIB_SRCDIR" || test -d "$GNULIB_SRCDIR" \
752 || die "Error: \$GNULIB_SRCDIR environment variable or --gnulib-srcdir option is specified, but does not denote a directory"
754 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
755 die "Running this script from a non-checked-out distribution is risky."
758 check_build_prerequisites $use_git
760 if $use_gnulib || $bootstrap_sync; then
761 prepare_GNULIB_SRCDIR
762 if $bootstrap_sync; then
763 upgrade_bootstrap
767 # Find sha1sum, named gsha1sum on MacPorts, shasum on Mac OS X 10.6.
768 # Also find the compatible sha1 utility on the BSDs
769 if test x"$SKIP_PO" = x; then
770 find_tool SHA1SUM sha1sum gsha1sum shasum sha1
773 # See if we can use gnulib's git-merge-changelog merge driver.
774 if $use_git && test -d .git && check_exists git; then
775 if git config merge.merge-changelog.driver >/dev/null ; then
777 elif check_exists git-merge-changelog; then
778 echo "$0: initializing git-merge-changelog driver"
779 git config merge.merge-changelog.name 'GNU-style ChangeLog merge driver'
780 git config merge.merge-changelog.driver 'git-merge-changelog %O %A %B'
781 else
782 echo "$0: consider installing git-merge-changelog from gnulib"
786 case $SKIP_PO in
788 if test -d po; then
789 update_po_files po $package || return
792 if test -d runtime-po; then
793 update_po_files runtime-po $package-runtime || return
794 fi;;
795 esac
797 # ---------------------------------------------------------------------------
799 bootstrap_post_pull_hook \
800 || die "bootstrap_post_pull_hook failed"
802 # Don't proceed if there are uninitialized submodules. In particular,
803 # autogen.sh will remove dangling links, which might be links into
804 # uninitialized submodules.
805 # But it's OK if the 'gnulib' submodule is uninitialized, as long as
806 # GNULIB_SRCDIR is set.
807 if $use_git; then
808 # Uninitialized submodules are listed with an initial dash.
809 uninitialized=`git submodule | grep '^-' | awk '{ print $2 }'`
810 if test -n "$GNULIB_SRCDIR"; then
811 uninitialized=`echo "$uninitialized" | grep -v '^gnulib$'`
813 if test -n "$uninitialized"; then
814 die "Some git submodules are not initialized: "`echo "$uninitialized" | tr '\n' ',' | sed -e 's|,$|.|'`" Either use option '--no-git', or run 'git submodule update --init' and bootstrap again."
818 if test -f "$medir"/autogen.sh; then
819 echo "$0: done. Now you can run '$medir/autogen.sh'."
823 # ----------------------------- Get translations. -----------------------------
825 download_po_files() {
826 subdir=$1
827 domain=$2
828 echo "$me: getting translations into $subdir for $domain..."
829 cmd=$(printf "$po_download_command_format" "$subdir" "$domain")
830 eval "$cmd"
833 # Mirror .po files to $po_dir/.reference and copy only the new
834 # or modified ones into $po_dir. Also update $po_dir/LINGUAS.
835 # Note po files that exist locally only are left in $po_dir but will
836 # not be included in LINGUAS and hence will not be distributed.
837 update_po_files() {
838 # Directory containing primary .po files.
839 # Overwrite them only when we're sure a .po file is new.
840 po_dir=$1
841 domain=$2
843 # Mirror *.po files into this dir.
844 # Usually contains *.s1 checksum files.
845 ref_po_dir="$po_dir/.reference"
847 test -d $ref_po_dir || mkdir $ref_po_dir || return
848 download_po_files $ref_po_dir $domain \
849 && ls "$ref_po_dir"/*.po 2>/dev/null |
850 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" || return
852 langs=$(cd $ref_po_dir && echo *.po | sed 's/\.po//g')
853 test "$langs" = '*' && langs=x
854 for po in $langs; do
855 case $po in x) continue;; esac
856 new_po="$ref_po_dir/$po.po"
857 cksum_file="$ref_po_dir/$po.s1"
858 if ! test -f "$cksum_file" ||
859 ! test -f "$po_dir/$po.po" ||
860 ! $SHA1SUM -c "$cksum_file" < "$new_po" > /dev/null 2>&1; then
861 echo "$me: updated $po_dir/$po.po..."
862 cp "$new_po" "$po_dir/$po.po" \
863 && $SHA1SUM < "$new_po" > "$cksum_file" || return
865 done
868 # -------- Generate files automatically from existing sources. --------------
870 autogen_usage() {
871 cat <<EOF
872 Usage: $me [OPTION]...
873 Bootstrap this package from the checked-out sources.
875 Optional environment variables:
876 GNULIB_SRCDIR Specifies the local directory where gnulib
877 sources reside. Use this if you already
878 have gnulib sources on your machine, and
879 you want to use these sources.
881 Options:
882 --copy copy files instead of creating symbolic links
883 --force attempt to bootstrap even if the sources seem
884 not to have been checked out
886 bootstrap_print_option_usage_hook
887 cat <<EOF
888 If the file bootstrap.conf exists in the same directory as this script, its
889 contents are read as shell variables to configure the bootstrap.
891 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
892 are honored.
894 Gnulib sources are assumed to be present:
895 * in \$GNULIB_SRCDIR, if that environment variable is set,
896 * otherwise, in the 'gnulib' submodule, if such a submodule is configured,
897 * otherwise, in the 'gnulib' subdirectory.
899 Running without arguments will suffice in most cases.
904 version_controlled_file() {
905 parent=$1
906 file=$2
907 if test -d .git; then
908 git rm -n "$file" > /dev/null 2>&1
909 elif test -d .svn; then
910 svn log -r HEAD "$file" > /dev/null 2>&1
911 elif test -d CVS; then
912 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev/null |
913 grep '^/[^/]*/[0-9]' > /dev/null
914 else
915 warn_ "no version control for $file?"
916 false
920 # Strip blank and comment lines to leave significant entries.
921 gitignore_entries() {
922 sed '/^#/d; /^$/d' "$@"
925 # If $STR is not already on a line by itself in $FILE, insert it at the start.
926 # Entries are inserted at the start of the ignore list to ensure existing
927 # entries starting with ! are not overridden. Such entries support
928 # whitelisting exceptions after a more generic blacklist pattern.
929 insert_if_absent() {
930 file=$1
931 str=$2
932 test -f $file || touch $file
933 test -r $file || die "Error: failed to read ignore file: $file"
934 duplicate_entries=$(gitignore_entries $file | sort | uniq -d)
935 if [ "$duplicate_entries" ] ; then
936 die "Error: Duplicate entries in $file: " $duplicate_entries
938 linesold=$(gitignore_entries $file | wc -l)
939 linesnew=$( { echo "$str"; cat $file; } | gitignore_entries | sort -u | wc -l)
940 if [ $linesold != $linesnew ] ; then
941 { echo "$str" | cat - $file > $file.bak && mv $file.bak $file; } \
942 || die "insert_if_absent $file $str: failed"
946 # Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
947 # insert_if_absent.
948 insert_vc_ignore() {
949 vc_ignore_file="$1"
950 pattern="$2"
951 case $vc_ignore_file in
952 *.gitignore)
953 # A .gitignore entry that does not start with '/' applies
954 # recursively to subdirectories, so prepend '/' to every
955 # .gitignore entry.
956 pattern=$(echo "$pattern" | sed s,^,/,);;
957 esac
958 insert_if_absent "$vc_ignore_file" "$pattern"
961 symlink_to_dir()
963 src=$1/$2
964 dst=${3-$2}
966 test -f "$src" && {
968 # If the destination directory doesn't exist, create it.
969 # This is required at least for "lib/uniwidth/cjk.h".
970 dst_dir=$(dirname "$dst")
971 if ! test -d "$dst_dir"; then
972 mkdir -p "$dst_dir"
974 # If we've just created a directory like lib/uniwidth,
975 # tell version control system(s) it's ignorable.
976 # FIXME: for now, this does only one level
977 parent=$(dirname "$dst_dir")
978 for dot_ig in x $vc_ignore; do
979 test $dot_ig = x && continue
980 ig=$parent/$dot_ig
981 insert_vc_ignore $ig "${dst_dir##*/}"
982 done
985 if $copy; then
987 test ! -h "$dst" || {
988 echo "$me: rm -f $dst" &&
989 rm -f "$dst"
991 } &&
992 test -f "$dst" &&
993 cmp -s "$src" "$dst" || {
994 echo "$me: cp -fp $src $dst" &&
995 cp -fp "$src" "$dst"
997 else
998 # Leave any existing symlink alone, if it already points to the source,
999 # so that broken build tools that care about symlink times
1000 # aren't confused into doing unnecessary builds. Conversely, if the
1001 # existing symlink's timestamp is older than the source, make it afresh,
1002 # so that broken tools aren't confused into skipping needed builds. See
1003 # <https://lists.gnu.org/r/bug-gnulib/2011-05/msg00326.html>.
1004 test -h "$dst" &&
1005 src_ls=$(ls -diL "$src" 2>/dev/null) && set $src_ls && src_i=$1 &&
1006 dst_ls=$(ls -diL "$dst" 2>/dev/null) && set $dst_ls && dst_i=$1 &&
1007 test "$src_i" = "$dst_i" &&
1008 both_ls=$(ls -dt "$src" "$dst") &&
1009 test "X$both_ls" = "X$dst$nl$src" || {
1010 dot_dots=
1011 case $src in
1012 /*) ;;
1014 case /$dst/ in
1015 *//* | */../* | */./* | /*/*/*/*/*/)
1016 die "invalid symlink calculation: $src -> $dst";;
1017 /*/*/*/*/) dot_dots=../../../;;
1018 /*/*/*/) dot_dots=../../;;
1019 /*/*/) dot_dots=../;;
1020 esac;;
1021 esac
1023 echo "$me: ln -fs $dot_dots$src $dst" &&
1024 ln -fs "$dot_dots$src" "$dst"
1030 # Regenerate all autogeneratable files that are omitted from the
1031 # version control repository. In particular, regenerate all
1032 # aclocal.m4, config.h.in, Makefile.in, configure files with new
1033 # versions of autoconf or automake.
1034 autogen()
1036 # Ensure that CDPATH is not set. Otherwise, the output from cd
1037 # would cause trouble in at least one use below.
1038 (unset CDPATH) >/dev/null 2>&1 && unset CDPATH
1040 # Environment variables that may be set by the user.
1041 : "${AUTOPOINT=autopoint}"
1042 : "${AUTORECONF=autoreconf}"
1044 if test "$vc_ignore" = auto; then
1045 vc_ignore=
1046 test -d .git && vc_ignore=.gitignore
1047 test -d CVS && vc_ignore="$vc_ignore .cvsignore"
1051 # Parse options.
1053 # Whether to use copies instead of symlinks.
1054 copy=false
1056 for option
1058 case $option in
1059 --help)
1060 autogen_usage
1061 return;;
1062 --version)
1063 set -e
1064 echo "autogen.sh $scriptlibversion"
1065 echo "$copyright"
1066 return 0
1068 --force)
1069 checkout_only_file=;;
1070 --copy)
1071 copy=true;;
1073 bootstrap_option_hook $option || die "$option: unknown option";;
1074 esac
1075 done
1077 test -z "$GNULIB_SRCDIR" || test -d "$GNULIB_SRCDIR" \
1078 || die "Error: \$GNULIB_SRCDIR environment variable or --gnulib-srcdir option is specified, but does not denote a directory"
1080 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
1081 die "Running this script from a non-checked-out distribution is risky."
1084 if $use_gnulib; then
1085 if test -z "$GNULIB_SRCDIR"; then
1086 gnulib_path=$(test -f .gitmodules && git config --file .gitmodules submodule.gnulib.path)
1087 test -z "$gnulib_path" && gnulib_path=gnulib
1088 GNULIB_SRCDIR=$gnulib_path
1092 # Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
1093 found_aux_dir=no
1094 grep '^[ ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'])' configure.ac \
1095 >/dev/null && found_aux_dir=yes
1096 grep '^[ ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
1097 >/dev/null && found_aux_dir=yes
1098 test $found_aux_dir = yes \
1099 || die "configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
1101 # If $build_aux doesn't exist, create it now, otherwise some bits
1102 # below will malfunction. If creating it, also mark it as ignored.
1103 if test ! -d $build_aux; then
1104 mkdir $build_aux
1105 for dot_ig in x $vc_ignore; do
1106 test $dot_ig = x && continue
1107 insert_vc_ignore $dot_ig $build_aux
1108 done
1111 check_build_prerequisites false
1113 use_libtool=0
1114 # We'd like to use grep -E, to see if any of LT_INIT,
1115 # AC_PROG_LIBTOOL, AM_PROG_LIBTOOL is used in configure.ac,
1116 # but that's not portable enough (e.g., for Solaris).
1117 grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac >/dev/null \
1118 && use_libtool=1
1119 grep '^[ ]*LT_INIT' configure.ac >/dev/null \
1120 && use_libtool=1
1121 if test $use_libtool = 1; then
1122 find_tool LIBTOOLIZE glibtoolize libtoolize
1125 if $use_gnulib; then
1126 gnulib_tool=$GNULIB_SRCDIR/gnulib-tool
1127 <$gnulib_tool || return
1130 # NOTE: we have to be careful to run both autopoint and libtoolize
1131 # before gnulib-tool, since gnulib-tool is likely to provide newer
1132 # versions of files "installed" by these two programs.
1133 # Then, *after* gnulib-tool (see below), we have to be careful to
1134 # run autoreconf in such a way that it does not run either of these
1135 # two just-pre-run programs.
1137 # Import from gettext.
1138 with_gettext=yes
1139 grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac >/dev/null || \
1140 with_gettext=no
1142 if test $with_gettext = yes || test $use_libtool = 1; then
1144 tempbase=.bootstrap$$
1145 trap "rm -f $tempbase.0 $tempbase.1" HUP INT PIPE TERM
1147 > $tempbase.0 > $tempbase.1 &&
1148 find . ! -type d -print | sort > $tempbase.0 || return
1150 if test $with_gettext = yes; then
1151 # Released autopoint has the tendency to install macros that have been
1152 # obsoleted in current gnulib, so run this before gnulib-tool.
1153 echo "$0: $AUTOPOINT --force"
1154 $AUTOPOINT --force || return
1157 # Autoreconf runs aclocal before libtoolize, which causes spurious
1158 # warnings if the initial aclocal is confused by the libtoolized
1159 # (or worse out-of-date) macro directory.
1160 # libtoolize 1.9b added the --install option; but we support back
1161 # to libtoolize 1.5.22, where the install action was default.
1162 if test $use_libtool = 1; then
1163 install=
1164 case $($LIBTOOLIZE --help) in
1165 *--install*) install=--install ;;
1166 esac
1167 echo "running: $LIBTOOLIZE $install --copy"
1168 $LIBTOOLIZE $install --copy
1171 find . ! -type d -print | sort >$tempbase.1
1172 old_IFS=$IFS
1173 IFS=$nl
1174 for file in $(comm -13 $tempbase.0 $tempbase.1); do
1175 IFS=$old_IFS
1176 parent=${file%/*}
1177 version_controlled_file "$parent" "$file" || {
1178 for dot_ig in x $vc_ignore; do
1179 test $dot_ig = x && continue
1180 ig=$parent/$dot_ig
1181 insert_vc_ignore "$ig" "${file##*/}"
1182 done
1184 done
1185 IFS=$old_IFS
1187 rm -f $tempbase.0 $tempbase.1
1188 trap - HUP INT PIPE TERM
1191 # Import from gnulib.
1193 if $use_gnulib; then
1194 gnulib_tool_options="\
1195 --no-changelog\
1196 --aux-dir=$build_aux\
1197 --doc-base=$doc_base\
1198 --lib=$gnulib_name\
1199 --m4-base=$m4_base/\
1200 --source-base=$source_base/\
1201 --tests-base=$tests_base\
1202 --local-dir=$local_gl_dir\
1203 $gnulib_tool_option_extras\
1205 if test $use_libtool = 1; then
1206 case "$gnulib_tool_options " in
1207 *' --libtool '*) ;;
1208 *) gnulib_tool_options="$gnulib_tool_options --libtool" ;;
1209 esac
1211 echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
1212 $gnulib_tool $gnulib_tool_options --import $gnulib_modules \
1213 || die "gnulib-tool failed"
1215 for file in $gnulib_files; do
1216 symlink_to_dir "$GNULIB_SRCDIR" $file \
1217 || die "failed to symlink $file"
1218 done
1221 bootstrap_post_import_hook \
1222 || die "bootstrap_post_import_hook failed"
1224 # Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
1225 # gnulib-populated directories. Such .m4 files would cause aclocal to fail.
1226 # The following requires GNU find 4.2.3 or newer. Considering the usual
1227 # portability constraints of this script, that may seem a very demanding
1228 # requirement, but it should be ok. Ignore any failure, which is fine,
1229 # since this is only a convenience to help developers avoid the relatively
1230 # unusual case in which a symlinked-to .m4 file is git-removed from gnulib
1231 # between successive runs of this script.
1232 find "$m4_base" "$source_base" \
1233 -depth \( -name '*.m4' -o -name '*.[ch]' \) \
1234 -type l -xtype l -delete > /dev/null 2>&1
1236 # Invoke autoreconf with --force --install to ensure upgrades of tools
1237 # such as ylwrap.
1238 AUTORECONFFLAGS="--verbose --install --force -I $m4_base $ACLOCAL_FLAGS"
1240 # Some systems (RHEL 5) are using ancient autotools, for which the
1241 # --no-recursive option had not been invented. Detect that lack and
1242 # omit the option when it's not supported. FIXME in 2017: remove this
1243 # hack when RHEL 5 autotools are updated, or when they become irrelevant.
1244 case $($AUTORECONF --help) in
1245 *--no-recursive*) AUTORECONFFLAGS="$AUTORECONFFLAGS --no-recursive";;
1246 esac
1248 # Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
1249 echo "running: AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS"
1250 AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS \
1251 || die "autoreconf failed"
1253 # Get some extra files from gnulib, overriding existing files.
1254 for file in $gnulib_extra_files; do
1255 case $file in
1256 */INSTALL) dst=INSTALL;;
1257 build-aux/*) dst=$build_aux/${file#build-aux/};;
1258 *) dst=$file;;
1259 esac
1260 symlink_to_dir "$GNULIB_SRCDIR" $file $dst \
1261 || die "failed to symlink $file"
1262 done
1264 if test $with_gettext = yes; then
1265 # Create gettext configuration.
1266 echo "$0: Creating po/Makevars from po/Makevars.template ..."
1267 rm -f po/Makevars
1268 sed '
1269 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
1270 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
1271 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
1272 /^XGETTEXT_OPTIONS *=/{
1273 s/$/ \\/
1275 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
1277 ' po/Makevars.template >po/Makevars \
1278 || die 'cannot generate po/Makevars'
1280 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
1281 # If only the 'gettext-h' module is in use, assume autopoint already
1282 # put the correct version of this file into place.
1283 case $gnulib_modules in
1284 *gettext-h*) ;;
1285 *gettext*)
1286 cp $GNULIB_SRCDIR/build-aux/po/Makefile.in.in po/Makefile.in.in \
1287 || die "cannot create po/Makefile.in.in"
1289 esac
1291 if test -d runtime-po; then
1292 # Similarly for runtime-po/Makevars, but not quite the same.
1293 rm -f runtime-po/Makevars
1294 sed '
1295 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
1296 /^subdir *=.*/s/=.*/= runtime-po/
1297 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
1298 /^XGETTEXT_OPTIONS *=/{
1299 s/$/ \\/
1301 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
1303 ' po/Makevars.template >runtime-po/Makevars \
1304 || die 'cannot generate runtime-po/Makevars'
1306 # Copy identical files from po to runtime-po.
1307 (cd po && cp -p Makefile.in.in *-quot *.header *.sed *.sin ../runtime-po)
1311 bootstrap_epilogue
1313 echo "$0: done. Now you can run './configure'."
1316 # ----------------------------------------------------------------------------
1318 # Local Variables:
1319 # eval: (add-hook 'before-save-hook 'time-stamp)
1320 # time-stamp-start: "scriptlibversion="
1321 # time-stamp-format: "%:y-%02m-%02d.%02H"
1322 # time-stamp-time-zone: "UTC0"
1323 # time-stamp-end: "; # UTC"
1324 # End:
1326 usage() {
1327 cat <<EOF
1328 Usage: $me [OPTION]...
1329 Bootstrap this package from the checked-out sources.
1331 Optional environment variables:
1332 GNULIB_SRCDIR Specifies the local directory where gnulib
1333 sources reside. Use this if you already
1334 have gnulib sources on your machine, and
1335 do not want to waste your bandwidth downloading
1336 them again.
1337 GNULIB_URL Cloneable URL of the gnulib repository.
1339 Options:
1341 --pull Do phase 1: pull files from network
1342 --gen Do phase 2: generate from local files.
1343 (The default is to do both phases.)
1345 --gnulib-srcdir=DIRNAME specify the local directory where gnulib
1346 sources reside. Use this if you already
1347 have gnulib sources on your machine, and
1348 you want to use these sources. Defaults
1349 to \$GNULIB_SRCDIR
1350 --gnulib-refdir=DIRNAME specify the local directory where a gnulib
1351 repository (with a .git subdirectory) resides.
1352 Use this if you already have gnulib sources
1353 and history on your machine, and do not want
1354 to waste your bandwidth downloading them again.
1355 Defaults to \$GNULIB_REFDIR
1357 --bootstrap-sync if this bootstrap script is not identical to
1358 the version in the local gnulib sources,
1359 update this script, and then restart it with
1360 /bin/sh or the shell \$CONFIG_SHELL
1361 --no-bootstrap-sync do not check whether bootstrap is out of sync
1363 --copy copy files instead of creating symbolic links
1364 --force attempt to bootstrap even if the sources seem
1365 not to have been checked out
1366 --no-git do not use git to update gnulib. Requires that
1367 \$GNULIB_SRCDIR or the --gnulib-srcdir option
1368 points to a gnulib repository with the correct
1369 revision
1370 --skip-po do not download po files
1372 bootstrap_print_option_usage_hook
1373 cat <<EOF
1374 If the file bootstrap.conf exists in the same directory as this script, its
1375 contents are read as shell variables to configure the bootstrap.
1377 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
1378 are honored.
1380 Gnulib sources can be fetched in various ways:
1382 * If the environment variable GNULIB_SRCDIR is set (either as an
1383 environment variable or via the --gnulib-srcdir option), then sources
1384 are fetched from that local directory. If it is a git repository and
1385 the configuration variable GNULIB_REVISION is set in bootstrap.conf,
1386 then that revision is checked out.
1388 * Otherwise, if this package is in a git repository with a 'gnulib'
1389 submodule configured, then that submodule is initialized and updated
1390 and sources are fetched from there. If GNULIB_REFDIR is set (either
1391 as an environment variable or via the --gnulib-refdir option) and is
1392 a git repository, then it is used as a reference.
1394 * Otherwise, if the 'gnulib' directory does not exist, Gnulib sources
1395 are cloned into that directory using git from \$GNULIB_URL, defaulting
1396 to $default_gnulib_url.
1397 If the configuration variable GNULIB_REVISION is set in bootstrap.conf,
1398 then that revision is checked out.
1400 * Otherwise, the existing Gnulib sources in the 'gnulib' directory are
1401 used. If it is a git repository and the configuration variable
1402 GNULIB_REVISION is set in bootstrap.conf, then that revision is
1403 checked out.
1405 If you maintain a package and want to pin a particular revision of the
1406 Gnulib sources that has been tested with your package, then there are
1407 two possible approaches: either configure a 'gnulib' submodule with the
1408 appropriate revision, or set GNULIB_REVISION (and if necessary
1409 GNULIB_URL) in bootstrap.conf.
1411 Running without arguments will suffice in most cases.
1415 # Parse options.
1417 # Whether to pull and generate.
1418 pull=false
1419 gen=false
1421 # Whether to use copies instead of symlinks.
1422 copy=false
1424 # Use git to update gnulib sources
1425 use_git=true
1427 for option
1429 case $option in
1430 --help)
1431 usage
1432 exit;;
1433 --version)
1434 set -e
1435 echo "bootstrap $scriptversion lib $scriptlibversion"
1436 echo "$copyright"
1437 exit 0
1439 --pull)
1440 pull=true;;
1441 --gen)
1442 gen=true;;
1443 --gnulib-srcdir=*)
1444 GNULIB_SRCDIR=${option#--gnulib-srcdir=};;
1445 --gnulib-refdir=*)
1446 GNULIB_REFDIR=${option#--gnulib-refdir=};;
1447 --skip-po)
1448 SKIP_PO=t;;
1449 --force)
1450 checkout_only_file=;;
1451 --copy)
1452 copy=true;;
1453 --bootstrap-sync)
1454 bootstrap_sync=true;;
1455 --no-bootstrap-sync)
1456 bootstrap_sync=false;;
1457 --no-git)
1458 use_git=false;;
1460 bootstrap_option_hook $option || die "$option: unknown option";;
1461 esac
1462 done
1464 # Default is to do both.
1465 $pull || $gen || pull=true gen=true
1467 $use_git || test -n "$GNULIB_SRCDIR" \
1468 || die "Error: --no-git requires \$GNULIB_SRCDIR environment variable or --gnulib-srcdir option"
1469 test -z "$GNULIB_SRCDIR" || test -d "$GNULIB_SRCDIR" \
1470 || die "Error: \$GNULIB_SRCDIR environment variable or --gnulib-srcdir option is specified, but does not denote a directory"
1472 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
1473 die "Bootstrapping from a non-checked-out distribution is risky."
1476 check_build_prerequisites $use_git
1478 if $bootstrap_sync; then
1479 prepare_GNULIB_SRCDIR
1480 upgrade_bootstrap
1481 # Since we have now upgraded if needed, no need to try it a second time below.
1482 bootstrap_sync=false
1485 echo "$0: Bootstrapping from checked-out $package sources..."
1487 # Pass GNULIB_SRCDIR and GNULIB_REFDIR to any subsidiary commands that care.
1488 export GNULIB_SRCDIR
1489 export GNULIB_REFDIR
1491 if $pull && { $use_git || test -z "$SKIP_PO"; }; then
1492 autopull \
1493 `if $bootstrap_sync; then echo ' --bootstrap-sync'; else echo ' --no-bootstrap-sync'; fi` \
1494 `if test -z "$checkout_only_file"; then echo ' --force'; fi` \
1495 `if ! $use_git; then echo ' --no-git'; fi` \
1496 `if test -n "$SKIP_PO"; then echo ' --skip-po'; fi` \
1497 || die "could not fetch auxiliary files"
1500 if $gen; then
1501 autogen \
1502 `if $copy; then echo ' --copy'; fi` \
1503 `if test -z "$checkout_only_file"; then echo ' --force'; fi` \
1504 || die "could not generate auxiliary files"
1507 # ----------------------------------------------------------------------------
1509 # Local Variables:
1510 # eval: (add-hook 'before-save-hook 'time-stamp)
1511 # time-stamp-start: "scriptversion="
1512 # time-stamp-format: "%:y-%02m-%02d.%02H"
1513 # time-stamp-time-zone: "UTC0"
1514 # time-stamp-end: "; # UTC"
1515 # End: