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