X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=boot;h=54209af7d64400cdfcab627fef0893f298866682;hb=edeee10702955ca3c53444f2f328b4cce0ab3e32;hp=39e8cd12d5d6b3dd27cc730d89d1c84409d5b82e;hpb=20c633b040a53166431744a8b0a0f8bf440835d6;p=ghc-hetmet.git diff --git a/boot b/boot index 39e8cd1..54209af 100644 --- a/boot +++ b/boot @@ -8,6 +8,7 @@ use Cwd; system("/usr/bin/perl", "-w", "boot-pkgs") == 0 or die "Running boot-pkgs failed: $?"; +my $tag; my $dir; my $curdir; @@ -20,21 +21,22 @@ while () { if (/^#/) { # Comment; do nothing } - elsif (/^([a-zA-Z0-9\/.-]+) *[^ ]+ *[^ ]+$/) { + elsif (/^([a-zA-Z0-9\/.-]+) +([^ ]+) +[^ ]+ +[^ ]+ +[^ ]+$/) { $dir = $1; + $tag = $2; - # 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 has a LICENSE file - # instead. - if (! -f "$dir/LICENSE") { - print STDERR "Error: $dir/LICENSE doesn't exist.\n"; - die "Maybe you haven't done './darcs-all get'?"; - } - } - elsif (/^([a-zA-Z0-9\/.-]+) *[^ ]+ *[^ ]+ *[^ ]+$/) { - # These are lines which refer to optional repositories, so their + # If $tag is not "-" then it is an optional repository, so its # absence isn't an error. + if ($tag eq "-") { + # 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 + # has a LICENSE file instead. + if (! -f "$dir/LICENSE") { + print STDERR "Error: $dir/LICENSE doesn't exist.\n"; + die "Maybe you haven't done './darcs-all get'?"; + } + } } else { die "Bad line in packages file: $_"; @@ -54,7 +56,7 @@ foreach $dir (".", glob("libraries/*/")) { } # Alas, darcs doesn't handle file permissions, so fix a few of them. -for my $file ("boot", "darcs-all", "push-all", "validate") { +for my $file ("boot", "darcs-all", "validate") { chmod 0755, $file if -f $file or die "Can't chmod 0755 $file: $!"; }