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