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