X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot;h=644c6d9ea251a8bde192f9ab449ad3c6b66344d6;hp=014efff4dbf30f1655bc234f09b85e45e6d8e9ff;hb=f96194794bf099020706c3816d1a5678b40addbb;hpb=63cddb36f1dd2e3e41274f494873a62921d3f787 diff --git a/boot b/boot index 014efff..644c6d9 100644 --- a/boot +++ b/boot @@ -1,20 +1,39 @@ -#!/bin/sh - +#! /bin/sh set -e -chmod +x rts/gmp/configure -chmod +x darcs-all - -./darcs-all ${1+"$@"} get +# Create libraries/*/{ghc.mk,GNUmakefile} +sh boot-pkgs -autoreconf +# Check that we have all boot packages. +for dir in `grep "^[^# ][^ ]* *[^ ][^ ]* *[^ ][^ ]*$" packages | sed "s/ .*//"` +do + # We would like to just check for an _darcs directory here, but in + # an lndir tree we avoid making _darcs directories, so it doesn't + # exist. We therefore require that every repo has a LICENSE file + # instead. + if test ! -f $dir/LICENSE + then + echo "Error: $dir/LICENSE doesn't exist." >&2 + echo "Maybe you haven't done './darcs-all get'?" >&2 + exit 1 + fi +done -for lib in libraries/*; do - if test -e $lib/configure.ac +# autoreconf everything that needs it. +for dir in . libraries/* +do + if test -f $dir/configure.ac then - cd $lib - autoreconf - cd ../.. + echo "Booting $dir" + ( cd $dir && autoreconf ) fi done +# 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 + chmod +x $f + fi +done