X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=boot;h=f47bdf649134f1c2fea3e73f77f72c0c42618872;hp=54209af7d64400cdfcab627fef0893f298866682;hb=64557b454b1a184ef9ee177806a05b75c79c0eb6;hpb=4ac17e1a625698df98fdc807118c0bb81aefdeb1 diff --git a/boot b/boot index 54209af..f47bdf6 100644 --- a/boot +++ b/boot @@ -4,6 +4,21 @@ use strict; use Cwd; +my %required_tag; + +$required_tag{"-"} = 1; + +while ($#ARGV ne -1) { + my $arg = shift @ARGV; + + if ($arg =~ /^--required-tag=(.*)/) { + $required_tag{$1} = 1; + } + else { + die "Bad arg: $arg"; + } +} + # Create libraries/*/{ghc.mk,GNUmakefile} system("/usr/bin/perl", "-w", "boot-pkgs") == 0 or die "Running boot-pkgs failed: $?"; @@ -27,7 +42,7 @@ while () { # If $tag is not "-" then it is an optional repository, so its # absence isn't an error. - if ($tag eq "-") { + if (defined($required_tag{$tag})) { # 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 @@ -57,6 +72,8 @@ foreach $dir (".", glob("libraries/*/")) { # Alas, darcs doesn't handle file permissions, so fix a few of them. for my $file ("boot", "darcs-all", "validate") { - chmod 0755, $file if -f $file - or die "Can't chmod 0755 $file: $!"; + if (-f $file) { + chmod 0755, $file + or die "Can't chmod 0755 $file: $!"; + } }