X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot;h=d554b037bd0714e3c4db702ca55c1b4dcaf65274;hp=be9291d979f3fac98a0b9690c528b61250f05aaf;hb=f5edc6b0871a0debbc9a64f4cdb95c0dc35e5b16;hpb=2d2393de269d8c5c9043a047e6ca652f64358610 diff --git a/boot b/boot index be9291d..d554b03 100644 --- a/boot +++ b/boot @@ -1,28 +1,30 @@ #! /bin/sh set -e -# 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 +# Check that we have all boot packages. +for dir in `cat libraries/boot-packages` +do + if test ! -d libraries/$dir + then + echo "Looks like you're missing libraries/$dir." >&2 + echo "Maybe you haven't done './darcs-all get'?" >&2 + exit 1 + fi done -# 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 +# autoreconf everything that needs it. +for dir in . libraries/* +do + if test -f $dir/configure.ac + then + echo "Booting $dir" + ( cd $dir && autoreconf ) + fi done # Alas, darcs doesn't handle file permissions, so fix a few of them. -chmod +x boot darcs-all push-all +for f in boot darcs-all push-all validate +do + test -f $f && chmod +x $f +done +