NEWS: cite --start-pos
[wget] / bootstrap
1 #! /bin/sh
2 # Print a version string.
3 scriptversion=2012-07-19.14; # UTC
4
5 # Bootstrap this package from checked-out sources.
6
7 # Copyright (C) 2003-2012 Free Software Foundation, Inc.
8
9 # This program is free software: you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation, either version 3 of the License, or
12 # (at your option) any later version.
13
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.
18
19 # You should have received a copy of the GNU General Public License
20 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
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.
31
32 nl='
33 '
34
35 # Ensure file names are sorted consistently across platforms.
36 LC_ALL=C
37 export LC_ALL
38
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
43 local_gl_dir=gl
44
45 me=$0
46
47 usage() {
48   cat <<EOF
49 Usage: $me [OPTION]...
50 Bootstrap this package from the checked-out sources.
51
52 Options:
53  --gnulib-srcdir=DIRNAME  specify the local directory where gnulib
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
57                           them again.  Defaults to \$GNULIB_SRCDIR
58  --bootstrap-sync         if this bootstrap script is not identical to
59                           the version in the local gnulib sources,
60                           update this script, and then restart it with
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
70 If the file $me.conf exists in the same directory as this script, its
71 contents are read as shell variables to configure the bootstrap.
72
73 For build prerequisites, environment variables like \$AUTOCONF and \$AMTAR
74 are honored.
75
76 Running without arguments will suffice in most cases.
77 EOF
78 }
79
80 # warnf_ FORMAT-STRING ARG1...
81 warnf_ ()
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...
95 warn_ ()
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...
105 die() { warn_ "$@"; exit 1; }
106
107 # Configuration.
108
109 # Name of the Makefile.am
110 gnulib_mk=gnulib.mk
111
112 # List of gnulib modules needed.
113 gnulib_modules=
114
115 # Any gnulib files needed that are not in modules.
116 gnulib_files=
117
118 : ${AUTOPOINT=autopoint}
119 : ${AUTORECONF=autoreconf}
120
121 # A function to be called right after gnulib-tool is run.
122 # Override it via your own definition in bootstrap.conf.
123 bootstrap_post_import_hook() { :; }
124
125 # A function to be called after everything else in this script.
126 # Override it via your own definition in bootstrap.conf.
127 bootstrap_epilogue() { :; }
128
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.
134 po_download_command_format=\
135 "rsync --delete --exclude '*.s1' -Lrtvz \
136  'translationproject.org::tp/latest/%s/' '%s'"
137
138 # Fallback for downloading .po files (if rsync fails).
139 po_download_command_format2=\
140 "wget --mirror -nd -q -np -A.po -P '%s' \
141  http://translationproject.org/latest/%s/"
142
143 extract_package_name='
144   /^AC_INIT(/{
145      /.*,.*,.*, */{
146        s///
147        s/[][]//g
148        s/)$//
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 '
160 package=$(sed -n "$extract_package_name" configure.ac) \
161   || die 'cannot find package name in configure.ac'
162 gnulib_name=lib$package
163
164 build_aux=build-aux
165 source_base=lib
166 m4_base=m4
167 doc_base=doc
168 tests_base=tests
169 gnulib_extra_files=''
170
171 # Additional gnulib-tool options to use.  Use "\newline" to break lines.
172 gnulib_tool_option_extras=
173
174 # Other locale categories that need message catalogs.
175 EXTRA_LOCALE_CATEGORIES=
176
177 # Additional xgettext options to use.  Use "\\\newline" to break lines.
178 XGETTEXT_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
184 # Package bug report address and copyright holder for gettext files
185 COPYRIGHT_HOLDER='Free Software Foundation, Inc.'
186 MSGID_BUGS_ADDRESS=bug-$package@gnu.org
187
188 # Files we don't want to import.
189 excluded_files=
190
191 # File that should exist in the top directory of a checked out hierarchy,
192 # but not in a distribution tarball.
193 checkout_only_file=README-hacking
194
195 # Whether to use copies instead of symlinks.
196 copy=false
197
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.
202 vc_ignore=auto
203
204 # Set this to true in bootstrap.conf to enable --bootstrap-sync by
205 # default.
206 bootstrap_sync=false
207
208 # Use git to update gnulib sources
209 use_git=true
210
211 # find_tool ENVVAR NAMES...
212 # -------------------------
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.,
215 # supports --version).  If found, set ENVVAR to the program name,
216 # die otherwise.
217 #
218 # FIXME: code duplication, see also gnu-web-doc-update.
219 find_tool ()
220 {
221   find_tool_envvar=$1
222   shift
223   find_tool_names=$@
224   eval "find_tool_res=\$$find_tool_envvar"
225   if test x"$find_tool_res" = x; then
226     for i
227     do
228       if ($i --version </dev/null) >/dev/null 2>&1; then
229        find_tool_res=$i
230        break
231       fi
232     done
233   else
234     find_tool_error_prefix="\$$find_tool_envvar: "
235   fi
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"
240   eval "$find_tool_envvar=\$find_tool_res"
241   eval "export $find_tool_envvar"
242 }
243
244 # Find sha1sum, named gsha1sum on MacPorts, and shasum on Mac OS X 10.6.
245 find_tool SHA1SUM sha1sum gsha1sum shasum
246
247 # Override the default configuration, if necessary.
248 # Make sure that bootstrap.conf is sourced from the current directory
249 # if we were invoked as "sh bootstrap".
250 case "$0" in
251   */*) test -r "$0.conf" && . "$0.conf" ;;
252   *) test -r "$0.conf" && . ./"$0.conf" ;;
253 esac
254
255 # Extra files from gnulib, which override files from other sources.
256 test -z "${gnulib_extra_files}" && \
257   gnulib_extra_files="
258         $build_aux/install-sh
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 "
266
267 if test "$vc_ignore" = auto; then
268   vc_ignore=
269   test -d .git && vc_ignore=.gitignore
270   test -d CVS && vc_ignore="$vc_ignore .cvsignore"
271 fi
272
273 # Translate configuration into internal form.
274
275 # Parse options.
276
277 for option
278 do
279   case $option in
280   --help)
281     usage
282     exit;;
283   --gnulib-srcdir=*)
284     GNULIB_SRCDIR=${option#--gnulib-srcdir=};;
285   --skip-po)
286     SKIP_PO=t;;
287   --force)
288     checkout_only_file=;;
289   --copy)
290     copy=true;;
291   --bootstrap-sync)
292     bootstrap_sync=true;;
293   --no-bootstrap-sync)
294     bootstrap_sync=false;;
295   --no-git)
296     use_git=false;;
297   *)
298     die "$option: unknown option";;
299   esac
300 done
301
302 $use_git || test -d "$GNULIB_SRCDIR" \
303   || die "Error: --no-git requires --gnulib-srcdir"
304
305 if test -n "$checkout_only_file" && test ! -r "$checkout_only_file"; then
306   die "Bootstrapping from a non-checked-out distribution is risky."
307 fi
308
309 # Ensure that lines starting with ! sort last, per gitignore conventions
310 # for whitelisting exceptions after a more generic blacklist pattern.
311 sort_patterns() {
312   sort -u "$@" | sed '/^!/ {
313     H
314     d
315   }
316   $ {
317     P
318     x
319     s/^\n//
320   }' | sed '/^$/d'
321 }
322
323 # If $STR is not already on a line by itself in $FILE, insert it,
324 # sorting the new contents of the file and replacing $FILE with the result.
325 insert_sorted_if_absent() {
326   file=$1
327   str=$2
328   test -f $file || touch $file
329   echo "$str" | sort_patterns - $file | cmp -s - $file > /dev/null \
330     || { echo "$str" | sort_patterns - $file > $file.bak \
331       && mv $file.bak $file; } \
332     || die "insert_sorted_if_absent $file $str: failed"
333 }
334
335 # Adjust $PATTERN for $VC_IGNORE_FILE and insert it with
336 # insert_sorted_if_absent.
337 insert_vc_ignore() {
338   vc_ignore_file="$1"
339   pattern="$2"
340   case $vc_ignore_file in
341   *.gitignore)
342     # A .gitignore entry that does not start with '/' applies
343     # recursively to subdirectories, so prepend '/' to every
344     # .gitignore entry.
345     pattern=$(echo "$pattern" | sed s,^,/,);;
346   esac
347   insert_sorted_if_absent "$vc_ignore_file" "$pattern"
348 }
349
350 # Die if there is no AC_CONFIG_AUX_DIR($build_aux) line in configure.ac.
351 found_aux_dir=no
352 grep '^[         ]*AC_CONFIG_AUX_DIR(\['"$build_aux"'\])' configure.ac \
353     >/dev/null && found_aux_dir=yes
354 grep '^[         ]*AC_CONFIG_AUX_DIR('"$build_aux"')' configure.ac \
355     >/dev/null && found_aux_dir=yes
356 test $found_aux_dir = yes \
357   || die "configure.ac lacks 'AC_CONFIG_AUX_DIR([$build_aux])'; add it"
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.
361 if test ! -d $build_aux; then
362   mkdir $build_aux
363   for dot_ig in x $vc_ignore; do
364     test $dot_ig = x && continue
365     insert_vc_ignore $dot_ig $build_aux
366   done
367 fi
368
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.
375 sort_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 }
408
409 get_version() {
410   app=$1
411
412   $app --version >/dev/null 2>&1 || return 1
413
414   $app --version 2>&1 |
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
420
421           # Remove characters after the version.
422           s/[^.a-z0-9-].*//
423
424           # The first component must be digits only.
425           s/^\([0-9]*\)[a-z-].*/\1/
426
427           #the following essentially does s/5.005/5.5/
428           s/\.0*\([1-9]\)/.\1/g
429           p
430           q'
431 }
432
433 check_versions() {
434   ret=0
435
436   while read app req_ver; do
437     # We only need libtoolize from the libtool package.
438     if test "$app" = libtool; then
439       app=libtoolize
440     fi
441     # Exempt git if --no-git is in effect.
442     if test "$app" = git; then
443       $use_git || continue
444     fi
445     # Honor $APP variables ($TAR, $AUTOCONF, etc.)
446     appvar=$(echo $app | LC_ALL=C tr '[a-z]-' '[A-Z]_')
447     test "$appvar" = TAR && appvar=AMTAR
448     case $appvar in
449         GZIP) ;; # Do not use $GZIP:  it contains gzip options.
450         *) eval "app=\${$appvar-$app}" ;;
451     esac
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)
461         app=${app%-ng}
462         ($app --version | grep '(GNU automake-ng)') >/dev/null 2>&1 || {
463           warn_ "Error: '$app' not found or not from Automake-NG"
464           ret=1
465           continue
466         } ;;
467     esac
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
473         warn_ "Error: '$app' not found"
474         ret=1
475       fi
476     else
477       # Require app to produce a new enough version string.
478       inst_ver=$(get_version $app)
479       if [ ! "$inst_ver" ]; then
480         warn_ "Error: '$app' not found"
481         ret=1
482       else
483         latest_ver=$(sort_ver $req_ver $inst_ver | cut -d' ' -f2)
484         if [ ! "$latest_ver" = "$inst_ver" ]; then
485           warnf_ '%s\n'                                        \
486               "Error: '$app' version == $inst_ver is too old"  \
487               "       '$app' version >= $req_ver is required"
488           ret=1
489         fi
490       fi
491     fi
492   done
493
494   return $ret
495 }
496
497 print_versions() {
498   echo "Program    Min_version"
499   echo "----------------------"
500   printf %s "$buildreq"
501   echo "----------------------"
502   # can't depend on column -t
503 }
504
505 use_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).
509 grep '^[         ]*A[CM]_PROG_LIBTOOL' configure.ac >/dev/null \
510   && use_libtool=1
511 grep '^[         ]*LT_INIT' configure.ac >/dev/null \
512   && use_libtool=1
513 if test $use_libtool = 1; then
514   find_tool LIBTOOLIZE glibtoolize libtoolize
515 fi
516
517 # gnulib-tool requires at least automake and autoconf.
518 # If either is not listed, add it (with minimum version) as a prerequisite.
519 case $buildreq in
520   *automake*) ;;
521   *) buildreq="automake 1.9
522 $buildreq" ;;
523 esac
524 case $buildreq in
525   *autoconf*) ;;
526   *) buildreq="autoconf 2.59
527 $buildreq" ;;
528 esac
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.
532 if test -d "$local_gl_dir" \
533     && ! find "$local_gl_dir" -name '*.diff' -exec false {} +; then
534   case $buildreq in
535     *patch*) ;;
536     *) buildreq="patch -
537 $buildreq" ;;
538   esac
539 fi
540
541 if ! printf "$buildreq" | check_versions; then
542   echo >&2
543   if test -f README-prereq; then
544     die "See README-prereq for how to get the prerequisite programs"
545   else
546     die "Please install the prerequisite programs"
547   fi
548 fi
549
550 echo "$0: Bootstrapping from checked-out $package sources..."
551
552 # See if we can use gnulib's git-merge-changelog merge driver.
553 if 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
557     echo "$0: initializing git-merge-changelog driver"
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
561     echo "$0: consider installing git-merge-changelog from gnulib"
562   fi
563 fi
564
565
566 cleanup_gnulib() {
567   status=$?
568   rm -fr "$gnulib_path"
569   exit $status
570 }
571
572 git_modules_config () {
573   test -f .gitmodules && git config --file .gitmodules "$@"
574 }
575
576 gnulib_path=$(git_modules_config submodule.gnulib.path)
577 test -z "$gnulib_path" && gnulib_path=gnulib
578
579 # Get gnulib files.
580
581 case ${GNULIB_SRCDIR--} in
582 -)
583   if git_modules_config submodule.gnulib.url >/dev/null; then
584     echo "$0: getting gnulib files..."
585     git submodule init || exit $?
586     git submodule update || exit $?
587
588   elif [ ! -d "$gnulib_path" ]; then
589     echo "$0: getting gnulib files..."
590
591     trap cleanup_gnulib 1 2 13 15
592
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" ||
596       cleanup_gnulib
597
598     trap - 1 2 13 15
599   fi
600   GNULIB_SRCDIR=$gnulib_path
601   ;;
602 *)
603   # Use GNULIB_SRCDIR as a reference.
604   if test -d "$GNULIB_SRCDIR"/.git && \
605         git_modules_config submodule.gnulib.url >/dev/null; then
606     echo "$0: getting gnulib files..."
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
626   fi
627   ;;
628 esac
629
630 if $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   }
638 fi
639
640 gnulib_tool=$GNULIB_SRCDIR/gnulib-tool
641 <$gnulib_tool || exit $?
642
643 # Get translations.
644
645 download_po_files() {
646   subdir=$1
647   domain=$2
648   echo "$me: getting translations into $subdir for $domain..."
649   cmd=$(printf "$po_download_command_format" "$domain" "$subdir")
650   eval "$cmd" && return
651   # Fallback to HTTP.
652   cmd=$(printf "$po_download_command_format2" "$subdir" "$domain")
653   eval "$cmd"
654 }
655
656 # Mirror .po files to $po_dir/.reference and copy only the new
657 # or modified ones into $po_dir.  Also update $po_dir/LINGUAS.
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.
660 update_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
666   # Mirror *.po files into this dir.
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 |
673       sed 's|.*/||; s|\.po$||' > "$po_dir/LINGUAS" || return
674
675   langs=$(cd $ref_po_dir && echo *.po | sed 's/\.po//g')
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
685       echo "$me: updated $po_dir/$po.po..."
686       cp "$new_po" "$po_dir/$po.po" \
687           && $SHA1SUM < "$new_po" > "$cksum_file"
688     fi
689   done
690 }
691
692 case $SKIP_PO in
693 '')
694   if test -d po; then
695     update_po_files po $package || exit
696   fi
697
698   if test -d runtime-po; then
699     update_po_files runtime-po $package-runtime || exit
700   fi;;
701 esac
702
703 symlink_to_dir()
704 {
705   src=$1/$2
706   dst=${3-$2}
707
708   test -f "$src" && {
709
710     # If the destination directory doesn't exist, create it.
711     # This is required at least for "lib/uniwidth/cjk.h".
712     dst_dir=$(dirname "$dst")
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
719       parent=$(dirname "$dst_dir")
720       for dot_ig in x $vc_ignore; do
721         test $dot_ig = x && continue
722         ig=$parent/$dot_ig
723         insert_vc_ignore $ig "${dst_dir##*/}"
724       done
725     fi
726
727     if $copy; then
728       {
729         test ! -h "$dst" || {
730           echo "$me: rm -f $dst" &&
731           rm -f "$dst"
732         }
733       } &&
734       test -f "$dst" &&
735       cmp -s "$src" "$dst" || {
736         echo "$me: cp -fp $src $dst" &&
737         cp -fp "$src" "$dst"
738       }
739     else
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>.
746       test -h "$dst" &&
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 &&
749       test "$src_i" = "$dst_i" &&
750       both_ls=$(ls -dt "$src" "$dst") &&
751       test "X$both_ls" = "X$dst$nl$src" || {
752         dot_dots=
753         case $src in
754         /*) ;;
755         *)
756           case /$dst/ in
757           *//* | */../* | */./* | /*/*/*/*/*/)
758              die "invalid symlink calculation: $src -> $dst";;
759           /*/*/*/*/)    dot_dots=../../../;;
760           /*/*/*/)      dot_dots=../../;;
761           /*/*/)        dot_dots=../;;
762           esac;;
763         esac
764
765         echo "$me: ln -fs $dot_dots$src $dst" &&
766         ln -fs "$dot_dots$src" "$dst"
767       }
768     fi
769   }
770 }
771
772 version_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
783     warn_ "no version control for $file?"
784     false
785   fi
786 }
787
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.
794
795 # Import from gettext.
796 with_gettext=yes
797 grep '^[         ]*AM_GNU_GETTEXT_VERSION(' configure.ac >/dev/null || \
798     with_gettext=no
799
800 if test $with_gettext = yes || test $use_libtool = 1; then
801
802   tempbase=.bootstrap$$
803   trap "rm -f $tempbase.0 $tempbase.1" 1 2 13 15
804
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
813   fi
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
847 fi
848
849 # Import from gnulib.
850
851 gnulib_tool_options="\
852  --import\
853  --no-changelog\
854  --aux-dir $build_aux\
855  --doc-base $doc_base\
856  --lib $gnulib_name\
857  --m4-base $m4_base/\
858  --source-base $source_base/\
859  --tests-base $tests_base\
860  --local-dir $local_gl_dir\
861  $gnulib_tool_option_extras\
862 "
863 if test $use_libtool = 1; then
864   case "$gnulib_tool_options " in
865     *' --libtool '*) ;;
866     *) gnulib_tool_options="$gnulib_tool_options --libtool" ;;
867   esac
868 fi
869 echo "$0: $gnulib_tool $gnulib_tool_options --import ..."
870 $gnulib_tool $gnulib_tool_options --import $gnulib_modules &&
871
872 for file in $gnulib_files; do
873   symlink_to_dir "$GNULIB_SRCDIR" $file \
874     || die "failed to symlink $file"
875 done
876
877 bootstrap_post_import_hook \
878   || die "bootstrap_post_import_hook failed"
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.
888 find "$m4_base" "$source_base" \
889   -depth \( -name '*.m4' -o -name '*.[ch]' \) \
890   -type l -xtype l -delete > /dev/null 2>&1
891
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.
896 no_recursive=
897 case $($AUTORECONF --help) in
898   *--no-recursive*) no_recursive=--no-recursive;;
899 esac
900
901 # Tell autoreconf not to invoke autopoint or libtoolize; they were run above.
902 echo "running: AUTOPOINT=true LIBTOOLIZE=true " \
903     "$AUTORECONF --verbose --install $no_recursive -I $m4_base $ACLOCAL_FLAGS"
904 AUTOPOINT=true LIBTOOLIZE=true \
905     $AUTORECONF --verbose --install $no_recursive -I $m4_base $ACLOCAL_FLAGS \
906   || die "autoreconf failed"
907
908 # Get some extra files from gnulib, overriding existing files.
909 for file in $gnulib_extra_files; do
910   case $file in
911   */INSTALL) dst=INSTALL;;
912   build-aux/*) dst=$build_aux/${file#build-aux/};;
913   *) dst=$file;;
914   esac
915   symlink_to_dir "$GNULIB_SRCDIR" $file $dst \
916     || die "failed to symlink $file"
917 done
918
919 if test $with_gettext = yes; then
920   # Create gettext configuration.
921   echo "$0: Creating po/Makevars from po/Makevars.template ..."
922   rm -f po/Makevars
923   sed '
924     /^EXTRA_LOCALE_CATEGORIES *=/s/=.*/= '"$EXTRA_LOCALE_CATEGORIES"'/
925     /^COPYRIGHT_HOLDER *=/s/=.*/= '"$COPYRIGHT_HOLDER"'/
926     /^MSGID_BUGS_ADDRESS *=/s|=.*|= '"$MSGID_BUGS_ADDRESS"'|
927     /^XGETTEXT_OPTIONS *=/{
928       s/$/ \\/
929       a\
930           '"$XGETTEXT_OPTIONS"' $${end_of_xgettext_options+}
931     }
932   ' po/Makevars.template >po/Makevars \
933     || die 'cannot generate po/Makevars'
934
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*)
941     cp $GNULIB_SRCDIR/build-aux/po/Makefile.in.in po/Makefile.in.in \
942       || die "cannot create po/Makefile.in.in"
943     ;;
944   esac
945
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 *=/{
954         s/$/ \\/
955         a\
956             '"$XGETTEXT_OPTIONS_RUNTIME"' $${end_of_xgettext_options+}
957       }
958     ' po/Makevars.template >runtime-po/Makevars \
959     || die 'cannot generate runtime-po/Makevars'
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
964 fi
965
966 bootstrap_epilogue
967
968 echo "$0: done.  Now you can run './configure'."
969
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"
976 # End: