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