X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot-pkgs;h=45520888086a08e2ba4125241c2c79703fc30036;hp=599e1b18e677971af499e0decaf9bbd1f209305f;hb=b00e3a6c0a82a8af3238d677f798d812cd7fd49f;hpb=6ddc8fd8b4952a23d1016dbad4263b89b63c5ae3 diff --git a/boot-pkgs b/boot-pkgs index 599e1b1..4552088 100644 --- a/boot-pkgs +++ b/boot-pkgs @@ -34,11 +34,14 @@ for $tarball (@tarballs) { &rmtree("libraries/$package") or die "Can't remove libraries/$package: $!"; } - mkdir "libraries/$package"; + mkdir "libraries/$package" + or die "Can't create libraries/$package: $!"; system ("sh", "-c", "cd 'libraries/$package' && { cat ../../$tarball | gzip -d | tar xf - ; } && mv */* .") == 0 or die "Failed to unpack $package"; - open STAMP, "> $stamp"; - close STAMP; + open STAMP, "> $stamp" + or die "Failed to open stamp file: $!"; + close STAMP + or die "Failed to close stamp file: $!"; } } } @@ -47,7 +50,8 @@ for $package (glob "libraries/*/") { $package =~ s/\/$//; my $pkgs = "$package/ghc-packages"; if (-f $pkgs) { - open PKGS, "< $pkgs"; + open PKGS, "< $pkgs" + or die "Failed to open $pkgs: $!"; while () { chomp; if (/.+/) { @@ -69,36 +73,34 @@ for $package (@library_dirs) { if ($#cabals eq 0) { my $cabal = $cabals[0]; my $pkg; - my $stage; my $top; if (-f $cabal) { $pkg = $cabal; $pkg =~ s#.*/##; $pkg =~ s/\.cabal$//; - if (-f "$package/ghc-stage") { - open STAGE, "< $package/ghc-stage"; - $stage = int(); - close STAGE; - } - else { - $stage = 1; - } $top = $package; $top =~ s#[^/]+#..#g; + $dir = $package; + $dir =~ s#^libraries/##g; print "Creating $package/ghc.mk\n"; - open GHCMK, "> $package/ghc.mk"; + open GHCMK, "> $package/ghc.mk" + or die "Opening $package/ghc.mk failed: $!"; print GHCMK "${package}_PACKAGE = ${pkg}\n"; print GHCMK "${package}_dist-install_GROUP = libraries\n"; - print GHCMK "\$(eval \$(call build-package,${package},dist-install,${stage}))\n"; - close GHCMK; + print GHCMK "\$(eval \$(call build-package,${package},dist-install,\$(if \$(filter ${dir},\$(STAGE2_PACKAGES)),2,1)))\n"; + close GHCMK + or die "Closing $package/ghc.mk failed: $!"; print "Creating $package/GNUmakefile\n"; - open GNUMAKEFILE, "> $package/GNUmakefile"; + open GNUMAKEFILE, "> $package/GNUmakefile" + or die "Opening $package/GNUmakefile failed: $!"; print GNUMAKEFILE "dir = ${package}\n"; print GNUMAKEFILE "TOP = ${top}\n"; print GNUMAKEFILE "include \$(TOP)/mk/sub-makefile.mk\n"; - close GNUMAKEFILE; + print GNUMAKEFILE "FAST_MAKE_OPTS += stage=0\n"; + close GNUMAKEFILE + or die "Closing $package/GNUmakefile failed: $!"; } } }