]> git.saurik.com Git - bison.git/blame_incremental - bootstrap
style: minor changes in the Java tests
[bison.git] / bootstrap
... / ...
CommitLineData
1#! /bin/sh
2# Print a version string.
3scriptversion=2013-05-08.20; # UTC
4
5# Bootstrap this package from checked-out sources.
6
7# Copyright (C) 2003-2013 Free Software Foundation, Inc.
8
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.
13
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.
18
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/>.
21
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.
29
30# Please report bugs or propose patches to bug-gnulib@gnu.org.
31
32nl='
33'
34
35# Ensure file names are sorted consistently across platforms.
36LC_ALL=C
37export LC_ALL
38
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
42
43local_gl_dir=gl
44
45me=$0
46
47usage() {
48 cat <<EOF
49Usage: $me [OPTION]...
50Bootstrap this package from the checked-out sources.
51
52Options:
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
69
70If the file $me.conf exists in the same directory as this script, its
71contents are read as shell variables to configure the bootstrap.
72
73For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
74are honored.
75
76Running without arguments will suffice in most cases.
77EOF
78}
79
80# warnf_ FORMAT-STRING ARG1...
81warnf_ ()
82{
83 warnf_format_=$1
84 shift
85 nl='
86'
87 case $* in
88 *$nl*) me_=$(printf "$me"|tr "$nl|" '??')
89 printf "$warnf_format_" "$@" | sed "s|^|$me_: |" ;;
90 *) printf "$me: $warnf_format_" "$@" ;;
91 esac >&2
92}
93
94# warn_ WORD1...
95warn_ ()
96{
97 # If IFS does not start with ' ', set it and emit the warning in a subshell.
98 case $IFS in
99 ' '*) warnf_ '%s\n' "$*";;
100 *) (IFS=' '; warn_ "$@");;
101 esac
102}
103
104# die WORD1...
105die() { warn_ "$@"; exit 1; }
106
107# Configuration.
108
109# Name of the Makefile.am
110gnulib_mk=gnulib.mk
111
112# List of gnulib modules needed.
113gnulib_modules=
114
115# Any gnulib files needed that are not in modules.
116gnulib_files=
117
118: ${AUTOPOINT=autopoint}
119: ${AUTORECONF=autoreconf}
120
121# A function to be called right after gnulib-tool is run.
122# Override it via your own definition in bootstrap.conf.
123bootstrap_post_import_hook() { :; }
124
125# A function to be called after everything else in this script.
126# Override it via your own definition in bootstrap.conf.
127bootstrap_epilogue() { :; }
128
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
133# all symlinks.
134po_download_command_format=\
135"rsync --delete --exclude '*.s1' -Lrtvz \
136 'translationproject.org::tp/latest/%s/' '%s'"
137
138# Fallback for downloading .po files (if rsync fails).
139po_download_command_format2=\
140"wget --mirror -nd -q -np -A.po -P '%s' \
141 http://translationproject.org/latest/%s/"
142
143# Prefer a non-empty tarname (4th argument of AC_INIT if given), else
144# fall back to the package name (1st argument with munging)
145extract_package_name='
146 /^AC_INIT(\[*/{
147 s///
148 /^[^,]*,[^,]*,[^,]*,[ []*\([^][ ,)]\)/{
149 s//\1/
150 s/[],)].*//
151 p
152 q
153 }
154 s/[],)].*//
155 s/^GNU //
156 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
157 s/[^abcdefghijklmnopqrstuvwxyz0123456789_]/-/g
158 p
159 }
160'
161package=$(sed -n "$extract_package_name" configure.ac) \
162 || die 'cannot find package name in configure.ac'
163gnulib_name=lib$package
164
165build_aux=build-aux
166source_base=lib
167m4_base=m4
168doc_base=doc
169tests_base=tests
170gnulib_extra_files=''
171
172# Additional gnulib-tool options to use. Use "\newline" to break lines.
173gnulib_tool_option_extras=
174
175# Other locale categories that need message catalogs.
176EXTRA_LOCALE_CATEGORIES=
177
178# Additional xgettext options to use. Use "\\\newline" to break lines.
179XGETTEXT_OPTIONS='\\\
180 --flag=_:1:pass-c-format\\\
181 --flag=N_:1:pass-c-format\\\
182 --flag=error:3:c-format --flag=error_at_line:5:c-format\\\
183'
184
185# Package bug report address and copyright holder for gettext files
186COPYRIGHT_HOLDER='Free Software Foundation, Inc.'
187MSGID_BUGS_ADDRESS=bug-$package@gnu.org
188
189# Files we don't want to import.
190excluded_files=
191
192# File that should exist in the top directory of a checked out hierarchy,
193# but not in a distribution tarball.
194checkout_only_file=README-hacking
195
196# Whether to use copies instead of symlinks.
197copy=false
198
199# Set this to '.cvsignore .gitignore' in bootstrap.conf if you want
200# those files to be generated in directories like lib/, m4/, and po/.
201# Or set it to 'auto' to make this script select which to use based
202# on which version control system (if any) is used in the source directory.
203vc_ignore=auto
204
205# Set this to true in bootstrap.conf to enable --bootstrap-sync by
206# default.
207bootstrap_sync=false
208
209# Use git to update gnulib sources
210use_git=true
211
212# find_tool ENVVAR NAMES...
213# -------------------------
214# Search for a required program. Use the value of ENVVAR, if set,
215# otherwise find the first of the NAMES that can be run (i.e.,
216# supports --version). If found, set ENVVAR to the program name,
217# die otherwise.
218#
219# FIXME: code duplication, see also gnu-web-doc-update.
220find_tool ()
221{
222 find_tool_envvar=$1
223 shift
224 find_tool_names=$@
225 eval "find_tool_res=\$$find_tool_envvar"
226 if test x"$find_tool_res" = x; then
227 for i
228 do
229 if ($i --version </dev/null) >/dev/null 2>&1; then
230 find_tool_res=$i
231 break
232 fi
233 done
234 else
235 find_tool_error_prefix="\$$find_tool_envvar: "
236 fi
237 test x"$find_tool_res" != x \
238 || die "one of these is required: $find_tool_names"
239 ($find_tool_res --version </dev/null) >/dev/null 2>&1 \
240 || die "${find_tool_error_prefix}cannot run $find_tool_res --version"
241 eval "$find_tool_envvar=\$find_tool_res"
242 eval "export $find_tool_envvar"
243}
244
245# Find sha1sum, named gsha1sum on MacPorts, and shasum on Mac OS X 10.6.
246find_tool SHA1SUM sha1sum gsha1sum shasum
247
248# Override the default configuration, if necessary.
249# Make sure that bootstrap.conf is sourced from the current directory
250# if we were invoked as "sh bootstrap".
251case "$0" in
252 */*) test -r "$0.conf" && . "$0.conf" ;;
253 *) test -r "$0.conf" && . ./"$0.conf" ;;
254esac
255
256# Extra files from gnulib, which override files from other sources.
257test -z "${gnulib_extra_files}" && \
258 gnulib_extra_files="
259 $build_aux/install-sh
260 $build_aux/mdate-sh
261 $build_aux/texinfo.tex
262 $build_aux/depcomp
263 $build_aux/config.guess
264 $build_aux/config.sub
265 doc/INSTALL
266"
267
268if test "$vc_ignore" = auto; then
269 vc_ignore=
270 test -d .git && vc_ignore=.gitignore
271 test -d CVS && vc_ignore="$vc_ignore .cvsignore"
272fi
273
274# Translate configuration into internal form.
275
276# Parse options.
277
278for option
279do
280 case $option in
281 --help)
282 usage
283 exit;;
284 --gnulib-srcdir=*)
285 GNULIB_SRCDIR=${option#--gnulib-srcdir=};;
286 --skip-po)
287 SKIP_PO=t;;
288 --force)
289 checkout_only_file=;;
290 --copy)
291 copy=true;;
292 --bootstrap-sync)
293 bootstrap_sync=true;;
294 --no-bootstrap-sync)
295 bootstrap_sync=false;;
296 --no-git)
297 use_git=false;;
298 *)
299 die "$option: unknown option";;
300 esac
301done
302
303$use_git || test -d "$GNULIB_SRCDIR" \
304 || die "Error: --no-git requires --gnulib-srcdir"
305
306if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
307 die "Bootstrapping from a non-checked-out distribution is risky."
308fi
309
310# Strip blank and comment lines to leave significant entries.
311gitignore_entries() {
312 sed '/^#/d; /^$/d' "$@"
313}
314
315# If $STR is not already on a line by itself in $FILE, insert it at the start.
316# Entries are inserted at the start of the ignore list to ensure existing
317# entries starting with ! are not overridden. Such entries support
318# whitelisting exceptions after a more generic blacklist pattern.
319insert_if_absent() {
320 file=$1
321 str=$2
322 test -f $file || touch $file
323 test -r $file || die "Error: failed to read ignore file: $file"
324 duplicate_entries=$(gitignore_entries $file | sort | uniq -d)
325 if [ "$duplicate_entries" ] ; then
326 die "Error: Duplicate entries in $file: " $duplicate_entries
327 fi
328 linesold=$(gitignore_entries $file | wc -l)
329 linesnew=$(echo "$str" | gitignore_entries - $file | sort -u | wc -l)
330 if [ $linesold != $linesnew ] ; then
331 { echo "$str" | cat - $file > $file.bak && mv $file.bak $file; } \
332 || die "insert_if_absent $file $str: failed"
333 fi
334}
335
336# Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
337# insert_if_absent.
338insert_vc_ignore() {
339 vc_ignore_file="$1"
340 pattern="$2"
341 case $vc_ignore_file in
342 *.gitignore)
343 # A .gitignore entry that does not start with '/' applies
344 # recursively to subdirectories, so prepend '/' to every
345 # .gitignore entry.
346 pattern=$(echo "$pattern" | sed s,^,/,);;
347 esac
348 insert_if_absent "$vc_ignore_file" "$pattern"
349}
350
351# Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
352found_aux_dir=no
353grep '^[ ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'\])' configure.ac \
354 >/dev/null && found_aux_dir=yes
355grep '^[ ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
356 >/dev/null && found_aux_dir=yes
357test $found_aux_dir = yes \
358 || die "configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
359
360# If $build_aux doesn't exist, create it now, otherwise some bits
361# below will malfunction. If creating it, also mark it as ignored.
362if test ! -d $build_aux; then
363 mkdir $build_aux
364 for dot_ig in x $vc_ignore; do
365 test $dot_ig = x && continue
366 insert_vc_ignore $dot_ig $build_aux
367 done
368fi
369
370# Note this deviates from the version comparison in automake
371# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
372# but this should suffice as we won't be specifying old
373# version formats or redundant trailing .0 in bootstrap.conf.
374# If we did want full compatibility then we should probably
375# use m4_version_compare from autoconf.
376sort_ver() { # sort -V is not generally available
377 ver1="$1"
378 ver2="$2"
379
380 # split on '.' and compare each component
381 i=1
382 while : ; do
383 p1=$(echo "$ver1" | cut -d. -f$i)
384 p2=$(echo "$ver2" | cut -d. -f$i)
385 if [ ! "$p1" ]; then
386 echo "$1 $2"
387 break
388 elif [ ! "$p2" ]; then
389 echo "$2 $1"
390 break
391 elif [ ! "$p1" = "$p2" ]; then
392 if [ "$p1" -gt "$p2" ] 2>/dev/null; then # numeric comparison
393 echo "$2 $1"
394 elif [ "$p2" -gt "$p1" ] 2>/dev/null; then # numeric comparison
395 echo "$1 $2"
396 else # numeric, then lexicographic comparison
397 lp=$(printf "$p1\n$p2\n" | LANG=C sort -n | tail -n1)
398 if [ "$lp" = "$p2" ]; then
399 echo "$1 $2"
400 else
401 echo "$2 $1"
402 fi
403 fi
404 break
405 fi
406 i=$(($i+1))
407 done
408}
409
410get_version() {
411 app=$1
412
413 $app --version >/dev/null 2>&1 || return 1
414
415 $app --version 2>&1 |
416 sed -n '# Move version to start of line.
417 s/.*[v ]\([0-9]\)/\1/
418
419 # Skip lines that do not start with version.
420 /^[0-9]/!d
421
422 # Remove characters after the version.
423 s/[^.a-z0-9-].*//
424
425 # The first component must be digits only.
426 s/^\([0-9]*\)[a-z-].*/\1/
427
428 #the following essentially does s/5.005/5.5/
429 s/\.0*\([1-9]\)/.\1/g
430 p
431 q'
432}
433
434check_versions() {
435 ret=0
436
437 while read app req_ver; do
438 # We only need libtoolize from the libtool package.
439 if test "$app" = libtool; then
440 app=libtoolize
441 fi
442 # Exempt git if --no-git is in effect.
443 if test "$app" = git; then
444 $use_git || continue
445 fi
446 # Honor $APP variables ($TAR, $AUTOCONF, etc.)
447 appvar=$(echo $app | LC_ALL=C tr '[a-z]-' '[A-Z]_')
448 test "$appvar" = TAR && appvar=AMTAR
449 case $appvar in
450 GZIP) ;; # Do not use $GZIP: it contains gzip options.
451 *) eval "app=\${$appvar-$app}" ;;
452 esac
453
454 # Handle the still-experimental Automake-NG programs specially.
455 # They remain named as the mainstream Automake programs ("automake",
456 # and "aclocal") to avoid gratuitous incompatibilities with
457 # pre-existing usages (by, say, autoreconf, or custom autogen.sh
458 # scripts), but correctly identify themselves (as being part of
459 # "GNU automake-ng") when asked their version.
460 case $app in
461 automake-ng|aclocal-ng)
462 app=${app%-ng}
463 ($app --version | grep '(GNU automake-ng)') >/dev/null 2>&1 || {
464 warn_ "Error: '$app' not found or not from Automake-NG"
465 ret=1
466 continue
467 } ;;
468 esac
469 if [ "$req_ver" = "-" ]; then
470 # Merely require app to exist; not all prereq apps are well-behaved
471 # so we have to rely on $? rather than get_version.
472 $app --version >/dev/null 2>&1
473 if [ 126 -le $? ]; then
474 warn_ "Error: '$app' not found"
475 ret=1
476 fi
477 else
478 # Require app to produce a new enough version string.
479 inst_ver=$(get_version $app)
480 if [ ! "$inst_ver" ]; then
481 warn_ "Error: '$app' not found"
482 ret=1
483 else
484 latest_ver=$(sort_ver $req_ver $inst_ver | cut -d' ' -f2)
485 if [ ! "$latest_ver" = "$inst_ver" ]; then
486 warnf_ '%s\n' \
487 "Error: '$app' version == $inst_ver is too old" \
488 " '$app' version >= $req_ver is required"
489 ret=1
490 fi
491 fi
492 fi
493 done
494
495 return $ret
496}
497
498print_versions() {
499 echo "Program Min_version"
500 echo "----------------------"
501 printf %s "$buildreq"
502 echo "----------------------"
503 # can't depend on column -t
504}
505
506use_libtool=0
507# We'd like to use grep -E, to see if any of LT_INIT,
508# AC_PROG_LIBTOOL, AM_PROG_LIBTOOL is used in configure.ac,
509# but that's not portable enough (e.g., for Solaris).
510grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac >/dev/null \
511 && use_libtool=1
512grep '^[ ]*LT_INIT' configure.ac >/dev/null \
513 && use_libtool=1
514if test $use_libtool = 1; then
515 find_tool LIBTOOLIZE glibtoolize libtoolize
516fi
517
518# gnulib-tool requires at least automake and autoconf.
519# If either is not listed, add it (with minimum version) as a prerequisite.
520case $buildreq in
521 *automake*) ;;
522 *) buildreq="automake 1.9
523$buildreq" ;;
524esac
525case $buildreq in
526 *autoconf*) ;;
527 *) buildreq="autoconf 2.59
528$buildreq" ;;
529esac
530
531# When we can deduce that gnulib-tool will require patch,
532# and when patch is not already listed as a prerequisite, add it, too.
533if test -d "$local_gl_dir" \
534 && ! find "$local_gl_dir" -name '*.diff' -exec false {} +; then
535 case $buildreq in
536 *patch*) ;;
537 *) buildreq="patch -
538$buildreq" ;;
539 esac
540fi
541
542if ! printf "$buildreq" | check_versions; then
543 echo >&2
544 if test -f README-prereq; then
545 die "See README-prereq for how to get the prerequisite programs"
546 else
547 die "Please install the prerequisite programs"
548 fi
549fi
550
551echo "$0: Bootstrapping from checked-out $package sources..."
552
553# See if we can use gnulib's git-merge-changelog merge driver.
554if test -d .git && (git --version) >/dev/null 2>/dev/null ; then
555 if git config merge.merge-changelog.driver >/dev/null ; then
556 :
557 elif (git-merge-changelog --version) >/dev/null 2>/dev/null ; then
558 echo "$0: initializing git-merge-changelog driver"
559 git config merge.merge-changelog.name 'GNU-style ChangeLog merge driver'
560 git config merge.merge-changelog.driver 'git-merge-changelog %O %A %B'
561 else
562 echo "$0: consider installing git-merge-changelog from gnulib"
563 fi
564fi
565
566
567cleanup_gnulib() {
568 status=$?
569 rm -fr "$gnulib_path"
570 exit $status
571}
572
573git_modules_config () {
574 test -f .gitmodules && git config --file .gitmodules "$@"
575}
576
577gnulib_path=$(git_modules_config submodule.gnulib.path)
578test -z "$gnulib_path" && gnulib_path=gnulib
579
580# Get gnulib files.
581
582case ${GNULIB_SRCDIR--} in
583-)
584 if git_modules_config submodule.gnulib.url >/dev/null; then
585 echo "$0: getting gnulib files..."
586 git submodule init || exit $?
587 git submodule update || exit $?
588
589 elif [ ! -d "$gnulib_path" ]; then
590 echo "$0: getting gnulib files..."
591
592 trap cleanup_gnulib 1 2 13 15
593
594 shallow=
595 git clone -h 2>&1 | grep -- --depth > /dev/null && shallow='--depth 2'
596 git clone $shallow git://git.sv.gnu.org/gnulib "$gnulib_path" ||
597 cleanup_gnulib
598
599 trap - 1 2 13 15
600 fi
601 GNULIB_SRCDIR=$gnulib_path
602 ;;
603*)
604 # Use GNULIB_SRCDIR as a reference.
605 if test -d "$GNULIB_SRCDIR"/.git && \
606 git_modules_config submodule.gnulib.url >/dev/null; then
607 echo "$0: getting gnulib files..."
608 if git submodule -h|grep -- --reference > /dev/null; then
609 # Prefer the one-liner available in git 1.6.4 or newer.
610 git submodule update --init --reference "$GNULIB_SRCDIR" \
611 "$gnulib_path" || exit $?
612 else
613 # This fallback allows at least git 1.5.5.
614 if test -f "$gnulib_path"/gnulib-tool; then
615 # Since file already exists, assume submodule init already complete.
616 git submodule update || exit $?
617 else
618 # Older git can't clone into an empty directory.
619 rmdir "$gnulib_path" 2>/dev/null
620 git clone --reference "$GNULIB_SRCDIR" \
621 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
622 && git submodule init && git submodule update \
623 || exit $?
624 fi
625 fi
626 GNULIB_SRCDIR=$gnulib_path
627 fi
628 ;;
629esac
630
631if $bootstrap_sync; then
632 cmp -s "$0" "$GNULIB_SRCDIR/build-aux/bootstrap" || {
633 echo "$0: updating bootstrap and restarting..."
634 case $(sh -c 'echo "$1"' -- a) in
635 a) ignored=--;;
636 *) ignored=ignored;;
637 esac
638 exec sh -c \
639 'cp "$1" "$2" && shift && exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
640 $ignored "$GNULIB_SRCDIR/build-aux/bootstrap" \
641 "$0" "$@" --no-bootstrap-sync
642 }
643fi
644
645gnulib_tool=$GNULIB_SRCDIR/gnulib-tool
646<$gnulib_tool || exit $?
647
648# Get translations.
649
650download_po_files() {
651 subdir=$1
652 domain=$2
653 echo "$me: getting translations into $subdir for $domain..."
654 cmd=$(printf "$po_download_command_format" "$domain" "$subdir")
655 eval "$cmd" && return
656 # Fallback to HTTP.
657 cmd=$(printf "$po_download_command_format2" "$subdir" "$domain")
658 eval "$cmd"
659}
660
661# Mirror .po files to $po_dir/.reference and copy only the new
662# or modified ones into $po_dir. Also update $po_dir/LINGUAS.
663# Note po files that exist locally only are left in $po_dir but will
664# not be included in LINGUAS and hence will not be distributed.
665update_po_files() {
666 # Directory containing primary .po files.
667 # Overwrite them only when we're sure a .po file is new.
668 po_dir=$1
669 domain=$2
670
671 # Mirror *.po files into this dir.
672 # Usually contains *.s1 checksum files.
673 ref_po_dir="$po_dir/.reference"
674
675 test -d $ref_po_dir || mkdir $ref_po_dir || return
676 download_po_files $ref_po_dir $domain \
677 && ls "$ref_po_dir"/*.po 2>/dev/null |
678 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" || return
679
680 langs=$(cd $ref_po_dir && echo *.po | sed 's/\.po//g')
681 test "$langs" = '*' && langs=x
682 for po in $langs; do
683 case $po in x) continue;; esac
684 new_po="$ref_po_dir/$po.po"
685 cksum_file="$ref_po_dir/$po.s1"
686 if ! test -f "$cksum_file" ||
687 ! test -f "$po_dir/$po.po" ||
688 ! $SHA1SUM -c --status "$cksum_file" \
689 < "$new_po" > /dev/null; then
690 echo "$me: updated $po_dir/$po.po..."
691 cp "$new_po" "$po_dir/$po.po" \
692 && $SHA1SUM < "$new_po" > "$cksum_file"
693 fi
694 done
695}
696
697case $SKIP_PO in
698'')
699 if test -d po; then
700 update_po_files po $package || exit
701 fi
702
703 if test -d runtime-po; then
704 update_po_files runtime-po $package-runtime || exit
705 fi;;
706esac
707
708symlink_to_dir()
709{
710 src=$1/$2
711 dst=${3-$2}
712
713 test -f "$src" && {
714
715 # If the destination directory doesn't exist, create it.
716 # This is required at least for "lib/uniwidth/cjk.h".
717 dst_dir=$(dirname "$dst")
718 if ! test -d "$dst_dir"; then
719 mkdir -p "$dst_dir"
720
721 # If we've just created a directory like lib/uniwidth,
722 # tell version control system(s) it's ignorable.
723 # FIXME: for now, this does only one level
724 parent=$(dirname "$dst_dir")
725 for dot_ig in x $vc_ignore; do
726 test $dot_ig = x && continue
727 ig=$parent/$dot_ig
728 insert_vc_ignore $ig "${dst_dir##*/}"
729 done
730 fi
731
732 if $copy; then
733 {
734 test ! -h "$dst" || {
735 echo "$me: rm -f $dst" &&
736 rm -f "$dst"
737 }
738 } &&
739 test -f "$dst" &&
740 cmp -s "$src" "$dst" || {
741 echo "$me: cp -fp $src $dst" &&
742 cp -fp "$src" "$dst"
743 }
744 else
745 # Leave any existing symlink alone, if it already points to the source,
746 # so that broken build tools that care about symlink times
747 # aren't confused into doing unnecessary builds. Conversely, if the
748 # existing symlink's time stamp is older than the source, make it afresh,
749 # so that broken tools aren't confused into skipping needed builds. See
750 # <http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00326.html>.
751 test -h "$dst" &&
752 src_ls=$(ls -diL "$src" 2>/dev/null) && set $src_ls && src_i=$1 &&
753 dst_ls=$(ls -diL "$dst" 2>/dev/null) && set $dst_ls && dst_i=$1 &&
754 test "$src_i" = "$dst_i" &&
755 both_ls=$(ls -dt "$src" "$dst") &&
756 test "X$both_ls" = "X$dst$nl$src" || {
757 dot_dots=
758 case $src in
759 /*) ;;
760 *)
761 case /$dst/ in
762 *//* | */../* | */./* | /*/*/*/*/*/)
763 die "invalid symlink calculation: $src -> $dst";;
764 /*/*/*/*/) dot_dots=../../../;;
765 /*/*/*/) dot_dots=../../;;
766 /*/*/) dot_dots=../;;
767 esac;;
768 esac
769
770 echo "$me: ln -fs $dot_dots$src $dst" &&
771 ln -fs "$dot_dots$src" "$dst"
772 }
773 fi
774 }
775}
776
777version_controlled_file() {
778 parent=$1
779 file=$2
780 if test -d .git; then
781 git rm -n "$file" > /dev/null 2>&1
782 elif test -d .svn; then
783 svn log -r HEAD "$file" > /dev/null 2>&1
784 elif test -d CVS; then
785 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev/null |
786 grep '^/[^/]*/[0-9]' > /dev/null
787 else
788 warn_ "no version control for $file?"
789 false
790 fi
791}
792
793# NOTE: we have to be careful to run both autopoint and libtoolize
794# before gnulib-tool, since gnulib-tool is likely to provide newer
795# versions of files "installed" by these two programs.
796# Then, *after* gnulib-tool (see below), we have to be careful to
797# run autoreconf in such a way that it does not run either of these
798# two just-pre-run programs.
799
800# Import from gettext.
801with_gettext=yes
802grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac >/dev/null || \
803 with_gettext=no
804
805if test $with_gettext = yes || test $use_libtool = 1; then
806
807 tempbase=.bootstrap$$
808 trap "rm -f $tempbase.0 $tempbase.1" 1 2 13 15
809
810 > $tempbase.0 > $tempbase.1 &&
811 find . ! -type d -print | sort > $tempbase.0 || exit
812
813 if test $with_gettext = yes; then
814 # Released autopoint has the tendency to install macros that have been
815 # obsoleted in current gnulib, so run this before gnulib-tool.
816 echo "$0: $AUTOPOINT --force"
817 $AUTOPOINT --force || exit
818 fi
819
820 # Autoreconf runs aclocal before libtoolize, which causes spurious
821 # warnings if the initial aclocal is confused by the libtoolized
822 # (or worse out-of-date) macro directory.
823 # libtoolize 1.9b added the --install option; but we support back
824 # to libtoolize 1.5.22, where the install action was default.
825 if test $use_libtool = 1; then
826 install=
827 case $($LIBTOOLIZE --help) in
828 *--install*) install=--install ;;
829 esac
830 echo "running: $LIBTOOLIZE $install --copy"
831 $LIBTOOLIZE $install --copy
832 fi
833
834 find . ! -type d -print | sort >$tempbase.1
835 old_IFS=$IFS
836 IFS=$nl
837 for file in $(comm -13 $tempbase.0 $tempbase.1); do
838 IFS=$old_IFS
839 parent=${file%/*}
840 version_controlled_file "$parent" "$file" || {
841 for dot_ig in x $vc_ignore; do
842 test $dot_ig = x && continue
843 ig=$parent/$dot_ig
844 insert_vc_ignore "$ig" "${file##*/}"
845 done
846 }
847 done
848 IFS=$old_IFS
849
850 rm -f $tempbase.0 $tempbase.1
851 trap - 1 2 13 15
852fi
853
854# Import from gnulib.
855
856gnulib_tool_options="\
857 --import\
858 --no-changelog\
859 --aux-dir $build_aux\
860 --doc-base $doc_base\
861 --lib $gnulib_name\
862 --m4-base $m4_base/\
863 --source-base $source_base/\
864 --tests-base $tests_base\
865 --local-dir $local_gl_dir\
866 $gnulib_tool_option_extras\
867"
868if test $use_libtool = 1; then
869 case "$gnulib_tool_options " in
870 *' --libtool '*) ;;
871 *) gnulib_tool_options="$gnulib_tool_options --libtool" ;;
872 esac
873fi
874echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
875$gnulib_tool $gnulib_tool_options --import $gnulib_modules &&
876
877for file in $gnulib_files; do
878 symlink_to_dir "$GNULIB_SRCDIR" $file \
879 || die "failed to symlink $file"
880done
881
882bootstrap_post_import_hook \
883 || die "bootstrap_post_import_hook failed"
884
885# Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
886# gnulib-populated directories. Such .m4 files would cause aclocal to fail.
887# The following requires GNU find 4.2.3 or newer. Considering the usual
888# portability constraints of this script, that may seem a very demanding
889# requirement, but it should be ok. Ignore any failure, which is fine,
890# since this is only a convenience to help developers avoid the relatively
891# unusual case in which a symlinked-to .m4 file is git-removed from gnulib
892# between successive runs of this script.
893find "$m4_base" "$source_base" \
894 -depth \( -name '*.m4' -o -name '*.[ch]' \) \
895 -type l -xtype l -delete > /dev/null 2>&1
896
897# Invoke autoreconf with --force --install to ensure upgrades of tools
898# such as ylwrap.
899AUTORECONFFLAGS="--verbose --install --force -I $m4_base $ACLOCAL_FLAGS"
900
901# Some systems (RHEL 5) are using ancient autotools, for which the
902# --no-recursive option had not been invented. Detect that lack and
903# omit the option when it's not supported. FIXME in 2017: remove this
904# hack when RHEL 5 autotools are updated, or when they become irrelevant.
905case $($AUTORECONF --help) in
906 *--no-recursive*) AUTORECONFFLAGS="$AUTORECONFFLAGS --no-recursive";;
907esac
908
909# Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
910echo "running: AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS"
911AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS \
912 || die "autoreconf failed"
913
914# Get some extra files from gnulib, overriding existing files.
915for file in $gnulib_extra_files; do
916 case $file in
917 */INSTALL) dst=INSTALL;;
918 build-aux/*) dst=$build_aux/${file#build-aux/};;
919 *) dst=$file;;
920 esac
921 symlink_to_dir "$GNULIB_SRCDIR" $file $dst \
922 || die "failed to symlink $file"
923done
924
925if test $with_gettext = yes; then
926 # Create gettext configuration.
927 echo "$0: Creating po/Makevars from po/Makevars.template ..."
928 rm -f po/Makevars
929 sed '
930 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
931 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
932 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
933 /^XGETTEXT_OPTIONS *=/{
934 s/$/ \\/
935 a\
936 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
937 }
938 ' po/Makevars.template >po/Makevars \
939 || die 'cannot generate po/Makevars'
940
941 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
942 # If only the 'gettext-h' module is in use, assume autopoint already
943 # put the correct version of this file into place.
944 case $gnulib_modules in
945 *gettext-h*) ;;
946 *gettext*)
947 cp $GNULIB_SRCDIR/build-aux/po/Makefile.in.in po/Makefile.in.in \
948 || die "cannot create po/Makefile.in.in"
949 ;;
950 esac
951
952 if test -d runtime-po; then
953 # Similarly for runtime-po/Makevars, but not quite the same.
954 rm -f runtime-po/Makevars
955 sed '
956 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
957 /^subdir *=.*/s/=.*/= runtime-po/
958 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
959 /^XGETTEXT_OPTIONS *=/{
960 s/$/ \\/
961 a\
962 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
963 }
964 ' po/Makevars.template >runtime-po/Makevars \
965 || die 'cannot generate runtime-po/Makevars'
966
967 # Copy identical files from po to runtime-po.
968 (cd po && cp -p Makefile.in.in *-quot *.header *.sed *.sin ../runtime-po)
969 fi
970fi
971
972bootstrap_epilogue
973
974echo "$0: done. Now you can run './configure'."
975
976# Local variables:
977# eval: (add-hook 'write-file-hooks 'time-stamp)
978# time-stamp-start: "scriptversion="
979# time-stamp-format: "%:y-%02m-%02d.%02H"
980# time-stamp-time-zone: "UTC"
981# time-stamp-end: "; # UTC"
982# End: