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