X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=boot;h=aa3b82d04a914b1b985022d64d0dbe8c2fa046f1;hb=27225b0c9f799a251c96242f502e8cfd6bf76d7c;hp=6683ad569825267e3f488b77a5d9c3cf5e905bc9;hpb=0e17d4498cc037d5c18d33fcc4a4885778d266c0;p=ghc-hetmet.git diff --git a/boot b/boot index 6683ad5..aa3b82d 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: $?"; @@ -21,13 +36,13 @@ while () { if (/^#/) { # Comment; do nothing } - elsif (/^([a-zA-Z0-9\/.-]+) *([^ ]+) *[^ ]+ *[^ ]+$/) { + elsif (/^([a-zA-Z0-9\/.-]+) +([^ ]+) +[^ ]+ +[^ ]+ +[^ ]+$/) { $dir = $1; $tag = $2; # 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