X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot;h=d586348de75670f94f02dbd94e95003b6b1700e6;hp=a21691ff21d87bc5337f92290e21bf6f41126eff;hb=de75026f5a48d3d052135a973ab4dff76c5b20f5;hpb=b1f0cd397d4cc0e9bf178bbe2774a9b7c1595b34 diff --git a/boot b/boot index a21691f..d586348 100644 --- a/boot +++ b/boot @@ -1,31 +1,49 @@ #! /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/aclocal.m4 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 -L configure.ac -newer configure`" || (test -f aclocal.m4 && test -n "`find -L aclocal.m4 -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 + +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=`basename ${cabals%.cabal}` + echo "${f}_PACKAGE = ${pkg}" >> $f/ghc.mk + echo "\$(eval \$(call build-package,${f},dist-install,1))" >> $f/ghc.mk + rm -f $f/GNUmakefile + echo "Creating $f/GNUmakefile" + echo "dir = ${f}" >> $f/GNUmakefile + echo "TOP = ../.." >> $f/GNUmakefile + echo "include \$(TOP)/mk/sub-makefile.mk" >> $f/GNUmakefile + fi done