]> git.saurik.com Git - bison.git/blame - bootstrap
uniqstr: fix assertion
[bison.git] / bootstrap
CommitLineData
01c56de4 1#! /bin/sh
86996fca 2# Print a version string.
41dfa1cb 3scriptversion=2013-07-03.20; # UTC
01c56de4 4
bbb44d83 5# Bootstrap this package from checked-out sources.
01c56de4 6
a565f732 7# Copyright (C) 2003-2013 Free Software Foundation, Inc.
1f65350a 8
f16b0819 9# This program is free software: you can redistribute it and/or modify
1f65350a 10# it under the terms of the GNU General Public License as published by
f16b0819
PE
11# the Free Software Foundation, either version 3 of the License, or
12# (at your option) any later version.
6d8e724d 13
1f65350a
PE
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.
6d8e724d 18
1f65350a 19# You should have received a copy of the GNU General Public License
f16b0819 20# along with this program. If not, see <http://www.gnu.org/licenses/>.
1f65350a 21
86996fca
PE
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.
1f65350a 31
3b2942e6
PE
32nl='
33'
5a2baae7 34
62a9592d 35# Ensure file names are sorted consistently across platforms.
a9f027b9
PE
36LC_ALL=C
37export LC_ALL
38
b2c4c25d
AD
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
6d8e724d
PE
43local_gl_dir=gl
44
a898435b 45me=$0
bbb44d83 46
e3ddc1e3 47usage() {
c1455bab 48 cat <<EOF
a898435b 49Usage: $me [OPTION]...
10f429ef 50Bootstrap this package from the checked-out sources.
e3ddc1e3
PE
51
52Options:
a898435b 53 --gnulib-srcdir=DIRNAME specify the local directory where gnulib
f0a43dd1
JD
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
a898435b
JD
57 them again. Defaults to \$GNULIB_SRCDIR
58 --bootstrap-sync if this bootstrap script is not identical to
dcd39f1d
JD
59 the version in the local gnulib sources,
60 update this script, and then restart it with
a898435b
JD
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
e3ddc1e3
PE
71contents are read as shell variables to configure the bootstrap.
72
f0a43dd1
JD
73For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
74are honored.
75
e3ddc1e3 76Running without arguments will suffice in most cases.
c1455bab 77EOF
e3ddc1e3 78}
3b2942e6 79
41c11ce4
AD
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
3b2942e6
PE
107# Configuration.
108
6d8e724d
PE
109# Name of the Makefile.am
110gnulib_mk=gnulib.mk
111
3b2942e6
PE
112# List of gnulib modules needed.
113gnulib_modules=
114
115# Any gnulib files needed that are not in modules.
116gnulib_files=
117
ee7e9e3b
JM
118: ${AUTOPOINT=autopoint}
119: ${AUTORECONF=autoreconf}
120
121# A function to be called right after gnulib-tool is run.
86996fca 122# Override it via your own definition in bootstrap.conf.
ee7e9e3b 123bootstrap_post_import_hook() { :; }
86996fca 124
f0a43dd1
JD
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
6d8e724d
PE
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=\
86996fca
PE
135"rsync --delete --exclude '*.s1' -Lrtvz \
136 'translationproject.org::tp/latest/%s/' '%s'"
3b2942e6 137
ee7e9e3b
JM
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
f9340b27
AD
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)
3b2942e6 145extract_package_name='
f9340b27
AD
146 /^AC_INIT(\[*/{
147 s///
148 /^[^,]*,[^,]*,[^,]*,[ []*\([^][ ,)]\)/{
149 s//\1/
150 s/[],)].*//
3b2942e6
PE
151 p
152 q
153 }
f9340b27 154 s/[],)].*//
3b2942e6
PE
155 s/^GNU //
156 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
f9340b27 157 s/[^abcdefghijklmnopqrstuvwxyz0123456789_]/-/g
3b2942e6
PE
158 p
159 }
160'
41c11ce4
AD
161package=$(sed -n "$extract_package_name" configure.ac) \
162 || die 'cannot find package name in configure.ac'
bbb44d83 163gnulib_name=lib$package
3b2942e6 164
bbb44d83 165build_aux=build-aux
f0a43dd1
JD
166source_base=lib
167m4_base=m4
168doc_base=doc
169tests_base=tests
a898435b 170gnulib_extra_files=''
3b2942e6 171
6d8e724d 172# Additional gnulib-tool options to use. Use "\newline" to break lines.
163bb369 173gnulib_tool_option_extras=
6d8e724d 174
3b2942e6
PE
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
86996fca
PE
185# Package bug report address and copyright holder for gettext files
186COPYRIGHT_HOLDER='Free Software Foundation, Inc.'
f0a43dd1
JD
187MSGID_BUGS_ADDRESS=bug-$package@gnu.org
188
3b2942e6
PE
189# Files we don't want to import.
190excluded_files=
191
10f429ef
PE
192# File that should exist in the top directory of a checked out hierarchy,
193# but not in a distribution tarball.
86996fca 194checkout_only_file=README-hacking
e3ddc1e3 195
46356ea4
PE
196# Whether to use copies instead of symlinks.
197copy=false
198
6d8e724d
PE
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
dcd39f1d
JD
205# Set this to true in bootstrap.conf to enable --bootstrap-sync by
206# default.
207bootstrap_sync=false
208
a898435b
JD
209# Use git to update gnulib sources
210use_git=true
211
d7be4085
AD
212# find_tool ENVVAR NAMES...
213# -------------------------
f0a43dd1
JD
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.,
3710dd02
AD
216# supports --version). If found, set ENVVAR to the program name,
217# die otherwise.
d511fbd5
AD
218#
219# FIXME: code duplication, see also gnu-web-doc-update.
d7be4085
AD
220find_tool ()
221{
d7be4085
AD
222 find_tool_envvar=$1
223 shift
3710dd02
AD
224 find_tool_names=$@
225 eval "find_tool_res=\$$find_tool_envvar"
226 if test x"$find_tool_res" = x; then
d7be4085
AD
227 for i
228 do
229 if ($i --version </dev/null) >/dev/null 2>&1; then
3710dd02
AD
230 find_tool_res=$i
231 break
d7be4085
AD
232 fi
233 done
3710dd02
AD
234 else
235 find_tool_error_prefix="\$$find_tool_envvar: "
d7be4085 236 fi
41c11ce4
AD
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"
3710dd02 241 eval "$find_tool_envvar=\$find_tool_res"
d7be4085
AD
242 eval "export $find_tool_envvar"
243}
244
9dcb193a 245# Find sha1sum, named gsha1sum on MacPorts, and shasum on Mac OS X 10.6.
86996fca 246find_tool SHA1SUM sha1sum gsha1sum shasum
d7be4085 247
3b2942e6 248# Override the default configuration, if necessary.
f0a43dd1
JD
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
a898435b
JD
256# Extra files from gnulib, which override files from other sources.
257test -z "${gnulib_extra_files}" && \
258 gnulib_extra_files="
41dfa1cb
AD
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
a898435b
JD
265 doc/INSTALL
266"
3b2942e6 267
6d8e724d
PE
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
3b2942e6
PE
274# Translate configuration into internal form.
275
1f65350a
PE
276# Parse options.
277
278for option
279do
280 case $option in
281 --help)
e3ddc1e3 282 usage
1f65350a
PE
283 exit;;
284 --gnulib-srcdir=*)
3f32a0d2 285 GNULIB_SRCDIR=${option#--gnulib-srcdir=};;
1f65350a
PE
286 --skip-po)
287 SKIP_PO=t;;
e3ddc1e3 288 --force)
bbb44d83 289 checkout_only_file=;;
46356ea4
PE
290 --copy)
291 copy=true;;
dcd39f1d
JD
292 --bootstrap-sync)
293 bootstrap_sync=true;;
294 --no-bootstrap-sync)
295 bootstrap_sync=false;;
a898435b
JD
296 --no-git)
297 use_git=false;;
1f65350a 298 *)
41c11ce4 299 die "$option: unknown option";;
1f65350a
PE
300 esac
301done
302
41c11ce4
AD
303$use_git || test -d "$GNULIB_SRCDIR" \
304 || die "Error: --no-git requires --gnulib-srcdir"
a898435b 305
bbb44d83 306if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
41c11ce4 307 die "Bootstrapping from a non-checked-out distribution is risky."
e3ddc1e3
PE
308fi
309
a565f732
AD
310# Strip blank and comment lines to leave significant entries.
311gitignore_entries() {
312 sed '/^#/d; /^$/d' "$@"
a898435b
JD
313}
314
a565f732
AD
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() {
bbb44d83
PE
320 file=$1
321 str=$2
6d8e724d 322 test -f $file || touch $file
a565f732
AD
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
bbb44d83
PE
334}
335
2f3fd8f9 336# Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
a565f732 337# insert_if_absent.
2f3fd8f9
JD
338insert_vc_ignore() {
339 vc_ignore_file="$1"
340 pattern="$2"
341 case $vc_ignore_file in
342 *.gitignore)
ee7e9e3b
JM
343 # A .gitignore entry that does not start with '/' applies
344 # recursively to subdirectories, so prepend '/' to every
2f3fd8f9 345 # .gitignore entry.
3f32a0d2 346 pattern=$(echo "$pattern" | sed s,^,/,);;
2f3fd8f9 347 esac
a565f732 348 insert_if_absent "$vc_ignore_file" "$pattern"
2f3fd8f9
JD
349}
350
bbb44d83
PE
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
41c11ce4
AD
357test $found_aux_dir = yes \
358 || die "configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
bbb44d83
PE
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
6d8e724d
PE
364 for dot_ig in x $vc_ignore; do
365 test $dot_ig = x && continue
2f3fd8f9 366 insert_vc_ignore $dot_ig $build_aux
bbb44d83
PE
367 done
368fi
369
f0a43dd1
JD
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}
1f65350a 409
f0a43dd1
JD
410get_version() {
411 app=$1
412
413 $app --version >/dev/null 2>&1 || return 1
414
415 $app --version 2>&1 |
dcd39f1d
JD
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
f0a43dd1 421
dcd39f1d
JD
422 # Remove characters after the version.
423 s/[^.a-z0-9-].*//
f0a43dd1 424
dcd39f1d
JD
425 # The first component must be digits only.
426 s/^\([0-9]*\)[a-z-].*/\1/
f0a43dd1 427
f0a43dd1
JD
428 #the following essentially does s/5.005/5.5/
429 s/\.0*\([1-9]\)/.\1/g
430 p
431 q'
e10a80ee
PE
432}
433
f0a43dd1
JD
434check_versions() {
435 ret=0
436
437 while read app req_ver; do
86996fca
PE
438 # We only need libtoolize from the libtool package.
439 if test "$app" = libtool; then
440 app=libtoolize
441 fi
a898435b
JD
442 # Exempt git if --no-git is in effect.
443 if test "$app" = git; then
444 $use_git || continue
445 fi
f0a43dd1 446 # Honor $APP variables ($TAR, $AUTOCONF, etc.)
3f32a0d2 447 appvar=$(echo $app | LC_ALL=C tr '[a-z]-' '[A-Z]_')
f0a43dd1 448 test "$appvar" = TAR && appvar=AMTAR
ee7e9e3b
JM
449 case $appvar in
450 GZIP) ;; # Do not use $GZIP: it contains gzip options.
451 *) eval "app=\${$appvar-$app}" ;;
452 esac
b2c4c25d
AD
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)
3f32a0d2 462 app=${app%-ng}
b2c4c25d 463 ($app --version | grep '(GNU automake-ng)') >/dev/null 2>&1 || {
41c11ce4 464 warn_ "Error: '$app' not found or not from Automake-NG"
b2c4c25d
AD
465 ret=1
466 continue
467 } ;;
468 esac
ee7e9e3b
JM
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
41c11ce4 474 warn_ "Error: '$app' not found"
f0a43dd1
JD
475 ret=1
476 fi
ee7e9e3b
JM
477 else
478 # Require app to produce a new enough version string.
479 inst_ver=$(get_version $app)
480 if [ ! "$inst_ver" ]; then
41c11ce4 481 warn_ "Error: '$app' not found"
ee7e9e3b
JM
482 ret=1
483 else
484 latest_ver=$(sort_ver $req_ver $inst_ver | cut -d' ' -f2)
485 if [ ! "$latest_ver" = "$inst_ver" ]; then
41c11ce4
AD
486 warnf_ '%s\n' \
487 "Error: '$app' version == $inst_ver is too old" \
488 " '$app' version >= $req_ver is required"
ee7e9e3b
JM
489 ret=1
490 fi
491 fi
f0a43dd1
JD
492 fi
493 done
494
495 return $ret
496}
fee2ed87 497
f0a43dd1
JD
498print_versions() {
499 echo "Program Min_version"
500 echo "----------------------"
86996fca 501 printf %s "$buildreq"
f0a43dd1
JD
502 echo "----------------------"
503 # can't depend on column -t
504}
505
86996fca
PE
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
ee7e9e3b
JM
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.
3f32a0d2
AD
533if test -d "$local_gl_dir" \
534 && ! find "$local_gl_dir" -name '*.diff' -exec false {} +; then
ee7e9e3b
JM
535 case $buildreq in
536 *patch*) ;;
537 *) buildreq="patch -
538$buildreq" ;;
539 esac
540fi
541
f0a43dd1 542if ! printf "$buildreq" | check_versions; then
86996fca
PE
543 echo >&2
544 if test -f README-prereq; then
41c11ce4 545 die "See README-prereq for how to get the prerequisite programs"
86996fca 546 else
41c11ce4 547 die "Please install the prerequisite programs"
86996fca 548 fi
f0a43dd1
JD
549fi
550
551echo "$0: Bootstrapping from checked-out $package sources..."
552
553# See if we can use gnulib's git-merge-changelog merge driver.
41dfa1cb 554if $use_git && test -d .git && (git --version) >/dev/null 2>/dev/null ; then
fee2ed87
PB
555 if git config merge.merge-changelog.driver >/dev/null ; then
556 :
557 elif (git-merge-changelog --version) >/dev/null 2>/dev/null ; then
a898435b 558 echo "$0: initializing git-merge-changelog driver"
fee2ed87
PB
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
a898435b 562 echo "$0: consider installing git-merge-changelog from gnulib"
fee2ed87
PB
563 fi
564fi
565
f0a43dd1
JD
566
567cleanup_gnulib() {
568 status=$?
86996fca 569 rm -fr "$gnulib_path"
f0a43dd1
JD
570 exit $status
571}
572
573git_modules_config () {
574 test -f .gitmodules && git config --file .gitmodules "$@"
575}
576
41dfa1cb
AD
577if $use_git; then
578 gnulib_path=$(git_modules_config submodule.gnulib.path)
579 test -z "$gnulib_path" && gnulib_path=gnulib
580fi
86996fca 581
41dfa1cb
AD
582# Get gnulib files. Populate $GNULIB_SRCDIR, possibly updating a
583# submodule, for use in the rest of the script.
1f65350a
PE
584
585case ${GNULIB_SRCDIR--} in
586-)
41dfa1cb 587 # Note that $use_git is necessarily true in this case.
f0a43dd1 588 if git_modules_config submodule.gnulib.url >/dev/null; then
1f65350a 589 echo "$0: getting gnulib files..."
f0a43dd1
JD
590 git submodule init || exit $?
591 git submodule update || exit $?
1f65350a 592
86996fca 593 elif [ ! -d "$gnulib_path" ]; then
f0a43dd1 594 echo "$0: getting gnulib files..."
1f65350a 595
e10a80ee
PE
596 trap cleanup_gnulib 1 2 13 15
597
86996fca
PE
598 shallow=
599 git clone -h 2>&1 | grep -- --depth > /dev/null && shallow='--depth 2'
600 git clone $shallow git://git.sv.gnu.org/gnulib "$gnulib_path" ||
e10a80ee 601 cleanup_gnulib
1f65350a 602
e10a80ee 603 trap - 1 2 13 15
1f65350a 604 fi
86996fca 605 GNULIB_SRCDIR=$gnulib_path
f0a43dd1
JD
606 ;;
607*)
41dfa1cb
AD
608 # Use GNULIB_SRCDIR directly or as a reference.
609 if $use_git && test -d "$GNULIB_SRCDIR"/.git && \
f0a43dd1 610 git_modules_config submodule.gnulib.url >/dev/null; then
f0a43dd1 611 echo "$0: getting gnulib files..."
86996fca
PE
612 if git submodule -h|grep -- --reference > /dev/null; then
613 # Prefer the one-liner available in git 1.6.4 or newer.
614 git submodule update --init --reference "$GNULIB_SRCDIR" \
615 "$gnulib_path" || exit $?
616 else
617 # This fallback allows at least git 1.5.5.
618 if test -f "$gnulib_path"/gnulib-tool; then
619 # Since file already exists, assume submodule init already complete.
620 git submodule update || exit $?
621 else
622 # Older git can't clone into an empty directory.
623 rmdir "$gnulib_path" 2>/dev/null
624 git clone --reference "$GNULIB_SRCDIR" \
625 "$(git_modules_config submodule.gnulib.url)" "$gnulib_path" \
626 && git submodule init && git submodule update \
627 || exit $?
628 fi
629 fi
630 GNULIB_SRCDIR=$gnulib_path
f0a43dd1
JD
631 fi
632 ;;
1f65350a
PE
633esac
634
41dfa1cb
AD
635# $GNULIB_SRCDIR now points to the version of gnulib to use, and
636# we no longer need to use git or $gnulib_path below here.
637
dcd39f1d
JD
638if $bootstrap_sync; then
639 cmp -s "$0" "$GNULIB_SRCDIR/build-aux/bootstrap" || {
640 echo "$0: updating bootstrap and restarting..."
a565f732
AD
641 case $(sh -c 'echo "$1"' -- a) in
642 a) ignored=--;;
643 *) ignored=ignored;;
644 esac
dcd39f1d
JD
645 exec sh -c \
646 'cp "$1" "$2" && shift && exec "${CONFIG_SHELL-/bin/sh}" "$@"' \
a565f732 647 $ignored "$GNULIB_SRCDIR/build-aux/bootstrap" \
dcd39f1d
JD
648 "$0" "$@" --no-bootstrap-sync
649 }
650fi
651
284d8a13 652gnulib_tool=$GNULIB_SRCDIR/gnulib-tool
163bb369 653<$gnulib_tool || exit $?
1f65350a 654
1f65350a
PE
655# Get translations.
656
6d8e724d 657download_po_files() {
5a2baae7
PE
658 subdir=$1
659 domain=$2
a898435b 660 echo "$me: getting translations into $subdir for $domain..."
3f32a0d2 661 cmd=$(printf "$po_download_command_format" "$domain" "$subdir")
ee7e9e3b
JM
662 eval "$cmd" && return
663 # Fallback to HTTP.
3f32a0d2 664 cmd=$(printf "$po_download_command_format2" "$subdir" "$domain")
6d8e724d
PE
665 eval "$cmd"
666}
5a2baae7 667
86996fca 668# Mirror .po files to $po_dir/.reference and copy only the new
6d8e724d 669# or modified ones into $po_dir. Also update $po_dir/LINGUAS.
86996fca
PE
670# Note po files that exist locally only are left in $po_dir but will
671# not be included in LINGUAS and hence will not be distributed.
6d8e724d
PE
672update_po_files() {
673 # Directory containing primary .po files.
674 # Overwrite them only when we're sure a .po file is new.
675 po_dir=$1
676 domain=$2
677
86996fca 678 # Mirror *.po files into this dir.
6d8e724d
PE
679 # Usually contains *.s1 checksum files.
680 ref_po_dir="$po_dir/.reference"
681
682 test -d $ref_po_dir || mkdir $ref_po_dir || return
683 download_po_files $ref_po_dir $domain \
684 && ls "$ref_po_dir"/*.po 2>/dev/null |
86996fca 685 sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" || return
6d8e724d 686
3f32a0d2 687 langs=$(cd $ref_po_dir && echo *.po | sed 's/\.po//g')
f0a43dd1
JD
688 test "$langs" = '*' && langs=x
689 for po in $langs; do
690 case $po in x) continue;; esac
691 new_po="$ref_po_dir/$po.po"
692 cksum_file="$ref_po_dir/$po.s1"
693 if ! test -f "$cksum_file" ||
694 ! test -f "$po_dir/$po.po" ||
695 ! $SHA1SUM -c --status "$cksum_file" \
696 < "$new_po" > /dev/null; then
a898435b 697 echo "$me: updated $po_dir/$po.po..."
f0a43dd1
JD
698 cp "$new_po" "$po_dir/$po.po" \
699 && $SHA1SUM < "$new_po" > "$cksum_file"
700 fi
6d8e724d 701 done
5a2baae7
PE
702}
703
1f65350a
PE
704case $SKIP_PO in
705'')
bbb44d83 706 if test -d po; then
6d8e724d 707 update_po_files po $package || exit
bbb44d83 708 fi
f7ab6a50 709
3b2942e6 710 if test -d runtime-po; then
6d8e724d 711 update_po_files runtime-po $package-runtime || exit
3b2942e6 712 fi;;
1f65350a
PE
713esac
714
6d8e724d 715symlink_to_dir()
e70f46d1 716{
6d8e724d
PE
717 src=$1/$2
718 dst=${3-$2}
e70f46d1
PE
719
720 test -f "$src" && {
6d8e724d 721
86996fca
PE
722 # If the destination directory doesn't exist, create it.
723 # This is required at least for "lib/uniwidth/cjk.h".
3f32a0d2 724 dst_dir=$(dirname "$dst")
86996fca
PE
725 if ! test -d "$dst_dir"; then
726 mkdir -p "$dst_dir"
727
728 # If we've just created a directory like lib/uniwidth,
729 # tell version control system(s) it's ignorable.
730 # FIXME: for now, this does only one level
3f32a0d2 731 parent=$(dirname "$dst_dir")
86996fca
PE
732 for dot_ig in x $vc_ignore; do
733 test $dot_ig = x && continue
734 ig=$parent/$dot_ig
3f32a0d2 735 insert_vc_ignore $ig "${dst_dir##*/}"
86996fca
PE
736 done
737 fi
6d8e724d 738
46356ea4
PE
739 if $copy; then
740 {
f0a43dd1 741 test ! -h "$dst" || {
a898435b 742 echo "$me: rm -f $dst" &&
f0a43dd1
JD
743 rm -f "$dst"
744 }
46356ea4
PE
745 } &&
746 test -f "$dst" &&
747 cmp -s "$src" "$dst" || {
a898435b 748 echo "$me: cp -fp $src $dst" &&
f0a43dd1 749 cp -fp "$src" "$dst"
46356ea4
PE
750 }
751 else
ee7e9e3b
JM
752 # Leave any existing symlink alone, if it already points to the source,
753 # so that broken build tools that care about symlink times
754 # aren't confused into doing unnecessary builds. Conversely, if the
755 # existing symlink's time stamp is older than the source, make it afresh,
756 # so that broken tools aren't confused into skipping needed builds. See
757 # <http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00326.html>.
46356ea4 758 test -h "$dst" &&
3f32a0d2
AD
759 src_ls=$(ls -diL "$src" 2>/dev/null) && set $src_ls && src_i=$1 &&
760 dst_ls=$(ls -diL "$dst" 2>/dev/null) && set $dst_ls && dst_i=$1 &&
ee7e9e3b 761 test "$src_i" = "$dst_i" &&
3f32a0d2 762 both_ls=$(ls -dt "$src" "$dst") &&
ee7e9e3b 763 test "X$both_ls" = "X$dst$nl$src" || {
f0a43dd1
JD
764 dot_dots=
765 case $src in
766 /*) ;;
767 *)
768 case /$dst/ in
769 *//* | */../* | */./* | /*/*/*/*/*/)
41c11ce4
AD
770 die "invalid symlink calculation: $src -> $dst";;
771 /*/*/*/*/) dot_dots=../../../;;
772 /*/*/*/) dot_dots=../../;;
773 /*/*/) dot_dots=../;;
f0a43dd1
JD
774 esac;;
775 esac
776
a898435b 777 echo "$me: ln -fs $dot_dots$src $dst" &&
f0a43dd1 778 ln -fs "$dot_dots$src" "$dst"
46356ea4
PE
779 }
780 fi
e70f46d1
PE
781 }
782}
783
3f32a0d2
AD
784version_controlled_file() {
785 parent=$1
786 file=$2
787 if test -d .git; then
788 git rm -n "$file" > /dev/null 2>&1
789 elif test -d .svn; then
790 svn log -r HEAD "$file" > /dev/null 2>&1
791 elif test -d CVS; then
792 grep -F "/${file##*/}/" "$parent/CVS/Entries" 2>/dev/null |
793 grep '^/[^/]*/[0-9]' > /dev/null
794 else
41c11ce4 795 warn_ "no version control for $file?"
3f32a0d2
AD
796 false
797 fi
798}
799
ee7e9e3b
JM
800# NOTE: we have to be careful to run both autopoint and libtoolize
801# before gnulib-tool, since gnulib-tool is likely to provide newer
802# versions of files "installed" by these two programs.
803# Then, *after* gnulib-tool (see below), we have to be careful to
804# run autoreconf in such a way that it does not run either of these
805# two just-pre-run programs.
1f65350a 806
ee7e9e3b
JM
807# Import from gettext.
808with_gettext=yes
809grep '^[ ]*AM_GNU_GETTEXT_VERSION(' configure.ac >/dev/null || \
810 with_gettext=no
1f65350a 811
3f32a0d2 812if test $with_gettext = yes || test $use_libtool = 1; then
ee7e9e3b 813
3f32a0d2
AD
814 tempbase=.bootstrap$$
815 trap "rm -f $tempbase.0 $tempbase.1" 1 2 13 15
1f65350a 816
3f32a0d2
AD
817 > $tempbase.0 > $tempbase.1 &&
818 find . ! -type d -print | sort > $tempbase.0 || exit
819
820 if test $with_gettext = yes; then
821 # Released autopoint has the tendency to install macros that have been
822 # obsoleted in current gnulib, so run this before gnulib-tool.
823 echo "$0: $AUTOPOINT --force"
824 $AUTOPOINT --force || exit
10f429ef 825 fi
3f32a0d2
AD
826
827 # Autoreconf runs aclocal before libtoolize, which causes spurious
828 # warnings if the initial aclocal is confused by the libtoolized
829 # (or worse out-of-date) macro directory.
830 # libtoolize 1.9b added the --install option; but we support back
831 # to libtoolize 1.5.22, where the install action was default.
832 if test $use_libtool = 1; then
833 install=
834 case $($LIBTOOLIZE --help) in
835 *--install*) install=--install ;;
836 esac
837 echo "running: $LIBTOOLIZE $install --copy"
838 $LIBTOOLIZE $install --copy
839 fi
840
841 find . ! -type d -print | sort >$tempbase.1
842 old_IFS=$IFS
843 IFS=$nl
844 for file in $(comm -13 $tempbase.0 $tempbase.1); do
845 IFS=$old_IFS
846 parent=${file%/*}
847 version_controlled_file "$parent" "$file" || {
848 for dot_ig in x $vc_ignore; do
849 test $dot_ig = x && continue
850 ig=$parent/$dot_ig
851 insert_vc_ignore "$ig" "${file##*/}"
852 done
853 }
854 done
855 IFS=$old_IFS
856
857 rm -f $tempbase.0 $tempbase.1
858 trap - 1 2 13 15
859fi
10f429ef 860
3b2942e6
PE
861# Import from gnulib.
862
863gnulib_tool_options="\
864 --import\
865 --no-changelog\
ee7e9e3b
JM
866 --aux-dir $build_aux\
867 --doc-base $doc_base\
bbb44d83 868 --lib $gnulib_name\
ee7e9e3b
JM
869 --m4-base $m4_base/\
870 --source-base $source_base/\
871 --tests-base $tests_base\
6d8e724d 872 --local-dir $local_gl_dir\
f0a43dd1 873 $gnulib_tool_option_extras\
3b2942e6 874"
86996fca
PE
875if test $use_libtool = 1; then
876 case "$gnulib_tool_options " in
877 *' --libtool '*) ;;
878 *) gnulib_tool_options="$gnulib_tool_options --libtool" ;;
879 esac
880fi
3b2942e6
PE
881echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
882$gnulib_tool $gnulib_tool_options --import $gnulib_modules &&
3b2942e6
PE
883
884for file in $gnulib_files; do
9dcb193a 885 symlink_to_dir "$GNULIB_SRCDIR" $file \
41c11ce4 886 || die "failed to symlink $file"
3b2942e6 887done
1f65350a 888
163bb369 889bootstrap_post_import_hook \
41c11ce4 890 || die "bootstrap_post_import_hook failed"
f0a43dd1
JD
891
892# Remove any dangling symlink matching "*.m4" or "*.[ch]" in some
893# gnulib-populated directories. Such .m4 files would cause aclocal to fail.
894# The following requires GNU find 4.2.3 or newer. Considering the usual
895# portability constraints of this script, that may seem a very demanding
896# requirement, but it should be ok. Ignore any failure, which is fine,
897# since this is only a convenience to help developers avoid the relatively
898# unusual case in which a symlinked-to .m4 file is git-removed from gnulib
899# between successive runs of this script.
900find "$m4_base" "$source_base" \
901 -depth \( -name '*.m4' -o -name '*.[ch]' \) \
902 -type l -xtype l -delete > /dev/null 2>&1
3b2942e6 903
a565f732
AD
904# Invoke autoreconf with --force --install to ensure upgrades of tools
905# such as ylwrap.
906AUTORECONFFLAGS="--verbose --install --force -I $m4_base $ACLOCAL_FLAGS"
907
ee7e9e3b
JM
908# Some systems (RHEL 5) are using ancient autotools, for which the
909# --no-recursive option had not been invented. Detect that lack and
910# omit the option when it's not supported. FIXME in 2017: remove this
911# hack when RHEL 5 autotools are updated, or when they become irrelevant.
ee7e9e3b 912case $($AUTORECONF --help) in
a565f732 913 *--no-recursive*) AUTORECONFFLAGS="$AUTORECONFFLAGS --no-recursive";;
ee7e9e3b 914esac
62a9592d 915
ee7e9e3b 916# Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
a565f732
AD
917echo "running: AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS"
918AUTOPOINT=true LIBTOOLIZE=true $AUTORECONF $AUTORECONFFLAGS \
41c11ce4 919 || die "autoreconf failed"
62a9592d 920
3b2942e6 921# Get some extra files from gnulib, overriding existing files.
3b2942e6 922for file in $gnulib_extra_files; do
3b2942e6 923 case $file in
e70f46d1 924 */INSTALL) dst=INSTALL;;
3f32a0d2 925 build-aux/*) dst=$build_aux/${file#build-aux/};;
e70f46d1 926 *) dst=$file;;
3b2942e6 927 esac
9dcb193a 928 symlink_to_dir "$GNULIB_SRCDIR" $file $dst \
41c11ce4 929 || die "failed to symlink $file"
3b2942e6 930done
fbca8023 931
bbb44d83
PE
932if test $with_gettext = yes; then
933 # Create gettext configuration.
934 echo "$0: Creating po/Makevars from po/Makevars.template ..."
935 rm -f po/Makevars
3b2942e6 936 sed '
bbb44d83 937 /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
86996fca
PE
938 /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
939 /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
bbb44d83
PE
940 /^XGETTEXT_OPTIONS *=/{
941 s/$/ \\/
942 a\
f0a43dd1 943 '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
bbb44d83 944 }
41c11ce4
AD
945 ' po/Makevars.template >po/Makevars \
946 || die 'cannot generate po/Makevars'
3b2942e6 947
b2c4c25d
AD
948 # If the 'gettext' module is in use, grab the latest Makefile.in.in.
949 # If only the 'gettext-h' module is in use, assume autopoint already
950 # put the correct version of this file into place.
951 case $gnulib_modules in
952 *gettext-h*) ;;
953 *gettext*)
41c11ce4
AD
954 cp $GNULIB_SRCDIR/build-aux/po/Makefile.in.in po/Makefile.in.in \
955 || die "cannot create po/Makefile.in.in"
b2c4c25d
AD
956 ;;
957 esac
8ef26c2a 958
bbb44d83
PE
959 if test -d runtime-po; then
960 # Similarly for runtime-po/Makevars, but not quite the same.
961 rm -f runtime-po/Makevars
962 sed '
963 /^DOMAIN *=.*/s/=.*/= '"$package"'-runtime/
964 /^subdir *=.*/s/=.*/= runtime-po/
965 /^MSGID_BUGS_ADDRESS *=/s/=.*/= bug-'"$package"'@gnu.org/
966 /^XGETTEXT_OPTIONS *=/{
f0a43dd1
JD
967 s/$/ \\/
968 a\
969 '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
bbb44d83 970 }
41c11ce4
AD
971 ' po/Makevars.template >runtime-po/Makevars \
972 || die 'cannot generate runtime-po/Makevars'
bbb44d83
PE
973
974 # Copy identical files from po to runtime-po.
975 (cd po && cp -p Makefile.in.in *-quot *.header *.sed *.sin ../runtime-po)
976 fi
3b2942e6 977fi
1f65350a 978
f0a43dd1
JD
979bootstrap_epilogue
980
1f65350a 981echo "$0: done. Now you can run './configure'."
f0a43dd1 982
86996fca
PE
983# Local variables:
984# eval: (add-hook 'write-file-hooks 'time-stamp)
985# time-stamp-start: "scriptversion="
986# time-stamp-format: "%:y-%02m-%02d.%02H"
987# time-stamp-time-zone: "UTC"
988# time-stamp-end: "; # UTC"
f0a43dd1 989# End: