X-Git-Url: http://git.ozo.com/?a=blobdiff_plain;f=scripts%2Fdownload.pl;h=543dcc1879e5288e838b811a007044a4baae12c8;hb=50d7e6ec294061923d350a7eb3b340b23b00d513;hp=859e6c8ba6b988d392ab2d51f1fd0f9692221392;hpb=c0dd042eef20687748d356b055e0ba569dd14b23;p=openwrt-10.03%2F.git diff --git a/scripts/download.pl b/scripts/download.pl index 859e6c8ba..543dcc187 100755 --- a/scripts/download.pl +++ b/scripts/download.pl @@ -8,16 +8,41 @@ use strict; use warnings; +use File::Basename; my $target = shift @ARGV; my $filename = shift @ARGV; my $md5sum = shift @ARGV; +my $scriptdir = dirname($0); my @mirrors; my $ok; @ARGV > 0 or die "Syntax: $0 [ ...]\n"; +sub localmirrors { + my @mlist; + open LM, "$scriptdir/localmirrors" and do { + while () { + chomp $_; + push @mlist, $_; + } + close LM; + }; + open CONFIG, "<".$ENV{'TOPDIR'}."/.config" and do { + while () { + /^CONFIG_LOCALMIRROR="(.+)"/ and do { + chomp; + push @mlist, $1; + }; + } + close CONFIG; + }; + + + return @mlist; +} + sub which($) { my $prog = shift; my $res = `which $prog`; @@ -78,6 +103,8 @@ sub cleanup unlink "$target/$filename.md5sum"; } +@mirrors = localmirrors(); + foreach my $mirror (@ARGV) { if ($mirror =~ /^\@SF\/(.+)$/) { # give sourceforge a few more tries, because it redirects to different mirrors