X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=darcs-all;h=69445d04d38f80d33753f14915f4ae109b400343;hp=cdef628e19389783f66390a10a84734984a16f1d;hb=5dd95594637dbb6b03bc675c032a1bf430c4b0bf;hpb=62f4d7ce402af37c87d5fffb2163d47af26f6e74 diff --git a/darcs-all b/darcs-all index cdef628..69445d0 100644 --- a/darcs-all +++ b/darcs-all @@ -112,6 +112,14 @@ sub warning { } } +sub download { + my ($from, $to) = @_; + + my @cmd = ("wget", $from, "-O", $to); + message "== running @cmd"; + system @cmd; +} + sub darcs { message "== running darcs @_"; system ("darcs", @_) == 0 @@ -132,7 +140,7 @@ sub darcsall { @repos = ; close IN; - REPO: foreach (@repos) { + foreach (@repos) { chomp; if (/^([^# ]+) +(?:([^ ]+) +)?([^ ]+) +([^ ]+)$/) { $localpath = $1; @@ -164,6 +172,10 @@ sub darcsall { die "Bad line: $_"; } } + + if ($_[0] eq "pull" || $_[0] eq "pul") { + &sync_tarballs(); + } } sub darcsget { @@ -215,6 +227,63 @@ sub darcsget { die "Bad line: $_"; } } + + &sync_tarballs(); +} + +sub sync_tarballs { + my $localpath; + my $localdirectory; + my $localfilename; + my $actualpath; + my $actualfilename; + my $remotepath; + my $path; + my @tarballs; + my %localtarballs; + my ($repo_base, $checked_out_tree) = getrepo(); + + message "== Syncing tarballs"; + + open IN, "< tarballs" or die "Can't open packages file"; + @tarballs = ; + close IN; + + foreach (@tarballs) { + chomp; + if (m@^([^# ]+)/([^#/ ]+) +([^ ]+)$@) { + $localdirectory = $1; + $localfilename = $2; + $remotepath = $3; + $localpath = "$localdirectory/$localfilename"; + + $localtarballs{$localdirectory}{$localfilename} = 1; + + if (! -e $localpath) { + if ($checked_out_tree) { + $path = "$repo_base/$localpath"; + } + else { + $path = "$repo_base/$remotepath"; + } + &download($path, $localpath); + } + } + elsif (! /^(#.*)?$/) { + die "Bad line: $_"; + } + } + + foreach $localdirectory (keys %localtarballs) { + FILE: foreach $actualpath (glob "$localdirectory/*.tar.gz $localdirectory/*.tar.bz2") { + $actualfilename = $actualpath; + $actualfilename =~ s#.*/##; + if (! defined($localtarballs{$localdirectory}{$actualfilename})) { + message "== Deleting $actualpath"; + unlink $actualpath; + } + } + } } sub main {