2 # Print a version string.
3 scriptversion
=2012-05-15.06
; # 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.
82 # Name of the Makefile.am
85 # List of gnulib modules needed.
88 # Any gnulib files needed that are not in modules.
91 : ${AUTOPOINT=autopoint}
92 : ${AUTORECONF=autoreconf}
94 # A function to be called right after gnulib-tool is run.
95 # Override it via your own definition in bootstrap.conf.
96 bootstrap_post_import_hook
() { :; }
98 # A function to be called after everything else in this script.
99 # Override it via your own definition in bootstrap.conf.
100 bootstrap_epilogue
() { :; }
102 # The command to download all .po files for a specified domain into
103 # a specified directory. Fill in the first %s is the domain name, and
104 # the second with the destination directory. Use rsync's -L and -r
105 # options because the latest/%s directory and the .po files within are
107 po_download_command_format
=\
108 "rsync --delete --exclude '*.s1' -Lrtvz \
109 'translationproject.org::tp/latest/%s/' '%s'"
111 # Fallback for downloading .po files (if rsync fails).
112 po_download_command_format2
=\
113 "wget --mirror -nd -q -np -A.po -P '%s' \
114 http://translationproject.org/latest/%s/"
116 extract_package_name
='
128 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
133 package
=$
(sed -n "$extract_package_name" configure.ac
) ||
exit
134 gnulib_name
=lib
$package
141 gnulib_extra_files
=''
143 # Additional gnulib-tool options to use. Use "\newline" to break lines.
144 gnulib_tool_option_extras
=
146 # Other locale categories that need message catalogs.
147 EXTRA_LOCALE_CATEGORIES
=
149 # Additional xgettext options to use. Use "\\\newline" to break lines.
150 XGETTEXT_OPTIONS
='\\\
151 --flag=_:1:pass-c-format\\\
152 --flag=N_:1:pass-c-format\\\
153 --flag=error:3:c-format --flag=error_at_line:5:c-format\\\
156 # Package bug report address and copyright holder for gettext files
157 COPYRIGHT_HOLDER
='Free Software Foundation, Inc.'
158 MSGID_BUGS_ADDRESS
=bug-
$package@gnu.org
160 # Files we don't want to import.
163 # File that should exist in the top directory of a checked out hierarchy,
164 # but not in a distribution tarball.
165 checkout_only_file
=README-hacking
167 # Whether to use copies instead of symlinks.
170 # Set this to '.cvsignore .gitignore' in bootstrap.conf if you want
171 # those files to be generated in directories like lib/, m4/, and po/.
172 # Or set it to 'auto' to make this script select which to use based
173 # on which version control system (if any) is used in the source directory.
176 # Set this to true in bootstrap.conf to enable --bootstrap-sync by
180 # Use git to update gnulib sources
183 # find_tool ENVVAR NAMES...
184 # -------------------------
185 # Search for a required program. Use the value of ENVVAR, if set,
186 # otherwise find the first of the NAMES that can be run (i.e.,
187 # supports --version). If found, set ENVVAR to the program name,
194 eval "find_tool_res=\$$find_tool_envvar"
195 if test x
"$find_tool_res" = x
; then
198 if ($i --version </dev
/null
) >/dev
/null
2>&1; then
204 find_tool_error_prefix
="\$$find_tool_envvar: "
206 if test x
"$find_tool_res" = x
; then
207 echo >&2 "$me: one of these is required: $find_tool_names"
210 ($find_tool_res --version </dev
/null
) >/dev
/null
2>&1 ||
{
211 echo >&2 "$me: ${find_tool_error_prefix}cannot run $find_tool_res --version"
214 eval "$find_tool_envvar=\$find_tool_res"
215 eval "export $find_tool_envvar"
218 # Find sha1sum, named gsha1sum on MacPorts, and shasum on MacOS 10.6.
219 find_tool SHA1SUM
sha1sum gsha1sum shasum
221 # Override the default configuration, if necessary.
222 # Make sure that bootstrap.conf is sourced from the current directory
223 # if we were invoked as "sh bootstrap".
225 */*) test -r "$0.conf" && .
"$0.conf" ;;
226 *) test -r "$0.conf" && . .
/"$0.conf" ;;
229 # Extra files from gnulib, which override files from other sources.
230 test -z "${gnulib_extra_files}" && \
232 $build_aux/install-sh
235 $build_aux/texinfo.tex
237 $build_aux/config.guess
238 $build_aux/config.sub
242 if test "$vc_ignore" = auto
; then
244 test -d .git
&& vc_ignore
=.gitignore
245 test -d CVS
&& vc_ignore
="$vc_ignore .cvsignore"
248 # Translate configuration into internal form.
259 GNULIB_SRCDIR
=${option#--gnulib-srcdir=};;
263 checkout_only_file
=;;
267 bootstrap_sync
=true
;;
269 bootstrap_sync
=false
;;
273 echo >&2 "$0: $option: unknown option"
278 if $use_git ||
test -d "$GNULIB_SRCDIR"; then
281 echo "$0: Error: --no-git requires --gnulib-srcdir" >&2
285 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
286 echo "$0: Bootstrapping from a non-checked-out distribution is risky." >&2
290 # Ensure that lines starting with ! sort last, per gitignore conventions
291 # for whitelisting exceptions after a more generic blacklist pattern.
293 sort -u "$@" |
sed '/^!/ {
304 # If $STR is not already on a line by itself in $FILE, insert it,
305 # sorting the new contents of the file and replacing $FILE with the result.
306 insert_sorted_if_absent
() {
309 test -f $file ||
touch $file
310 echo "$str" | sort_patterns
- $file |
cmp -s - $file > /dev
/null \
311 ||
{ echo "$str" | sort_patterns
- $file > $file.bak \
312 && mv $file.bak
$file; } \
316 # Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
317 # insert_sorted_if_absent.
321 case $vc_ignore_file in
323 # A .gitignore entry that does not start with '/' applies
324 # recursively to subdirectories, so prepend '/' to every
326 pattern
=$
(echo "$pattern" |
sed s
,^
,/,);;
328 insert_sorted_if_absent
"$vc_ignore_file" "$pattern"
331 # Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
333 grep '^[ ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'\])' configure.ac \
334 >/dev
/null
&& found_aux_dir
=yes
335 grep '^[ ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
336 >/dev
/null
&& found_aux_dir
=yes
337 if test $found_aux_dir = no
; then
338 echo "$0: expected line not found in configure.ac. Add the following:" >&2
339 echo " AC_CONFIG_AUX_DIR([$build_aux])" >&2
343 # If $build_aux doesn't exist, create it now, otherwise some bits
344 # below will malfunction. If creating it, also mark it as ignored.
345 if test ! -d $build_aux; then
347 for dot_ig
in x
$vc_ignore; do
348 test $dot_ig = x
&& continue
349 insert_vc_ignore
$dot_ig $build_aux
353 # Note this deviates from the version comparison in automake
354 # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
355 # but this should suffice as we won't be specifying old
356 # version formats or redundant trailing .0 in bootstrap.conf.
357 # If we did want full compatibility then we should probably
358 # use m4_version_compare from autoconf.
359 sort_ver
() { # sort -V is not generally available
363 # split on '.' and compare each component
366 p1
=$
(echo "$ver1" | cut
-d.
-f$i)
367 p2
=$
(echo "$ver2" | cut
-d.
-f$i)
371 elif [ ! "$p2" ]; then
374 elif [ ! "$p1" = "$p2" ]; then
375 if [ "$p1" -gt "$p2" ] 2>/dev
/null
; then # numeric comparison
377 elif [ "$p2" -gt "$p1" ] 2>/dev
/null
; then # numeric comparison
379 else # numeric, then lexicographic comparison
380 lp=$
(printf "$p1\n$p2\n" | LANG
=C
sort -n |
tail -n1)
381 if [ "$lp" = "$p2" ]; then
396 $app --version >/dev
/null
2>&1 ||
return 1
398 $app --version 2>&1 |
399 sed -n '# Move version to start of line.
400 s/.*[v ]\([0-9]\)/\1/
402 # Skip lines that do not start with version.
405 # Remove characters after the version.
408 # The first component must be digits only.
409 s/^\([0-9]*\)[a-z-].*/\1/
411 #the following essentially does s/5.005/5.5/
412 s/\.0*\([1-9]\)/.\1/g
420 while read app req_ver
; do
421 # We only need libtoolize from the libtool package.
422 if test "$app" = libtool
; then
425 # Exempt git if --no-git is in effect.
426 if test "$app" = git
; then
429 # Honor $APP variables ($TAR, $AUTOCONF, etc.)
430 appvar
=$
(echo $app | LC_ALL
=C
tr '[a-z]-' '[A-Z]_')
431 test "$appvar" = TAR
&& appvar
=AMTAR
433 GZIP
) ;; # Do not use $GZIP: it contains gzip options.
434 *) eval "app=\${$appvar-$app}" ;;
437 # Handle the still-experimental Automake-NG programs specially.
438 # They remain named as the mainstream Automake programs ("automake",
439 # and "aclocal") to avoid gratuitous incompatibilities with
440 # pre-existing usages (by, say, autoreconf, or custom autogen.sh
441 # scripts), but correctly identify themselves (as being part of
442 # "GNU automake-ng") when asked their version.
444 automake-ng|aclocal-ng
)
446 ($app --version |
grep '(GNU automake-ng)') >/dev
/null
2>&1 ||
{
447 echo "$me: Error: '$app' not found or not from Automake-NG" >&2
452 if [ "$req_ver" = "-" ]; then
453 # Merely require app to exist; not all prereq apps are well-behaved
454 # so we have to rely on $? rather than get_version.
455 $app --version >/dev
/null
2>&1
456 if [ 126 -le $?
]; then
457 echo "$me: Error: '$app' not found" >&2
461 # Require app to produce a new enough version string.
462 inst_ver
=$
(get_version
$app)
463 if [ ! "$inst_ver" ]; then
464 echo "$me: Error: '$app' not found" >&2
467 latest_ver
=$
(sort_ver
$req_ver $inst_ver | cut
-d' ' -f2)
468 if [ ! "$latest_ver" = "$inst_ver" ]; then
469 echo "$me: Error: '$app' version == $inst_ver is too old" >&2
470 echo " '$app' version >= $req_ver is required" >&2
481 echo "Program Min_version"
482 echo "----------------------"
483 printf %s
"$buildreq"
484 echo "----------------------"
485 # can't depend on column -t
489 # We'd like to use grep -E, to see if any of LT_INIT,
490 # AC_PROG_LIBTOOL, AM_PROG_LIBTOOL is used in configure.ac,
491 # but that's not portable enough (e.g., for Solaris).
492 grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac
>/dev
/null \
494 grep '^[ ]*LT_INIT' configure.ac
>/dev
/null \
496 if test $use_libtool = 1; then
497 find_tool LIBTOOLIZE glibtoolize libtoolize
500 # gnulib-tool requires at least automake and autoconf.
501 # If either is not listed, add it (with minimum version) as a prerequisite.
504 *) buildreq
="automake 1.9
509 *) buildreq
="autoconf 2.59
513 # When we can deduce that gnulib-tool will require patch,
514 # and when patch is not already listed as a prerequisite, add it, too.
515 if test -d "$local_gl_dir" \
516 && ! find "$local_gl_dir" -name '*.diff' -exec false
{} +; then
524 if ! printf "$buildreq" | check_versions
; then
526 if test -f README-prereq
; then
527 echo "$0: See README-prereq for how to get the prerequisite programs" >&2
529 echo "$0: Please install the prerequisite programs" >&2
534 echo "$0: Bootstrapping from checked-out $package sources..."
536 # See if we can use gnulib's git-merge-changelog merge driver.
537 if test -d .git
&& (git
--version) >/dev
/null
2>/dev
/null
; then
538 if git config merge.merge-changelog.driver
>/dev
/null
; then
540 elif (git-merge-changelog
--version) >/dev
/null
2>/dev
/null
; then
541 echo "$0: initializing git-merge-changelog driver"
542 git config merge.merge-changelog.name
'GNU-style ChangeLog merge driver'
543 git config merge.merge-changelog.driver
'git-merge-changelog %O %A %B'
545 echo "$0: consider installing git-merge-changelog from gnulib"
552 rm -fr "$gnulib_path"
556 git_modules_config
() {
557 test -f .gitmodules
&& git config
--file .gitmodules
"$@"
560 gnulib_path
=$
(git_modules_config submodule.gnulib.path
)
561 test -z "$gnulib_path" && gnulib_path
=gnulib
565 case ${GNULIB_SRCDIR--} in
567 if git_modules_config submodule.gnulib.url
>/dev
/null
; then
568 echo "$0: getting gnulib files..."
569 git submodule init ||
exit $?
570 git submodule update ||
exit $?
572 elif [ ! -d "$gnulib_path" ]; then
573 echo "$0: getting gnulib files..."
575 trap cleanup_gnulib
1 2 13 15
578 git clone
-h 2>&1 |
grep -- --depth > /dev
/null
&& shallow
='--depth 2'
579 git clone
$shallow git
://git.sv.gnu.org
/gnulib
"$gnulib_path" ||
584 GNULIB_SRCDIR
=$gnulib_path
587 # Use GNULIB_SRCDIR as a reference.
588 if test -d "$GNULIB_SRCDIR"/.git
&& \
589 git_modules_config submodule.gnulib.url
>/dev
/null
; then
590 echo "$0: getting gnulib files..."
591 if git submodule
-h|
grep -- --reference > /dev
/null
; then
592 # Prefer the one-liner available in git 1.6.4 or newer.
593 git submodule update
--init --reference "$GNULIB_SRCDIR" \
594 "$gnulib_path" ||
exit $?
596 # This fallback allows at least git 1.5.5.
597 if test -f "$gnulib_path"/gnulib-tool
; then
598 # Since file already exists, assume submodule init already complete.
599 git submodule update ||
exit $?
601 # Older git can't clone into an empty directory.
602 rmdir "$gnulib_path" 2>/dev
/null
603 git clone
--reference "$GNULIB_SRCDIR" \
604 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
605 && git submodule init
&& git submodule update \
609 GNULIB_SRCDIR
=$gnulib_path
614 if $bootstrap_sync; then
615 cmp -s "$0" "$GNULIB_SRCDIR/build-aux/bootstrap" ||
{
616 echo "$0: updating bootstrap and restarting..."
618 'cp "$1" "$2" && shift && exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
619 -- "$GNULIB_SRCDIR/build-aux/bootstrap" \
620 "$0" "$@" --no-bootstrap-sync
624 gnulib_tool
=$GNULIB_SRCDIR/gnulib-tool
625 <$gnulib_tool ||
exit $?
629 download_po_files
() {
632 echo "$me: getting translations into $subdir for $domain..."
633 cmd
=$
(printf "$po_download_command_format" "$domain" "$subdir")
634 eval "$cmd" && return
636 cmd
=$
(printf "$po_download_command_format2" "$subdir" "$domain")
640 # Mirror .po files to $po_dir/.reference and copy only the new
641 # or modified ones into $po_dir. Also update $po_dir/LINGUAS.
642 # Note po files that exist locally only are left in $po_dir but will
643 # not be included in LINGUAS and hence will not be distributed.
645 # Directory containing primary .po files.
646 # Overwrite them only when we're sure a .po file is new.
650 # Mirror *.po files into this dir.
651 # Usually contains *.s1 checksum files.
652 ref_po_dir
="$po_dir/.reference"
654 test -d $ref_po_dir || mkdir
$ref_po_dir ||
return
655 download_po_files
$ref_po_dir $domain \
656 && ls "$ref_po_dir"/*.po
2>/dev
/null |
657 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" ||
return
659 langs
=$
(cd $ref_po_dir && echo *.po |
sed 's/\.po//g')
660 test "$langs" = '*' && langs
=x
662 case $po in x
) continue;; esac
663 new_po
="$ref_po_dir/$po.po"
664 cksum_file
="$ref_po_dir/$po.s1"
665 if ! test -f "$cksum_file" ||
666 ! test -f "$po_dir/$po.po" ||
667 ! $SHA1SUM -c --status "$cksum_file" \
668 < "$new_po" > /dev
/null
; then
669 echo "$me: updated $po_dir/$po.po..."
670 cp "$new_po" "$po_dir/$po.po" \
671 && $SHA1SUM < "$new_po" > "$cksum_file"
679 update_po_files po
$package ||
exit
682 if test -d runtime-po
; then
683 update_po_files runtime-po
$package-runtime ||
exit
694 # If the destination directory doesn't exist, create it.
695 # This is required at least for "lib/uniwidth/cjk.h".
696 dst_dir
=$
(dirname "$dst")
697 if ! test -d "$dst_dir"; then
700 # If we've just created a directory like lib/uniwidth,
701 # tell version control system(s) it's ignorable.
702 # FIXME: for now, this does only one level
703 parent
=$
(dirname "$dst_dir")
704 for dot_ig
in x
$vc_ignore; do
705 test $dot_ig = x
&& continue
707 insert_vc_ignore
$ig "${dst_dir##*/}"
713 test ! -h "$dst" ||
{
714 echo "$me: rm -f $dst" &&
719 cmp -s "$src" "$dst" ||
{
720 echo "$me: cp -fp $src $dst" &&
724 # Leave any existing symlink alone, if it already points to the source,
725 # so that broken build tools that care about symlink times
726 # aren't confused into doing unnecessary builds. Conversely, if the
727 # existing symlink's time stamp is older than the source, make it afresh,
728 # so that broken tools aren't confused into skipping needed builds. See
729 # <http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00326.html>.
731 src_ls
=$
(ls -diL "$src" 2>/dev
/null
) && set $src_ls && src_i
=$1 &&
732 dst_ls
=$
(ls -diL "$dst" 2>/dev
/null
) && set $dst_ls && dst_i
=$1 &&
733 test "$src_i" = "$dst_i" &&
734 both_ls
=$
(ls -dt "$src" "$dst") &&
735 test "X$both_ls" = "X$dst$nl$src" ||
{
741 *//* |
*/..
/* |
*/.
/* |
/*/*/*/*/*/)
742 echo >&2 "$me: invalid symlink calculation: $src -> $dst"
744 /*/*/*/*/) dot_dots
=..
/..
/..
/;;
745 /*/*/*/) dot_dots
=..
/..
/;;
746 /*/*/) dot_dots
=..
/;;
750 echo "$me: ln -fs $dot_dots$src $dst" &&
751 ln -fs "$dot_dots$src" "$dst"
757 version_controlled_file
() {
760 if test -d .git
; then
761 git
rm -n "$file" > /dev
/null
2>&1
762 elif test -d .svn
; then
763 svn log
-r HEAD
"$file" > /dev
/null
2>&1
764 elif test -d CVS
; then
765 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev
/null |
766 grep '^/[^/]*/[0-9]' > /dev
/null
768 echo "$me: no version control for $file?" >&2
773 # NOTE: we have to be careful to run both autopoint and libtoolize
774 # before gnulib-tool, since gnulib-tool is likely to provide newer
775 # versions of files "installed" by these two programs.
776 # Then, *after* gnulib-tool (see below), we have to be careful to
777 # run autoreconf in such a way that it does not run either of these
778 # two just-pre-run programs.
780 # Import from gettext.
782 grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac
>/dev
/null || \
785 if test $with_gettext = yes ||
test $use_libtool = 1; then
787 tempbase
=.bootstrap$$
788 trap "rm -f $tempbase.0 $tempbase.1" 1 2 13 15
790 > $tempbase.0 > $tempbase.1 &&
791 find .
! -type d
-print |
sort > $tempbase.0 ||
exit
793 if test $with_gettext = yes; then
794 # Released autopoint has the tendency to install macros that have been
795 # obsoleted in current gnulib, so run this before gnulib-tool.
796 echo "$0: $AUTOPOINT --force"
797 $AUTOPOINT --force ||
exit
800 # Autoreconf runs aclocal before libtoolize, which causes spurious
801 # warnings if the initial aclocal is confused by the libtoolized
802 # (or worse out-of-date) macro directory.
803 # libtoolize 1.9b added the --install option; but we support back
804 # to libtoolize 1.5.22, where the install action was default.
805 if test $use_libtool = 1; then
807 case $
($LIBTOOLIZE --help) in
808 *--install*) install=--install ;;
810 echo "running: $LIBTOOLIZE $install --copy"
811 $LIBTOOLIZE $install --copy
814 find .
! -type d
-print |
sort >$tempbase.1
817 for file in $
(comm -13 $tempbase.0 $tempbase.1); do
820 version_controlled_file
"$parent" "$file" ||
{
821 for dot_ig
in x
$vc_ignore; do
822 test $dot_ig = x
&& continue
824 insert_vc_ignore
"$ig" "${file##*/}"
830 rm -f $tempbase.0 $tempbase.1
834 # Import from gnulib.
836 gnulib_tool_options
="\
839 --aux-dir $build_aux\
840 --doc-base $doc_base\
843 --source-base $source_base/\
844 --tests-base $tests_base\
845 --local-dir $local_gl_dir\
846 $gnulib_tool_option_extras\
848 if test $use_libtool = 1; then
849 case "$gnulib_tool_options " in
851 *) gnulib_tool_options
="$gnulib_tool_options --libtool" ;;
854 echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
855 $gnulib_tool $gnulib_tool_options --import $gnulib_modules &&
857 for file in $gnulib_files; do
858 symlink_to_dir
"$GNULIB_SRCDIR" $file ||
exit
861 bootstrap_post_import_hook \
862 ||
{ echo >&2 "$me: bootstrap_post_import_hook failed"; exit 1; }
864 # Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
865 # gnulib-populated directories. Such .m4 files would cause aclocal to fail.
866 # The following requires GNU find 4.2.3 or newer. Considering the usual
867 # portability constraints of this script, that may seem a very demanding
868 # requirement, but it should be ok. Ignore any failure, which is fine,
869 # since this is only a convenience to help developers avoid the relatively
870 # unusual case in which a symlinked-to .m4 file is git-removed from gnulib
871 # between successive runs of this script.
872 find "$m4_base" "$source_base" \
873 -depth \
( -name '*.m4' -o -name '*.[ch]' \
) \
874 -type l
-xtype l
-delete > /dev
/null
2>&1
876 # Some systems (RHEL 5) are using ancient autotools, for which the
877 # --no-recursive option had not been invented. Detect that lack and
878 # omit the option when it's not supported. FIXME in 2017: remove this
879 # hack when RHEL 5 autotools are updated, or when they become irrelevant.
881 case $
($AUTORECONF --help) in
882 *--no-recursive*) no_recursive
=--no-recursive;;
885 # Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
886 echo "running: AUTOPOINT=true LIBTOOLIZE=true " \
887 "$AUTORECONF --verbose --install $no_recursive -I $m4_base $ACLOCAL_FLAGS"
888 AUTOPOINT
=true LIBTOOLIZE
=true \
889 $AUTORECONF --verbose --install $no_recursive -I $m4_base $ACLOCAL_FLAGS \
892 # Get some extra files from gnulib, overriding existing files.
893 for file in $gnulib_extra_files; do
895 */INSTALL
) dst
=INSTALL
;;
896 build-aux
/*) dst
=$build_aux/${file#build-aux/};;
899 symlink_to_dir
"$GNULIB_SRCDIR" $file $dst ||
exit
902 if test $with_gettext = yes; then
903 # Create gettext configuration.
904 echo "$0: Creating po/Makevars from po/Makevars.template ..."
907 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
908 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
909 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
910 /^XGETTEXT_OPTIONS *=/{
913 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
915 ' po
/Makevars.template
>po
/Makevars ||
exit 1
917 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
918 # If only the 'gettext-h' module is in use, assume autopoint already
919 # put the correct version of this file into place.
920 case $gnulib_modules in
923 cp $GNULIB_SRCDIR/build-aux
/po
/Makefile.
in.
in po
/Makefile.
in.
in ||
exit 1
927 if test -d runtime-po
; then
928 # Similarly for runtime-po/Makevars, but not quite the same.
929 rm -f runtime-po
/Makevars
931 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
932 /^subdir *=.*/s/=.*/= runtime-po/
933 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
934 /^XGETTEXT_OPTIONS *=/{
937 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
939 ' po
/Makevars.template
>runtime-po
/Makevars ||
exit 1
941 # Copy identical files from po to runtime-po.
942 (cd po
&& cp -p Makefile.
in.
in *-quot *.header
*.
sed *.sin ..
/runtime-po
)
948 echo "$0: done. Now you can run './configure'."
951 # eval: (add-hook 'write-file-hooks 'time-stamp)
952 # time-stamp-start: "scriptversion="
953 # time-stamp-format: "%:y-%02m-%02d.%02H"
954 # time-stamp-time-zone: "UTC"
955 # time-stamp-end: "; # UTC"