X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=boot;h=18a083e02e92b2d38add0a2107cf72c77680f45a;hb=c933c909cbc122e63a055afed55969234422521a;hp=d983d2f560146634fe10a2ca8f5967959c198762;hpb=9a7ac3c44ff2f03a2395f246a3ebaf975426f0ff;p=ghc-hetmet.git diff --git a/boot b/boot index d983d2f..18a083e 100644 --- a/boot +++ b/boot @@ -1,25 +1,33 @@ -#!/bin/sh - +#! /bin/sh set -e -for d in `cat libraries/core-packages` +# Check that we have all boot packages. +for dir in `grep "^[^# ][^ ]* *[^ ][^ ]* *[^ ][^ ]*$" packages | sed "s/ .*//"` do - if test ! -d libraries/$d + if test ! -d $dir then - echo "Looks like you're missing libraries/$d," - echo "maybe you haven't done 'sh darcs-all get'?" + echo "Looks like you're missing $dir." >&2 + echo "Maybe you haven't done './darcs-all get'?" >&2 exit 1 fi done -autoreconf +# 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 -for lib in libraries/*; do - if test -e $lib/configure.ac +# Alas, darcs doesn't handle file permissions, so fix a few of them. +for f in boot darcs-all push-all validate +do + if test -f $f then - cd $lib - autoreconf - cd ../.. + chmod +x $f fi done