X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot;h=be9291d979f3fac98a0b9690c528b61250f05aaf;hp=aa906266f6b819cbe03aff91c56e0b0e8bdc035d;hb=0b9530245a33b8206ca38b9de6dfb01e056fd8dc;hpb=bdd44abe63ce79b32e3570e846afabad2024cd09 diff --git a/boot b/boot index aa90626..be9291d 100644 --- a/boot +++ b/boot @@ -1,15 +1,28 @@ -#!/bin/sh - +#! /bin/sh set -e -autoreconf +# Check that we have all core packages. +for dir in `cat libraries/core-packages`; do + if test ! -d libraries/$dir; then + echo "Looks like you're missing libraries/$dir, maybe you haven't done './darcs-all get'?" >&2 + exit 1 + fi +done -for lib in libraries/*; do - if test -e $lib/configure.ac - then - cd $lib - autoreconf - cd ../.. - fi +# We don't recurse into the library packages with autoreconf anymore, so we +# have to do this manually. To avoid a strict dependency on autoreconf, we +# are careful to call autoreconf only when configure does not exist yet or the +# corresponding configure.ac is newer. This would be dead easy if every shell +# supported the "-nt" option for "test", but this is not the case. The only +# portable solution seems to be via find's "-newer" option or to basically give +# up and replace find with perl: :-P +# +# perl -e 'print "configure.ac\n" if -M "configure.ac" < -M "configure"' +for dir in . libraries/*; do + if test -f $dir/configure.ac; then + ( cd $dir ; { test ! -f configure || test -n "`find configure.ac -newer configure`"; } && autoreconf ) + fi done +# Alas, darcs doesn't handle file permissions, so fix a few of them. +chmod +x boot darcs-all push-all