X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=boot;h=0cdee985f69dfc7a3a4a41dd6b207691456d24a2;hb=ed4beb8bc5e49d84e38b047c2dfc14eb22c74607;hp=1889e8cac8c65504c5ef52f5c7431d3f8ed238df;hpb=e97891e69706e84761c6bcac783526f9dafe7f2e;p=ghc-hetmet.git diff --git a/boot b/boot index 1889e8c..0cdee98 100644 --- a/boot +++ b/boot @@ -1,30 +1,68 @@ #! /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 `grep "^[^# ][^ ]* *[^ ][^ ]* *[^ ][^ ]*$" packages | sed "s/ .*//"` +do + 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 -# 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. -for f in boot darcs-all push-all validate; do - test -f $f && chmod +x $f +for f in boot darcs-all push-all validate +do + if test -f $f + then + chmod +x $f + fi +done + +libraries= + +for f in libraries/*; do + pkgs=$f/ghc-packages + if test -f $pkgs; then + for p in `cat $pkgs`; do + libraries="$libraries $f/$p" + done + else + libraries="$libraries $f" + fi +done + +for f in $libraries; do + dir=`basename $f` + cabals=`echo $f/*.cabal` + if test -f $cabals; then + echo "Creating $f/ghc.mk" + rm -f $f/ghc.mk + pkg=`echo "$cabals" | sed -e 's#.*/##' -e 's#\.cabal$##'` + if test -f $f/ghc-stage; then + stage=`cat $f/ghc-stage` + else + stage=1 + fi + top=`echo $f | sed "s/[^/]*/../g"` + echo "${f}_PACKAGE = ${pkg}" >> $f/ghc.mk + echo "\$(eval \$(call build-package,${f},dist-install,${stage}))" >> $f/ghc.mk + rm -f $f/GNUmakefile + echo "Creating $f/GNUmakefile" + echo "dir = ${f}" >> $f/GNUmakefile + echo "TOP = ${top}" >> $f/GNUmakefile + echo "include \$(TOP)/mk/sub-makefile.mk" >> $f/GNUmakefile + fi done