2 # Print a version string.
3 scriptversion
=2012-12-28.10
; # UTC
5 # Bootstrap this package from checked-out sources.
7 # Copyright (C) 2003-2012 Free Software Foundation, Inc.
9 # This program is free software: you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation, either version 3 of the License, or
12 # (at your option) any later version.
14 # This program is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
19 # You should have received a copy of the GNU General Public License
20 # along with this program. If not, see <http://www.gnu.org/licenses/>.
22 # Originally written by Paul Eggert. The canonical version of this
23 # script is maintained as build-aux/bootstrap in gnulib, however, to
24 # be useful to your project, you should place a copy of it under
25 # version control in the top-level directory of your project. The
26 # intent is that all customization can be done with a bootstrap.conf
27 # file also maintained in your version control; gnulib comes with a
28 # template build-aux/bootstrap.conf to get you started.
30 # Please report bugs or propose patches to bug-gnulib@gnu.org.
35 # Ensure file names are sorted consistently across platforms.
39 # Ensure that CDPATH is not set. Otherwise, the output from cd
40 # would cause trouble in at least one use below.
41 (unset CDPATH
) >/dev
/null
2>&1 && unset CDPATH
49 Usage: $me [OPTION]...
50 Bootstrap this package from the checked-out sources.
53 --gnulib-srcdir=DIRNAME specify the local directory where gnulib
54 sources reside. Use this if you already
55 have gnulib sources on your machine, and
56 do not want to waste your bandwidth downloading
57 them again. Defaults to \$GNULIB_SRCDIR
58 --bootstrap-sync if this bootstrap script is not identical to
59 the version in the local gnulib sources,
60 update this script, and then restart it with
61 /bin/sh or the shell \$CONFIG_SHELL
62 --no-bootstrap-sync do not check whether bootstrap is out of sync
63 --copy copy files instead of creating symbolic links
64 --force attempt to bootstrap even if the sources seem
65 not to have been checked out
66 --no-git do not use git to update gnulib. Requires that
67 --gnulib-srcdir point to a correct gnulib snapshot
68 --skip-po do not download po files
70 If the file $me.conf exists in the same directory as this script, its
71 contents are read as shell variables to configure the bootstrap.
73 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
76 Running without arguments will suffice in most cases.
80 # warnf_ FORMAT-STRING ARG1...
88 *$nl*) me_
=$(printf "$me"|tr "$nl|" '??')
89 printf "$warnf_format_" "$@" | sed "s|^|$me_: |" ;;
90 *) printf "$me: $warnf_format_" "$@" ;;
97 # If IFS does not start with ' ', set it and emit the warning in a subshell.
99 ' '*) warnf_
'%s\n' "$*";;
100 *) (IFS
=' '; warn_
"$@");;
105 die
() { warn_
"$@"; exit 1; }
109 # Name of the Makefile.am
112 # List of gnulib modules needed.
115 # Any gnulib files needed that are not in modules.
118 : ${AUTOPOINT=autopoint}
119 : ${AUTORECONF=autoreconf}
121 # A function to be called right after gnulib-tool is run.
122 # Override it via your own definition in bootstrap.conf.
123 bootstrap_post_import_hook
() { :; }
125 # A function to be called after everything else in this script.
126 # Override it via your own definition in bootstrap.conf.
127 bootstrap_epilogue
() { :; }
129 # The command to download all .po files for a specified domain into
130 # a specified directory. Fill in the first %s is the domain name, and
131 # the second with the destination directory. Use rsync's -L and -r
132 # options because the latest/%s directory and the .po files within are
134 po_download_command_format
=\
135 "rsync --delete --exclude '*.s1' -Lrtvz \
136 'translationproject.org::tp/latest/%s/' '%s'"
138 # Fallback for downloading .po files (if rsync fails).
139 po_download_command_format2
=\
140 "wget --mirror -nd -q -np -A.po -P '%s' \
141 http://translationproject.org/latest/%s/"
143 extract_package_name
='
155 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
160 package
=$(sed -n "$extract_package_name" configure.ac) \
161 || die
'cannot find package name in configure.ac'
162 gnulib_name
=lib
$package
169 gnulib_extra_files
=''
171 # Additional gnulib-tool options to use. Use "\newline" to break lines.
172 gnulib_tool_option_extras
=
174 # Other locale categories that need message catalogs.
175 EXTRA_LOCALE_CATEGORIES
=
177 # Additional xgettext options to use. Use "\\\newline" to break lines.
178 XGETTEXT_OPTIONS
='\\\
179 --flag=_:1:pass-c-format\\\
180 --flag=N_:1:pass-c-format\\\
181 --flag=error:3:c-format --flag=error_at_line:5:c-format\\\
184 # Package bug report address and copyright holder for gettext files
185 COPYRIGHT_HOLDER
='Free Software Foundation, Inc.'
186 MSGID_BUGS_ADDRESS
=bug
-$package@gnu.org
188 # Files we don't want to import.
191 # File that should exist in the top directory of a checked out hierarchy,
192 # but not in a distribution tarball.
193 checkout_only_file
=README
-hacking
195 # Whether to use copies instead of symlinks.
198 # Set this to '.cvsignore .gitignore' in bootstrap.conf if you want
199 # those files to be generated in directories like lib/, m4/, and po/.
200 # Or set it to 'auto' to make this script select which to use based
201 # on which version control system (if any) is used in the source directory.
204 # Set this to true in bootstrap.conf to enable --bootstrap-sync by
208 # Use git to update gnulib sources
211 # find_tool ENVVAR NAMES...
212 # -------------------------
213 # Search for a required program. Use the value of ENVVAR, if set,
214 # otherwise find the first of the NAMES that can be run (i.e.,
215 # supports --version). If found, set ENVVAR to the program name,
218 # FIXME: code duplication, see also gnu-web-doc-update.
224 eval "find_tool_res=\$$find_tool_envvar"
225 if test x
"$find_tool_res" = x
; then
228 if ($i --version </dev
/null
) >/dev
/null
2>&1; then
234 find_tool_error_prefix
="\$$find_tool_envvar: "
236 test x
"$find_tool_res" != x \
237 || die
"one of these is required: $find_tool_names"
238 ($find_tool_res --version </dev
/null
) >/dev
/null
2>&1 \
239 || die
"${find_tool_error_prefix}cannot run $find_tool_res --version"
240 eval "$find_tool_envvar=\$find_tool_res"
241 eval "export $find_tool_envvar"
244 # Find sha1sum, named gsha1sum on MacPorts, and shasum on Mac OS X 10.6.
245 find_tool SHA1SUM
sha1sum gsha1sum shasum
247 # Override the default configuration, if necessary.
248 # Make sure that bootstrap.conf is sourced from the current directory
249 # if we were invoked as "sh bootstrap".
251 */*) test -r "$0.conf" && .
"$0.conf" ;;
252 *) test -r "$0.conf" && . .
/"$0.conf" ;;
255 # Extra files from gnulib, which override files from other sources.
256 test -z "${gnulib_extra_files}" && \
258 $build_aux/install-sh
260 $build_aux/texinfo.tex
262 $build_aux/config.guess
263 $build_aux/config.sub
267 if test "$vc_ignore" = auto
; then
269 test -d .git
&& vc_ignore
=.gitignore
270 test -d CVS
&& vc_ignore
="$vc_ignore .cvsignore"
273 # Translate configuration into internal form.
284 GNULIB_SRCDIR
=${option#--gnulib-srcdir=};;
288 checkout_only_file
=;;
292 bootstrap_sync
=true
;;
294 bootstrap_sync
=false
;;
298 die
"$option: unknown option";;
302 $use_git || test -d "$GNULIB_SRCDIR" \
303 || die
"Error: --no-git requires --gnulib-srcdir"
305 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
306 die
"Bootstrapping from a non-checked-out distribution is risky."
309 # Ensure that lines starting with ! sort last, per gitignore conventions
310 # for whitelisting exceptions after a more generic blacklist pattern.
312 sort -u "$@" | sed '/^!/ {
323 # If $STR is not already on a line by itself in $FILE, insert it,
324 # sorting the new contents of the file and replacing $FILE with the result.
325 insert_sorted_if_absent
() {
328 test -f $file || touch $file
329 echo "$str" | sort_patterns
- $file | cmp -s - $file > /dev
/null \
330 || { echo "$str" | sort_patterns
- $file > $file.bak \
331 && mv $file.bak
$file; } \
332 || die
"insert_sorted_if_absent $file $str: failed"
335 # Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
336 # insert_sorted_if_absent.
340 case $vc_ignore_file in
342 # A .gitignore entry that does not start with '/' applies
343 # recursively to subdirectories, so prepend '/' to every
345 pattern
=$(echo "$pattern" | sed s,^,/,);;
347 insert_sorted_if_absent
"$vc_ignore_file" "$pattern"
350 # Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
352 grep '^[ ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'\])' configure.ac \
353 >/dev
/null
&& found_aux_dir
=yes
354 grep '^[ ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
355 >/dev
/null
&& found_aux_dir
=yes
356 test $found_aux_dir = yes \
357 || die
"configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
359 # If $build_aux doesn't exist, create it now, otherwise some bits
360 # below will malfunction. If creating it, also mark it as ignored.
361 if test ! -d $build_aux; then
363 for dot_ig
in x
$vc_ignore; do
364 test $dot_ig = x
&& continue
365 insert_vc_ignore
$dot_ig $build_aux
369 # Note this deviates from the version comparison in automake
370 # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
371 # but this should suffice as we won't be specifying old
372 # version formats or redundant trailing .0 in bootstrap.conf.
373 # If we did want full compatibility then we should probably
374 # use m4_version_compare from autoconf.
375 sort_ver
() { # sort -V is not generally available
379 # split on '.' and compare each component
382 p1
=$(echo "$ver1" | cut -d. -f$i)
383 p2
=$(echo "$ver2" | cut -d. -f$i)
387 elif [ ! "$p2" ]; then
390 elif [ ! "$p1" = "$p2" ]; then
391 if [ "$p1" -gt "$p2" ] 2>/dev
/null
; then # numeric comparison
393 elif [ "$p2" -gt "$p1" ] 2>/dev
/null
; then # numeric comparison
395 else # numeric, then lexicographic comparison
396 lp=$(printf "$p1\n$p2\n" | LANG=C sort -n | tail -n1)
397 if [ "$lp" = "$p2" ]; then
412 $app --version >/dev
/null
2>&1 || return 1
414 $app --version 2>&1 |
415 sed -n '# Move version to start of line.
416 s/.*[v ]\([0-9]\)/\1/
418 # Skip lines that do not start with version.
421 # Remove characters after the version.
424 # The first component must be digits only.
425 s/^\([0-9]*\)[a-z-].*/\1/
427 #the following essentially does s/5.005/5.5/
428 s/\.0*\([1-9]\)/.\1/g
436 while read app req_ver
; do
437 # We only need libtoolize from the libtool package.
438 if test "$app" = libtool
; then
441 # Exempt git if --no-git is in effect.
442 if test "$app" = git
; then
445 # Honor $APP variables ($TAR, $AUTOCONF, etc.)
446 appvar
=$(echo $app | LC_ALL=C tr '[a-z]-' '[A-Z]_')
447 test "$appvar" = TAR
&& appvar
=AMTAR
449 GZIP
) ;; # Do not use $GZIP: it contains gzip options.
450 *) eval "app=\${$appvar-$app}" ;;
453 # Handle the still-experimental Automake-NG programs specially.
454 # They remain named as the mainstream Automake programs ("automake",
455 # and "aclocal") to avoid gratuitous incompatibilities with
456 # pre-existing usages (by, say, autoreconf, or custom autogen.sh
457 # scripts), but correctly identify themselves (as being part of
458 # "GNU automake-ng") when asked their version.
460 automake
-ng|aclocal
-ng)
462 ($app --version | grep '(GNU automake-ng)') >/dev
/null
2>&1 || {
463 warn_
"Error: '$app' not found or not from Automake-NG"
468 if [ "$req_ver" = "-" ]; then
469 # Merely require app to exist; not all prereq apps are well-behaved
470 # so we have to rely on $? rather than get_version.
471 $app --version >/dev
/null
2>&1
472 if [ 126 -le $?
]; then
473 warn_
"Error: '$app' not found"
477 # Require app to produce a new enough version string.
478 inst_ver
=$(get_version $app)
479 if [ ! "$inst_ver" ]; then
480 warn_
"Error: '$app' not found"
483 latest_ver
=$(sort_ver $req_ver $inst_ver | cut -d' ' -f2)
484 if [ ! "$latest_ver" = "$inst_ver" ]; then
486 "Error: '$app' version == $inst_ver is too old" \
487 " '$app' version >= $req_ver is required"
498 echo "Program Min_version"
499 echo "----------------------"
500 printf %s
"$buildreq"
501 echo "----------------------"
502 # can't depend on column -t
506 # We'd like to use grep -E, to see if any of LT_INIT,
507 # AC_PROG_LIBTOOL, AM_PROG_LIBTOOL is used in configure.ac,
508 # but that's not portable enough (e.g., for Solaris).
509 grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac
>/dev
/null \
511 grep '^[ ]*LT_INIT' configure.ac
>/dev
/null \
513 if test $use_libtool = 1; then
514 find_tool LIBTOOLIZE glibtoolize libtoolize
517 # gnulib-tool requires at least automake and autoconf.
518 # If either is not listed, add it (with minimum version) as a prerequisite.
521 *) buildreq
="automake 1.9
526 *) buildreq
="autoconf 2.59
530 # When we can deduce that gnulib-tool will require patch,
531 # and when patch is not already listed as a prerequisite, add it, too.
532 if test -d "$local_gl_dir" \
533 && ! find "$local_gl_dir" -name '*.diff' -exec false
{} +; then
541 if ! printf "$buildreq" | check_versions
; then
543 if test -f README
-prereq; then
544 die
"See README-prereq for how to get the prerequisite programs"
546 die
"Please install the prerequisite programs"
550 echo "$0: Bootstrapping from checked-out $package sources..."
552 # See if we can use gnulib's git-merge-changelog merge driver.
553 if test -d .git
&& (git
--version) >/dev
/null
2>/dev
/null
; then
554 if git config merge.merge
-changelog.driver
>/dev
/null
; then
556 elif (git
-merge-changelog --version) >/dev
/null
2>/dev
/null
; then
557 echo "$0: initializing git-merge-changelog driver"
558 git config merge.merge
-changelog.name
'GNU-style ChangeLog merge driver'
559 git config merge.merge
-changelog.driver
'git-merge-changelog %O %A %B'
561 echo "$0: consider installing git-merge-changelog from gnulib"
568 rm -fr "$gnulib_path"
572 git_modules_config
() {
573 test -f .gitmodules
&& git config
--file .gitmodules
"$@"
576 gnulib_path
=$(git_modules_config submodule.gnulib.path)
577 test -z "$gnulib_path" && gnulib_path
=gnulib
581 case ${GNULIB_SRCDIR--} in
583 if git_modules_config submodule.gnulib.url
>/dev
/null
; then
584 echo "$0: getting gnulib files..."
585 git submodule init
|| exit $?
586 git submodule update
|| exit $?
588 elif [ ! -d "$gnulib_path" ]; then
589 echo "$0: getting gnulib files..."
591 trap cleanup_gnulib
1 2 13 15
594 git clone
-h 2>&1 | grep -- --depth > /dev
/null
&& shallow
='--depth 2'
595 git clone
$shallow git
://git.sv.gnu.org
/gnulib
"$gnulib_path" ||
600 GNULIB_SRCDIR
=$gnulib_path
603 # Use GNULIB_SRCDIR as a reference.
604 if test -d "$GNULIB_SRCDIR"/.git
&& \
605 git_modules_config submodule.gnulib.url
>/dev
/null
; then
606 echo "$0: getting gnulib files..."
607 if git submodule
-h|grep -- --reference > /dev
/null
; then
608 # Prefer the one-liner available in git 1.6.4 or newer.
609 git submodule update
--init --reference "$GNULIB_SRCDIR" \
610 "$gnulib_path" || exit $?
612 # This fallback allows at least git 1.5.5.
613 if test -f "$gnulib_path"/gnulib
-tool; then
614 # Since file already exists, assume submodule init already complete.
615 git submodule update
|| exit $?
617 # Older git can't clone into an empty directory.
618 rmdir "$gnulib_path" 2>/dev
/null
619 git clone
--reference "$GNULIB_SRCDIR" \
620 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
621 && git submodule init
&& git submodule update \
625 GNULIB_SRCDIR
=$gnulib_path
630 if $bootstrap_sync; then
631 cmp -s "$0" "$GNULIB_SRCDIR/build-aux/bootstrap" || {
632 echo "$0: updating bootstrap and restarting..."
634 'cp "$1" "$2" && shift && exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
635 -- "$GNULIB_SRCDIR/build-aux/bootstrap" \
636 "$0" "$@" --no-bootstrap-sync
640 gnulib_tool
=$GNULIB_SRCDIR/gnulib
-tool
641 <$gnulib_tool || exit $?
645 download_po_files
() {
648 echo "$me: getting translations into $subdir for $domain..."
649 cmd
=$(printf "$po_download_command_format" "$domain" "$subdir")
650 eval "$cmd" && return
652 cmd
=$(printf "$po_download_command_format2" "$subdir" "$domain")
656 # Mirror .po files to $po_dir/.reference and copy only the new
657 # or modified ones into $po_dir. Also update $po_dir/LINGUAS.
658 # Note po files that exist locally only are left in $po_dir but will
659 # not be included in LINGUAS and hence will not be distributed.
661 # Directory containing primary .po files.
662 # Overwrite them only when we're sure a .po file is new.
666 # Mirror *.po files into this dir.
667 # Usually contains *.s1 checksum files.
668 ref_po_dir
="$po_dir/.reference"
670 test -d $ref_po_dir || mkdir $ref_po_dir || return
671 download_po_files
$ref_po_dir $domain \
672 && ls "$ref_po_dir"/*.po
2>/dev
/null
|
673 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" || return
675 langs
=$(cd $ref_po_dir && echo *.po | sed 's/\.po//g')
676 test "$langs" = '*' && langs
=x
678 case $po in x
) continue;; esac
679 new_po
="$ref_po_dir/$po.po"
680 cksum_file
="$ref_po_dir/$po.s1"
681 if ! test -f "$cksum_file" ||
682 ! test -f "$po_dir/$po.po" ||
683 ! $SHA1SUM -c --status "$cksum_file" \
684 < "$new_po" > /dev
/null
; then
685 echo "$me: updated $po_dir/$po.po..."
686 cp "$new_po" "$po_dir/$po.po" \
687 && $SHA1SUM < "$new_po" > "$cksum_file"
695 update_po_files po
$package || exit
698 if test -d runtime
-po; then
699 update_po_files runtime
-po $package-runtime || exit
710 # If the destination directory doesn't exist, create it.
711 # This is required at least for "lib/uniwidth/cjk.h".
712 dst_dir
=$(dirname "$dst")
713 if ! test -d "$dst_dir"; then
716 # If we've just created a directory like lib/uniwidth,
717 # tell version control system(s) it's ignorable.
718 # FIXME: for now, this does only one level
719 parent
=$(dirname "$dst_dir")
720 for dot_ig
in x
$vc_ignore; do
721 test $dot_ig = x
&& continue
723 insert_vc_ignore
$ig "${dst_dir##*/}"
729 test ! -h "$dst" || {
730 echo "$me: rm -f $dst" &&
735 cmp -s "$src" "$dst" || {
736 echo "$me: cp -fp $src $dst" &&
740 # Leave any existing symlink alone, if it already points to the source,
741 # so that broken build tools that care about symlink times
742 # aren't confused into doing unnecessary builds. Conversely, if the
743 # existing symlink's time stamp is older than the source, make it afresh,
744 # so that broken tools aren't confused into skipping needed builds. See
745 # <http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00326.html>.
747 src_ls
=$(ls -diL "$src" 2>/dev/null) && set $src_ls && src_i
=$1 &&
748 dst_ls
=$(ls -diL "$dst" 2>/dev/null) && set $dst_ls && dst_i
=$1 &&
749 test "$src_i" = "$dst_i" &&
750 both_ls
=$(ls -dt "$src" "$dst") &&
751 test "X$both_ls" = "X$dst$nl$src" || {
757 *//* | */..
/* | */.
/* | /*/*/*/*/*/)
758 die
"invalid symlink calculation: $src -> $dst";;
759 /*/*/*/*/) dot_dots
=..
/..
/..
/;;
760 /*/*/*/) dot_dots
=..
/..
/;;
761 /*/*/) dot_dots
=..
/;;
765 echo "$me: ln -fs $dot_dots$src $dst" &&
766 ln -fs "$dot_dots$src" "$dst"
772 version_controlled_file
() {
775 if test -d .git
; then
776 git
rm -n "$file" > /dev
/null
2>&1
777 elif test -d .svn
; then
778 svn log
-r HEAD
"$file" > /dev
/null
2>&1
779 elif test -d CVS
; then
780 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev
/null
|
781 grep '^/[^/]*/[0-9]' > /dev
/null
783 warn_
"no version control for $file?"
788 # NOTE: we have to be careful to run both autopoint and libtoolize
789 # before gnulib-tool, since gnulib-tool is likely to provide newer
790 # versions of files "installed" by these two programs.
791 # Then, *after* gnulib-tool (see below), we have to be careful to
792 # run autoreconf in such a way that it does not run either of these
793 # two just-pre-run programs.
795 # Import from gettext.
797 grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac
>/dev
/null
|| \
800 if test $with_gettext = yes || test $use_libtool = 1; then
802 tempbase
=.bootstrap$$
803 trap "rm -f $tempbase.0 $tempbase.1" 1 2 13 15
805 > $tempbase.0 > $tempbase.1 &&
806 find .
! -type d
-print | sort > $tempbase.0 || exit
808 if test $with_gettext = yes; then
809 # Released autopoint has the tendency to install macros that have been
810 # obsoleted in current gnulib, so run this before gnulib-tool.
811 echo "$0: $AUTOPOINT --force"
812 $AUTOPOINT --force || exit
815 # Autoreconf runs aclocal before libtoolize, which causes spurious
816 # warnings if the initial aclocal is confused by the libtoolized
817 # (or worse out-of-date) macro directory.
818 # libtoolize 1.9b added the --install option; but we support back
819 # to libtoolize 1.5.22, where the install action was default.
820 if test $use_libtool = 1; then
822 case $($LIBTOOLIZE --help) in
823 *--install*) install=--install ;;
825 echo "running: $LIBTOOLIZE $install --copy"
826 $LIBTOOLIZE $install --copy
829 find .
! -type d
-print | sort >$tempbase.1
832 for file in $(comm -13 $tempbase.0 $tempbase.1); do
835 version_controlled_file
"$parent" "$file" || {
836 for dot_ig
in x
$vc_ignore; do
837 test $dot_ig = x
&& continue
839 insert_vc_ignore
"$ig" "${file##*/}"
845 rm -f $tempbase.0 $tempbase.1
849 # Import from gnulib.
851 gnulib_tool_options
="\
854 --aux-dir $build_aux\
855 --doc-base $doc_base\
858 --source-base $source_base/\
859 --tests-base $tests_base\
860 --local-dir $local_gl_dir\
861 $gnulib_tool_option_extras\
863 if test $use_libtool = 1; then
864 case "$gnulib_tool_options " in
866 *) gnulib_tool_options
="$gnulib_tool_options --libtool" ;;
869 echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
870 $gnulib_tool $gnulib_tool_options --import $gnulib_modules &&
872 for file in $gnulib_files; do
873 symlink_to_dir
"$GNULIB_SRCDIR" $file \
874 || die
"failed to symlink $file"
877 bootstrap_post_import_hook \
878 || die
"bootstrap_post_import_hook failed"
880 # Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
881 # gnulib-populated directories. Such .m4 files would cause aclocal to fail.
882 # The following requires GNU find 4.2.3 or newer. Considering the usual
883 # portability constraints of this script, that may seem a very demanding
884 # requirement, but it should be ok. Ignore any failure, which is fine,
885 # since this is only a convenience to help developers avoid the relatively
886 # unusual case in which a symlinked-to .m4 file is git-removed from gnulib
887 # between successive runs of this script.
888 find "$m4_base" "$source_base" \
889 -depth \
( -name '*.m4' -o -name '*.[ch]' \
) \
890 -type l
-xtype l
-delete > /dev
/null
2>&1
892 # Invoke autoreconf with --force --install to ensure upgrades of tools
894 AUTORECONFFLAGS
="--verbose --install --force -I $m4_base $ACLOCAL_FLAGS"
896 # Some systems (RHEL 5) are using ancient autotools, for which the
897 # --no-recursive option had not been invented. Detect that lack and
898 # omit the option when it's not supported. FIXME in 2017: remove this
899 # hack when RHEL 5 autotools are updated, or when they become irrelevant.
900 case $($AUTORECONF --help) in
901 *--no-recursive*) AUTORECONFFLAGS
="$AUTORECONFFLAGS --no-recursive";;
904 # Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
905 echo "running: AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS"
906 AUTOPOINT
=true LIBTOOLIZE
=true
$AUTORECONF $AUTORECONFFLAGS \
907 || die
"autoreconf failed"
909 # Get some extra files from gnulib, overriding existing files.
910 for file in $gnulib_extra_files; do
912 */INSTALL
) dst
=INSTALL
;;
913 build
-aux/*) dst
=$build_aux/${file#build-aux/};;
916 symlink_to_dir
"$GNULIB_SRCDIR" $file $dst \
917 || die
"failed to symlink $file"
920 if test $with_gettext = yes; then
921 # Create gettext configuration.
922 echo "$0: Creating po/Makevars from po/Makevars.template ..."
925 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
926 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
927 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
928 /^XGETTEXT_OPTIONS *=/{
931 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
933 ' po
/Makevars.template
>po
/Makevars \
934 || die
'cannot generate po/Makevars'
936 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
937 # If only the 'gettext-h' module is in use, assume autopoint already
938 # put the correct version of this file into place.
939 case $gnulib_modules in
942 cp $GNULIB_SRCDIR/build
-aux/po
/Makefile.
in.
in po
/Makefile.
in.
in \
943 || die
"cannot create po/Makefile.in.in"
947 if test -d runtime
-po; then
948 # Similarly for runtime-po/Makevars, but not quite the same.
949 rm -f runtime
-po/Makevars
951 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
952 /^subdir *=.*/s/=.*/= runtime-po/
953 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
954 /^XGETTEXT_OPTIONS *=/{
957 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
959 ' po
/Makevars.template
>runtime
-po/Makevars \
960 || die
'cannot generate runtime-po/Makevars'
962 # Copy identical files from po to runtime-po.
963 (cd po
&& cp -p Makefile.
in.
in *-quot *.header
*.
sed *.sin ..
/runtime
-po)
969 echo "$0: done. Now you can run './configure'."
972 # eval: (add-hook 'write-file-hooks 'time-stamp)
973 # time-stamp-start: "scriptversion="
974 # time-stamp-format: "%:y-%02m-%02d.%02H"
975 # time-stamp-time-zone: "UTC"
976 # time-stamp-end: "; # UTC"