2 # DO NOT EDIT! GENERATED AUTOMATICALLY!
4 # Bootstrap this package from checked-out sources.
6 scriptversion
=2023-07-01.18
; # 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.
36 # Read the function library and the configuration.
38 # A library of shell functions for autopull.sh, autogen.sh, and bootstrap.
40 scriptlibversion
=2023-07-01.17
; # 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.
68 # Ensure file names are sorted consistently across platforms.
72 # Honor $PERL, but work even if there is none.
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...
92 *$nl*) me_
=$
(printf "$me"|
tr "$nl|" '??')
93 printf "$warnf_format_" "$@" |
sed "s|^|$me_: |" ;;
94 *) printf "$me: $warnf_format_" "$@" ;;
101 # If IFS does not start with ' ', set it and emit the warning in a subshell.
103 ' '*) warnf_
'%s\n' "$*";;
104 *) (IFS
=' '; warn_
"$@");;
109 die
() { warn_
"$@"; exit 1; }
111 # ------------------------------ Configuration. ------------------------------
113 # Directory that contains package-specific gnulib modules and/or overrides.
116 # Name of the Makefile.am
120 # List of gnulib modules needed.
123 # Any gnulib files needed that are not in modules.
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
='
160 /^[^,]*,[^,]*,[^,]*,[ []*\([^][ ,)]\)/{
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
188 build-aux/texinfo.tex
190 build-aux/config.guess
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.
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.
226 # Set this to true in bootstrap.conf to enable --bootstrap-sync by
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 -------------------------
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
)
247 ($1 --version </dev
/null
) >/dev
/null
2>&1
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
263 # split on '.' and compare each component
266 p1
=$
(echo "$ver1" | cut
-d.
-f$i)
267 p2
=$
(echo "$ver2" | cut
-d.
-f$i)
271 elif [ ! "$p2" ]; then
274 elif [ ! "$p1" = "$p2" ]; then
275 if [ "$p1" -gt "$p2" ] 2>/dev
/null
; then # numeric comparison
277 elif [ "$p2" -gt "$p1" ] 2>/dev
/null
; then # numeric comparison
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
294 # Move version to start of line.
295 s/.*[v ]\([0-9]\)/\1/
297 # Skip lines that do not start with version.
300 # Remove characters after the version.
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
314 $app --version >/dev
/null
2>&1 ||
{ $app --version; return 1; }
316 $app --version 2>&1 |
sed -n "$get_version_sed"
322 while read app req_ver
; do
323 # We only need libtoolize from the libtool package.
324 if test "$app" = libtool
; then
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
335 GZIP
) ;; # Do not use $GZIP: it contains gzip options.
336 PERL
::*) ;; # Keep perl modules as-is
337 *) eval "app=\${$appvar-$app}" ;;
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 # preexisting 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.
347 automake-ng|aclocal-ng
)
349 ($app --version |
grep '(GNU automake-ng)') >/dev
/null
2>&1 ||
{
350 warn_
"Error: '$app' not found or not from Automake-NG"
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.
357 # Extract module name
359 if ! $PERL -m"$app" -e 'exit 0' >/dev
/null
2>&1; then
360 warn_
"Error: perl module '$app' not found"
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"
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"
380 latest_ver
=$
(sort_ver
$req_ver $inst_ver | cut
-d' ' -f2)
381 if [ ! "$latest_ver" = "$inst_ver" ]; then
383 "Error: '$app' version == $inst_ver is too old" \
384 " '$app' version >= $req_ver is required"
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
()
407 # gnulib-tool requires at least automake and autoconf.
408 # If either is not listed, add it (with minimum version) as a prerequisite.
411 *) buildreq
="automake 1.9
416 *) buildreq
="autoconf 2.59
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
431 if ! printf '%s' "$buildreq" | check_versions
; then
433 if test -f README-prereq
; then
434 die
"See README-prereq for how to get the prerequisite programs"
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.
461 eval "find_tool_res=\$$find_tool_envvar"
462 if test x
"$find_tool_res" = x
; then
464 if check_exists
$i; then
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.
483 # XXX It's a bad idea to erase the submodule directory if it contains local
485 rm -fr "$gnulib_path"
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," \
501 "but does not contain gnulib-tool"
503 gnulib_path
=$
(git_modules_config submodule.gnulib.path
)
504 test -z "$gnulib_path" && gnulib_path
=gnulib
506 # Get gnulib files. Populate $gnulib_path, possibly updating a
507 # submodule, for use in the rest of the script.
509 if test -n "$GNULIB_REFDIR" && test -d "$GNULIB_REFDIR"/.git \
510 && git_modules_config submodule.gnulib.url
>/dev
/null
; then
511 # Use GNULIB_REFDIR as a reference.
512 echo "$0: getting gnulib files..."
513 if git submodule
-h|
grep -- --reference > /dev
/null
; then
514 # Prefer the one-liner available in git 1.6.4 or newer.
515 git submodule update
--init --reference "$GNULIB_REFDIR" \
516 "$gnulib_path" ||
exit $?
518 # This fallback allows at least git 1.5.5.
519 if test -f "$gnulib_path"/gnulib-tool
; then
520 # Since file already exists, assume submodule init already complete.
521 git submodule update
-- "$gnulib_path" ||
exit $?
523 # Older git can't clone into an empty directory.
524 rmdir "$gnulib_path" 2>/dev
/null
525 git clone
--reference "$GNULIB_REFDIR" \
526 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
527 && git submodule init
-- "$gnulib_path" \
528 && git submodule update
-- "$gnulib_path" \
533 # GNULIB_REFDIR is not set or not usable. Ignore it.
534 if git_modules_config submodule.gnulib.url
>/dev
/null
; then
535 echo "$0: getting gnulib files..."
536 git submodule init
-- "$gnulib_path" ||
exit $?
537 git submodule update
-- "$gnulib_path" ||
exit $?
539 elif [ ! -d "$gnulib_path" ]; then
540 echo "$0: getting gnulib files..."
542 trap cleanup_gnulib HUP INT PIPE TERM
545 if test -z "$GNULIB_REVISION"; then
546 if git clone
-h 2>&1 |
grep -- --depth > /dev
/null
; then
549 git clone
$shallow ${GNULIB_URL:-$default_gnulib_url} "$gnulib_path" \
552 if git fetch
-h 2>&1 |
grep -- --depth > /dev
/null
; then
555 mkdir
-p "$gnulib_path"
556 # Only want a shallow checkout of $GNULIB_REVISION, but git does not
557 # support cloning by commit hash. So attempt a shallow fetch by commit
558 # hash to minimize the amount of data downloaded and changes needed to
559 # be processed, which can drastically reduce download and processing
560 # time for checkout. If the fetch by commit fails, a shallow fetch can
561 # not be performed because we do not know what the depth of the commit
562 # is without fetching all commits. So fall back to fetching all
564 git
-C "$gnulib_path" init
565 git
-C "$gnulib_path" remote add origin \
566 ${GNULIB_URL:-$default_gnulib_url}
567 git
-C "$gnulib_path" fetch
$shallow origin
"$GNULIB_REVISION" \
568 || git
-C "$gnulib_path" fetch origin \
570 git
-C "$gnulib_path" reset --hard FETCH_HEAD
573 trap - HUP INT PIPE TERM
576 GNULIB_SRCDIR
=$gnulib_path
577 # Verify that the submodule contains a gnulib checkout.
578 test -f "$gnulib_path/gnulib-tool" \
579 || die
"Error: $gnulib_path is supposed to contain a gnulib checkout," \
580 "but does not contain gnulib-tool"
583 # XXX Should this be done if $use_git is false?
584 if test -d "$GNULIB_SRCDIR"/.git
&& test -n "$GNULIB_REVISION" \
585 && ! git_modules_config submodule.gnulib.url
>/dev
/null
; then
586 (cd "$GNULIB_SRCDIR" && git checkout
"$GNULIB_REVISION") || cleanup_gnulib
589 # $GNULIB_SRCDIR now points to the version of gnulib to use, and
590 # we no longer need to use git or $gnulib_path below here.
593 # -------- Upgrading bootstrap to the version found in GNULIB_SRCDIR. --------
597 if test -f "$medir"/bootstrap-funclib.sh
; then
599 { cmp -s "$medir"/bootstrap
"$GNULIB_SRCDIR/top/bootstrap" \
600 && cmp -s "$medir"/bootstrap-funclib.sh \
601 "$GNULIB_SRCDIR/top/bootstrap-funclib.sh" \
602 && cmp -s "$medir"/autopull.sh
"$GNULIB_SRCDIR/top/autopull.sh" \
603 && cmp -s "$medir"/autogen.sh
"$GNULIB_SRCDIR/top/autogen.sh"; \
607 cmp -s "$medir"/bootstrap
"$GNULIB_SRCDIR/build-aux/bootstrap"
610 echo "$0: updating bootstrap & companions and restarting..."
612 echo "$0: updating bootstrap and restarting..."
614 case $
(sh
-c 'echo "$1"' -- a
) in
620 '{ if '$u' && test -f "$1"; then cp "$1" "$3"; else cp "$2" "$3"; fi; } &&
621 { if '$u' && test -f "$4"; then cp "$4" "$5"; else rm -f "$5"; fi; } &&
622 { if '$u' && test -f "$6"; then cp "$6" "$7"; else rm -f "$7"; fi; } &&
623 { if '$u' && test -f "$8"; then cp "$8" "$9"; else rm -f "$9"; fi; } &&
624 shift && shift && shift && shift && shift &&
625 shift && shift && shift && shift &&
626 exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
628 "$GNULIB_SRCDIR/top/bootstrap" "$GNULIB_SRCDIR/build-aux/bootstrap" \
630 "$GNULIB_SRCDIR/top/bootstrap-funclib.sh" "$medir/bootstrap-funclib.sh" \
631 "$GNULIB_SRCDIR/top/autopull.sh" "$medir/autopull.sh" \
632 "$GNULIB_SRCDIR/top/autogen.sh" "$medir/autogen.sh" \
633 "$0" "$@" --no-bootstrap-sync
637 # ----------------------------------------------------------------------------
639 if test x
"$gnulib_modules$gnulib_files$gnulib_extra_files" = x
; then
645 # -------- Fetch auxiliary files from the network. --------------------------
649 Usage: $me [OPTION]...
650 Bootstrap this package from the checked-out sources.
652 Optional environment variables:
653 GNULIB_SRCDIR Specifies the local directory where gnulib
654 sources reside. Use this if you already
655 have gnulib sources on your machine, and
656 you want to use these sources.
657 GNULIB_REFDIR Specifies the local directory where a gnulib
658 repository (with a .git subdirectory) resides.
659 Use this if you already have gnulib sources
660 and history on your machine, and do not want
661 to waste your bandwidth downloading them again.
662 GNULIB_URL Cloneable URL of the gnulib repository.
665 --bootstrap-sync if this bootstrap script is not identical to
666 the version in the local gnulib sources,
667 update this script, and then restart it with
668 /bin/sh or the shell \$CONFIG_SHELL
669 --no-bootstrap-sync do not check whether bootstrap is out of sync
670 --force attempt to bootstrap even if the sources seem
671 not to have been checked out
672 --no-git do not use git to update gnulib. Requires that
673 \$GNULIB_SRCDIR or the --gnulib-srcdir option
674 points to a gnulib repository with the correct
676 --skip-po do not download po files
678 bootstrap_print_option_usage_hook
680 If the file bootstrap.conf exists in the same directory as this script, its
681 contents are read as shell variables to configure the bootstrap.
683 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
686 Gnulib sources can be fetched in various ways:
688 * If the environment variable GNULIB_SRCDIR is set (either as an
689 environment variable or via the --gnulib-srcdir option), then sources
690 are fetched from that local directory. If it is a git repository and
691 the configuration variable GNULIB_REVISION is set in bootstrap.conf,
692 then that revision is checked out.
694 * Otherwise, if this package is in a git repository with a 'gnulib'
695 submodule configured, then that submodule is initialized and updated
696 and sources are fetched from there. If GNULIB_REFDIR is set (either
697 as an environment variable or via the --gnulib-refdir option) and is
698 a git repository, then it is used as a reference.
700 * Otherwise, if the 'gnulib' directory does not exist, Gnulib sources
701 are cloned into that directory using git from \$GNULIB_URL, defaulting
702 to $default_gnulib_url.
703 If the configuration variable GNULIB_REVISION is set in bootstrap.conf,
704 then that revision is checked out.
706 * Otherwise, the existing Gnulib sources in the 'gnulib' directory are
707 used. If it is a git repository and the configuration variable
708 GNULIB_REVISION is set in bootstrap.conf, then that revision is
711 If you maintain a package and want to pin a particular revision of the
712 Gnulib sources that has been tested with your package, then there are
713 two possible approaches: either configure a 'gnulib' submodule with the
714 appropriate revision, or set GNULIB_REVISION (and if necessary
715 GNULIB_URL) in bootstrap.conf.
717 Running without arguments will suffice in most cases.
721 # Fetch auxiliary files that are omitted from the version control
722 # repository of this package.
725 # Ensure that CDPATH is not set. Otherwise, the output from cd
726 # would cause trouble in at least one use below.
727 (unset CDPATH
) >/dev
/null
2>&1 && unset CDPATH
731 # Use git to update gnulib sources
742 echo "autopull.sh $scriptlibversion"
749 checkout_only_file
=;;
751 bootstrap_sync
=true
;;
753 bootstrap_sync
=false
;;
757 bootstrap_option_hook
$option || die
"$option: unknown option";;
761 $use_git ||
test -n "$GNULIB_SRCDIR" \
762 || die
"Error: --no-git requires \$GNULIB_SRCDIR environment variable" \
763 "or --gnulib-srcdir option"
764 test -z "$GNULIB_SRCDIR" ||
test -d "$GNULIB_SRCDIR" \
765 || die
"Error: \$GNULIB_SRCDIR environment variable" \
766 "or --gnulib-srcdir option is specified," \
767 "but does not denote a directory"
769 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
770 die
"Running this script from a non-checked-out distribution is risky."
773 check_build_prerequisites
$use_git
775 if $use_gnulib ||
$bootstrap_sync; then
776 prepare_GNULIB_SRCDIR
777 if $bootstrap_sync; then
782 # Find sha1sum, named gsha1sum on MacPorts, shasum on Mac OS X 10.6.
783 # Also find the compatible sha1 utility on the BSDs
784 if test x
"$SKIP_PO" = x
; then
785 find_tool SHA1SUM
sha1sum gsha1sum shasum sha1
788 # See if we can use gnulib's git-merge-changelog merge driver.
789 if $use_git && test -d .git
&& check_exists git
; then
790 if git config merge.merge-changelog.driver
>/dev
/null
; then
792 elif check_exists git-merge-changelog
; then
793 echo "$0: initializing git-merge-changelog driver"
794 git config merge.merge-changelog.name
'GNU-style ChangeLog merge driver'
795 git config merge.merge-changelog.driver
'git-merge-changelog %O %A %B'
797 echo "$0: consider installing git-merge-changelog from gnulib"
804 update_po_files po
$package ||
return
807 if test -d runtime-po
; then
808 update_po_files runtime-po
$package-runtime ||
return
812 # ---------------------------------------------------------------------------
814 bootstrap_post_pull_hook \
815 || die
"bootstrap_post_pull_hook failed"
817 # Don't proceed if there are uninitialized submodules. In particular,
818 # autogen.sh will remove dangling links, which might be links into
819 # uninitialized submodules.
820 # But it's OK if the 'gnulib' submodule is uninitialized, as long as
821 # GNULIB_SRCDIR is set.
823 # Uninitialized submodules are listed with an initial dash.
824 uninitialized
=`git submodule | grep '^-' | awk '{ print $2 }'`
825 if test -n "$GNULIB_SRCDIR"; then
826 uninitialized
=`echo "$uninitialized" | grep -v '^gnulib$'`
828 if test -n "$uninitialized"; then
829 uninit_comma
=`echo "$uninitialized" | tr '\n' ',' | sed -e 's|,$|.|'`
830 die
"Some git submodules are not initialized: "$uninit_comma \
831 "Either use option '--no-git'," \
832 "or run 'git submodule update --init' and bootstrap again."
836 if test -f "$medir"/autogen.sh
; then
837 echo "$0: done. Now you can run '$medir/autogen.sh'."
841 # ----------------------------- Get translations. -----------------------------
843 download_po_files
() {
846 echo "$me: getting translations into $subdir for $domain..."
847 cmd
=$
(printf "$po_download_command_format" "$subdir" "$domain")
851 # Mirror .po files to $po_dir/.reference and copy only the new
852 # or modified ones into $po_dir. Also update $po_dir/LINGUAS.
853 # Note po files that exist locally only are left in $po_dir but will
854 # not be included in LINGUAS and hence will not be distributed.
856 # Directory containing primary .po files.
857 # Overwrite them only when we're sure a .po file is new.
861 # Mirror *.po files into this dir.
862 # Usually contains *.s1 checksum files.
863 ref_po_dir
="$po_dir/.reference"
865 test -d $ref_po_dir || mkdir
$ref_po_dir ||
return
866 download_po_files
$ref_po_dir $domain \
867 && ls "$ref_po_dir"/*.po
2>/dev
/null |
868 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" ||
return
870 langs
=$
(cd $ref_po_dir && echo *.po |
sed 's/\.po//g')
871 test "$langs" = '*' && langs
=x
873 case $po in x
) continue;; esac
874 new_po
="$ref_po_dir/$po.po"
875 cksum_file
="$ref_po_dir/$po.s1"
876 if ! test -f "$cksum_file" ||
877 ! test -f "$po_dir/$po.po" ||
878 ! $SHA1SUM -c "$cksum_file" < "$new_po" > /dev
/null
2>&1; then
879 echo "$me: updated $po_dir/$po.po..."
880 cp "$new_po" "$po_dir/$po.po" \
881 && $SHA1SUM < "$new_po" > "$cksum_file" ||
return
886 # -------- Generate files automatically from existing sources. --------------
890 Usage: $me [OPTION]...
891 Bootstrap this package from the checked-out sources.
893 Optional environment variables:
894 GNULIB_SRCDIR Specifies the local directory where gnulib
895 sources reside. Use this if you already
896 have gnulib sources on your machine, and
897 you want to use these sources.
900 --copy copy files instead of creating symbolic links
901 --force attempt to bootstrap even if the sources seem
902 not to have been checked out
904 bootstrap_print_option_usage_hook
906 If the file bootstrap.conf exists in the same directory as this script, its
907 contents are read as shell variables to configure the bootstrap.
909 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
912 Gnulib sources are assumed to be present:
913 * in \$GNULIB_SRCDIR, if that environment variable is set,
914 * otherwise, in the 'gnulib' submodule, if such a submodule is configured,
915 * otherwise, in the 'gnulib' subdirectory.
917 Running without arguments will suffice in most cases.
922 version_controlled_file
() {
925 if test -d .git
; then
926 git
rm -n "$file" > /dev
/null
2>&1
927 elif test -d .svn
; then
928 svn log
-r HEAD
"$file" > /dev
/null
2>&1
929 elif test -d CVS
; then
930 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev
/null |
931 grep '^/[^/]*/[0-9]' > /dev
/null
933 warn_
"no version control for $file?"
938 # Strip blank and comment lines to leave significant entries.
939 gitignore_entries
() {
940 sed '/^#/d; /^$/d' "$@"
943 # If $STR is not already on a line by itself in $FILE, insert it at the start.
944 # Entries are inserted at the start of the ignore list to ensure existing
945 # entries starting with ! are not overridden. Such entries support
946 # whitelisting exceptions after a more generic blacklist pattern.
950 test -f $file ||
touch $file
951 test -r $file || die
"Error: failed to read ignore file: $file"
952 duplicate_entries
=$
(gitignore_entries
$file |
sort |
uniq -d)
953 if [ "$duplicate_entries" ] ; then
954 die
"Error: Duplicate entries in $file: " $duplicate_entries
956 linesold
=$
(gitignore_entries
$file |
wc -l)
957 linesnew
=$
( { echo "$str"; cat $file; } | gitignore_entries |
sort -u |
wc -l)
958 if [ $linesold != $linesnew ] ; then
959 { echo "$str" |
cat - $file > $file.bak
&& mv $file.bak
$file; } \
960 || die
"insert_if_absent $file $str: failed"
964 # Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
969 case $vc_ignore_file in
971 # A .gitignore entry that does not start with '/' applies
972 # recursively to subdirectories, so prepend '/' to every
974 pattern
=$
(echo "$pattern" |
sed s
,^
,/,);;
976 insert_if_absent
"$vc_ignore_file" "$pattern"
986 # If the destination directory doesn't exist, create it.
987 # This is required at least for "lib/uniwidth/cjk.h".
988 dst_dir
=$
(dirname "$dst")
989 if ! test -d "$dst_dir"; then
992 # If we've just created a directory like lib/uniwidth,
993 # tell version control system(s) it's ignorable.
994 # FIXME: for now, this does only one level
995 parent
=$
(dirname "$dst_dir")
996 for dot_ig
in x
$vc_ignore; do
997 test $dot_ig = x
&& continue
999 insert_vc_ignore
$ig "${dst_dir##*/}/"
1005 test ! -h "$dst" ||
{
1006 echo "$me: rm -f $dst" &&
1011 cmp -s "$src" "$dst" ||
{
1012 echo "$me: cp -fp $src $dst" &&
1013 cp -fp "$src" "$dst"
1016 # Leave any existing symlink alone, if it already points to the source,
1017 # so that broken build tools that care about symlink times
1018 # aren't confused into doing unnecessary builds. Conversely, if the
1019 # existing symlink's timestamp is older than the source, make it afresh,
1020 # so that broken tools aren't confused into skipping needed builds. See
1021 # <https://lists.gnu.org/r/bug-gnulib/2011-05/msg00326.html>.
1023 src_ls
=$
(ls -diL "$src" 2>/dev
/null
) && set $src_ls && src_i
=$1 &&
1024 dst_ls
=$
(ls -diL "$dst" 2>/dev
/null
) && set $dst_ls && dst_i
=$1 &&
1025 test "$src_i" = "$dst_i" &&
1026 both_ls
=$
(ls -dt "$src" "$dst") &&
1027 test "X$both_ls" = "X$dst$nl$src" ||
{
1033 *//* |
*/..
/* |
*/.
/* |
/*/*/*/*/*/)
1034 die
"invalid symlink calculation: $src -> $dst";;
1035 /*/*/*/*/) dot_dots
=..
/..
/..
/;;
1036 /*/*/*/) dot_dots
=..
/..
/;;
1037 /*/*/) dot_dots
=..
/;;
1041 echo "$me: ln -fs $dot_dots$src $dst" &&
1042 ln -fs "$dot_dots$src" "$dst"
1048 # Regenerate all autogeneratable files that are omitted from the
1049 # version control repository. In particular, regenerate all
1050 # aclocal.m4, config.h.in, Makefile.in, configure files with new
1051 # versions of autoconf or automake.
1054 # Ensure that CDPATH is not set. Otherwise, the output from cd
1055 # would cause trouble in at least one use below.
1056 (unset CDPATH
) >/dev
/null
2>&1 && unset CDPATH
1058 # Environment variables that may be set by the user.
1059 : "${AUTOPOINT=autopoint}"
1060 : "${AUTORECONF=autoreconf}"
1062 if test "$vc_ignore" = auto
; then
1064 test -d .git
&& vc_ignore
=.gitignore
1065 test -d CVS
&& vc_ignore
="$vc_ignore .cvsignore"
1071 # Whether to use copies instead of symlinks.
1082 echo "autogen.sh $scriptlibversion"
1087 checkout_only_file
=;;
1091 bootstrap_option_hook
$option || die
"$option: unknown option";;
1095 test -z "$GNULIB_SRCDIR" ||
test -d "$GNULIB_SRCDIR" \
1096 || die
"Error: \$GNULIB_SRCDIR environment variable or --gnulib-srcdir" \
1097 "option is specified, but does not denote a directory"
1099 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
1100 die
"Running this script from a non-checked-out distribution is risky."
1103 if $use_gnulib; then
1104 if test -z "$GNULIB_SRCDIR"; then
1105 gnulib_path
=$
(test -f .gitmodules
&&
1106 git config
--file .gitmodules submodule.gnulib.path
)
1107 test -z "$gnulib_path" && gnulib_path
=gnulib
1108 GNULIB_SRCDIR
=$gnulib_path
1112 # Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
1114 grep '^[ ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'])' configure.ac \
1115 >/dev
/null
&& found_aux_dir
=yes
1116 grep '^[ ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
1117 >/dev
/null
&& found_aux_dir
=yes
1118 test $found_aux_dir = yes \
1119 || die
"configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
1121 # If $build_aux doesn't exist, create it now, otherwise some bits
1122 # below will malfunction. If creating it, also mark it as ignored.
1123 if test ! -d $build_aux; then
1125 for dot_ig
in x
$vc_ignore; do
1126 test $dot_ig = x
&& continue
1127 insert_vc_ignore
$dot_ig $build_aux/
1131 check_build_prerequisites false
1134 # We'd like to use grep -E, to see if any of LT_INIT,
1135 # AC_PROG_LIBTOOL, AM_PROG_LIBTOOL is used in configure.ac,
1136 # but that's not portable enough (e.g., for Solaris).
1137 grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac
>/dev
/null \
1139 grep '^[ ]*LT_INIT' configure.ac
>/dev
/null \
1141 if test $use_libtool = 1; then
1142 find_tool LIBTOOLIZE glibtoolize libtoolize
1145 if $use_gnulib; then
1146 gnulib_tool
=$GNULIB_SRCDIR/gnulib-tool
1147 <$gnulib_tool ||
return
1150 # NOTE: we have to be careful to run both autopoint and libtoolize
1151 # before gnulib-tool, since gnulib-tool is likely to provide newer
1152 # versions of files "installed" by these two programs.
1153 # Then, *after* gnulib-tool (see below), we have to be careful to
1154 # run autoreconf in such a way that it does not run either of these
1155 # two just-pre-run programs.
1157 # Import from gettext.
1159 grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac
>/dev
/null || \
1162 if test $with_gettext = yes ||
test $use_libtool = 1; then
1164 tempbase
=.bootstrap$$
1165 trap "rm -f $tempbase.0 $tempbase.1" HUP INT PIPE TERM
1167 > $tempbase.0 > $tempbase.1 &&
1168 find .
! -type d
-print |
sort > $tempbase.0 ||
return
1170 if test $with_gettext = yes; then
1171 # Released autopoint has the tendency to install macros that have been
1172 # obsoleted in current gnulib, so run this before gnulib-tool.
1173 echo "$0: $AUTOPOINT --force"
1174 $AUTOPOINT --force ||
return
1177 # Autoreconf runs aclocal before libtoolize, which causes spurious
1178 # warnings if the initial aclocal is confused by the libtoolized
1179 # (or worse out-of-date) macro directory.
1180 # libtoolize 1.9b added the --install option; but we support back
1181 # to libtoolize 1.5.22, where the install action was default.
1182 if test $use_libtool = 1; then
1184 case $
($LIBTOOLIZE --help) in
1185 *--install*) install=--install ;;
1187 echo "running: $LIBTOOLIZE $install --copy"
1188 $LIBTOOLIZE $install --copy
1191 find .
! -type d
-print |
sort >$tempbase.1
1194 for file in $
(comm -13 $tempbase.0 $tempbase.1); do
1197 version_controlled_file
"$parent" "$file" ||
{
1198 for dot_ig
in x
$vc_ignore; do
1199 test $dot_ig = x
&& continue
1201 insert_vc_ignore
"$ig" "${file##*/}"
1207 rm -f $tempbase.0 $tempbase.1
1208 trap - HUP INT PIPE TERM
1211 # Import from gnulib.
1213 if $use_gnulib; then
1214 gnulib_tool_options
="\
1216 --aux-dir=$build_aux\
1217 --doc-base=$doc_base\
1219 --m4-base=$m4_base/\
1220 --source-base=$source_base/\
1221 --tests-base=$tests_base\
1222 --local-dir=$local_gl_dir\
1223 $gnulib_tool_option_extras\
1225 if test $use_libtool = 1; then
1226 case "$gnulib_tool_options " in
1228 *) gnulib_tool_options
="$gnulib_tool_options --libtool" ;;
1231 echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
1232 $gnulib_tool $gnulib_tool_options --import $gnulib_modules \
1233 || die
"gnulib-tool failed"
1235 for file in $gnulib_files; do
1236 symlink_to_dir
"$GNULIB_SRCDIR" $file \
1237 || die
"failed to symlink $file"
1241 bootstrap_post_import_hook \
1242 || die
"bootstrap_post_import_hook failed"
1244 # Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
1245 # gnulib-populated directories. Such .m4 files would cause aclocal to fail.
1246 # The following requires GNU find 4.2.3 or newer. Considering the usual
1247 # portability constraints of this script, that may seem a very demanding
1248 # requirement, but it should be ok. Ignore any failure, which is fine,
1249 # since this is only a convenience to help developers avoid the relatively
1250 # unusual case in which a symlinked-to .m4 file is git-removed from gnulib
1251 # between successive runs of this script.
1252 find "$m4_base" "$source_base" \
1253 -depth \
( -name '*.m4' -o -name '*.[ch]' \
) \
1254 -type l
-xtype l
-delete > /dev
/null
2>&1
1256 # Invoke autoreconf with --force --install to ensure upgrades of tools
1258 AUTORECONFFLAGS
="--verbose --install --force -I $m4_base $ACLOCAL_FLAGS"
1259 AUTORECONFFLAGS
="$AUTORECONFFLAGS --no-recursive"
1261 # Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
1262 echo "running: AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS"
1263 AUTOPOINT
=true LIBTOOLIZE
=true
$AUTORECONF $AUTORECONFFLAGS \
1264 || die
"autoreconf failed"
1266 # Get some extra files from gnulib, overriding existing files.
1267 for file in $gnulib_extra_files; do
1269 */INSTALL
) dst
=INSTALL
;;
1270 build-aux
/*) dst
=$build_aux/${file#build-aux/};;
1273 symlink_to_dir
"$GNULIB_SRCDIR" $file $dst \
1274 || die
"failed to symlink $file"
1277 if test $with_gettext = yes; then
1278 # Create gettext configuration.
1279 echo "$0: Creating po/Makevars from po/Makevars.template ..."
1282 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
1283 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
1284 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
1285 /^XGETTEXT_OPTIONS *=/{
1288 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
1290 ' po
/Makevars.template
>po
/Makevars \
1291 || die
'cannot generate po/Makevars'
1293 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
1294 # If only the 'gettext-h' module is in use, assume autopoint already
1295 # put the correct version of this file into place.
1296 case $gnulib_modules in
1299 cp $GNULIB_SRCDIR/build-aux
/po
/Makefile.
in.
in po
/Makefile.
in.
in \
1300 || die
"cannot create po/Makefile.in.in"
1304 if test -d runtime-po
; then
1305 # Similarly for runtime-po/Makevars, but not quite the same.
1306 rm -f runtime-po
/Makevars
1308 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
1309 /^subdir *=.*/s/=.*/= runtime-po/
1310 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
1311 /^XGETTEXT_OPTIONS *=/{
1314 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
1316 ' po
/Makevars.template
>runtime-po
/Makevars \
1317 || die
'cannot generate runtime-po/Makevars'
1319 # Copy identical files from po to runtime-po.
1320 (cd po
&& cp -p Makefile.
in.
in *-quot *.header
*.
sed *.sin ..
/runtime-po
)
1326 echo "$0: done. Now you can run './configure'."
1329 # ----------------------------------------------------------------------------
1332 # eval: (add-hook 'before-save-hook 'time-stamp)
1333 # time-stamp-start: "scriptlibversion="
1334 # time-stamp-format: "%:y-%02m-%02d.%02H"
1335 # time-stamp-time-zone: "UTC0"
1336 # time-stamp-end: "; # UTC"
1341 Usage: $me [OPTION]...
1342 Bootstrap this package from the checked-out sources.
1344 Optional environment variables:
1345 GNULIB_SRCDIR Specifies the local directory where gnulib
1346 sources reside. Use this if you already
1347 have gnulib sources on your machine, and
1348 do not want to waste your bandwidth downloading
1350 GNULIB_URL Cloneable URL of the gnulib repository.
1354 --pull Do phase 1: pull files from network
1355 --gen Do phase 2: generate from local files.
1356 (The default is to do both phases.)
1358 --gnulib-srcdir=DIRNAME specify the local directory where gnulib
1359 sources reside. Use this if you already
1360 have gnulib sources on your machine, and
1361 you want to use these sources. Defaults
1363 --gnulib-refdir=DIRNAME specify the local directory where a gnulib
1364 repository (with a .git subdirectory) resides.
1365 Use this if you already have gnulib sources
1366 and history on your machine, and do not want
1367 to waste your bandwidth downloading them again.
1368 Defaults to \$GNULIB_REFDIR
1370 --bootstrap-sync if this bootstrap script is not identical to
1371 the version in the local gnulib sources,
1372 update this script, and then restart it with
1373 /bin/sh or the shell \$CONFIG_SHELL
1374 --no-bootstrap-sync do not check whether bootstrap is out of sync
1376 --copy copy files instead of creating symbolic links
1377 --force attempt to bootstrap even if the sources seem
1378 not to have been checked out
1379 --no-git do not use git to update gnulib. Requires that
1380 \$GNULIB_SRCDIR or the --gnulib-srcdir option
1381 points to a gnulib repository with the correct
1383 --skip-po do not download po files
1385 bootstrap_print_option_usage_hook
1387 If the file bootstrap.conf exists in the same directory as this script, its
1388 contents are read as shell variables to configure the bootstrap.
1390 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
1393 Gnulib sources can be fetched in various ways:
1395 * If the environment variable GNULIB_SRCDIR is set (either as an
1396 environment variable or via the --gnulib-srcdir option), then sources
1397 are fetched from that local directory. If it is a git repository and
1398 the configuration variable GNULIB_REVISION is set in bootstrap.conf,
1399 then that revision is checked out.
1401 * Otherwise, if this package is in a git repository with a 'gnulib'
1402 submodule configured, then that submodule is initialized and updated
1403 and sources are fetched from there. If GNULIB_REFDIR is set (either
1404 as an environment variable or via the --gnulib-refdir option) and is
1405 a git repository, then it is used as a reference.
1407 * Otherwise, if the 'gnulib' directory does not exist, Gnulib sources
1408 are cloned into that directory using git from \$GNULIB_URL, defaulting
1409 to $default_gnulib_url.
1410 If the configuration variable GNULIB_REVISION is set in bootstrap.conf,
1411 then that revision is checked out.
1413 * Otherwise, the existing Gnulib sources in the 'gnulib' directory are
1414 used. If it is a git repository and the configuration variable
1415 GNULIB_REVISION is set in bootstrap.conf, then that revision is
1418 If you maintain a package and want to pin a particular revision of the
1419 Gnulib sources that has been tested with your package, then there are
1420 two possible approaches: either configure a 'gnulib' submodule with the
1421 appropriate revision, or set GNULIB_REVISION (and if necessary
1422 GNULIB_URL) in bootstrap.conf.
1424 Running without arguments will suffice in most cases.
1430 # Whether to pull and generate.
1434 # Whether to use copies instead of symlinks.
1437 # Use git to update gnulib sources
1448 echo "bootstrap $scriptversion lib $scriptlibversion"
1457 GNULIB_SRCDIR
=${option#--gnulib-srcdir=};;
1459 GNULIB_REFDIR
=${option#--gnulib-refdir=};;
1463 checkout_only_file
=;;
1467 bootstrap_sync
=true
;;
1468 --no-bootstrap-sync)
1469 bootstrap_sync
=false
;;
1473 bootstrap_option_hook
$option || die
"$option: unknown option";;
1477 # Default is to do both.
1478 $pull ||
$gen || pull
=true gen
=true
1480 $use_git ||
test -n "$GNULIB_SRCDIR" \
1481 || die
"Error: --no-git requires \$GNULIB_SRCDIR environment variable" \
1482 "or --gnulib-srcdir option"
1483 test -z "$GNULIB_SRCDIR" ||
test -d "$GNULIB_SRCDIR" \
1484 || die
"Error: \$GNULIB_SRCDIR environment variable or --gnulib-srcdir" \
1485 "option is specified, but does not denote a directory"
1487 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
1488 die
"Bootstrapping from a non-checked-out distribution is risky."
1491 check_build_prerequisites
$use_git
1493 if $bootstrap_sync; then
1494 prepare_GNULIB_SRCDIR
1496 # Since we have now upgraded if needed, no need to try it a second time below.
1497 bootstrap_sync
=false
1500 echo "$0: Bootstrapping from checked-out $package sources..."
1502 # Pass GNULIB_SRCDIR and GNULIB_REFDIR to any subsidiary commands that care.
1503 export GNULIB_SRCDIR
1504 export GNULIB_REFDIR
1506 if $pull && { $use_git ||
test -z "$SKIP_PO"; }; then
1508 `if $bootstrap_sync; then
1509 echo ' --bootstrap-sync'
1511 echo ' --no-bootstrap-sync'
1513 `if test -z "$checkout_only_file"; then echo ' --force'; fi` \
1514 `if ! $use_git; then echo ' --no-git'; fi` \
1515 `if test -n "$SKIP_PO"; then echo ' --skip-po'; fi` \
1516 || die
"could not fetch auxiliary files"
1521 `if $copy; then echo ' --copy'; fi` \
1522 `if test -z "$checkout_only_file"; then echo ' --force'; fi` \
1523 || die
"could not generate auxiliary files"
1526 # ----------------------------------------------------------------------------
1529 # eval: (add-hook 'before-save-hook 'time-stamp)
1530 # time-stamp-start: "scriptversion="
1531 # time-stamp-format: "%:y-%02m-%02d.%02H"
1532 # time-stamp-time-zone: "UTC0"
1533 # time-stamp-end: "; # UTC"