X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/3373d2dda9b90caa1e5f1cd59d1b3c00179338ad..e0fbcb5a25886aa035eb0a3a3048720f344ce582:/scripts/download.pl diff --git a/scripts/download.pl b/scripts/download.pl index 633a4f6f7..042b1cce7 100755 --- a/scripts/download.pl +++ b/scripts/download.pl @@ -24,7 +24,7 @@ sub localmirrors { open LM, "$scriptdir/localmirrors" and do { while () { chomp $_; - push @mlist, $_; + push @mlist, $_ if $_; } close LM; }; @@ -135,14 +135,20 @@ foreach my $mirror (@ARGV) { push @mirrors, "ftp://ftp.leo.org/pub/comp/os/unix/gnu/$1"; push @mirrors, "ftp://ftp.digex.net/pub/gnu/$1"; } elsif ($mirror =~ /^\@KERNEL\/(.+)$/) { - push @mirrors, "ftp://ftp.geo.kernel.org/pub/$1"; - push @mirrors, "http://ftp.geo.kernel.org/pub/$1"; - push @mirrors, "ftp://ftp.all.kernel.org/pub/$1"; - push @mirrors, "http://ftp.all.kernel.org/pub/$1"; - push @mirrors, "ftp://ftp.de.kernel.org/pub/$1"; - push @mirrors, "http://ftp.de.kernel.org/pub/$1"; - push @mirrors, "ftp://ftp.fr.kernel.org/pub/$1"; - push @mirrors, "http://ftp.fr.kernel.org/pub/$1"; + my @extra = ( $1 ); + if ($filename =~ /linux-\d+\.\d+(?:\.\d+)?-rc/) { + push @extra, "$extra[0]/testing"; + } elsif ($filename =~ /linux-(\d+\.\d+(?:\.\d+)?)/) { + push @extra, "$extra[0]/longterm/v$1"; + } + foreach my $dir (@extra) { + push @mirrors, "ftp://ftp.all.kernel.org/pub/$dir"; + push @mirrors, "http://ftp.all.kernel.org/pub/$dir"; + push @mirrors, "ftp://ftp.de.kernel.org/pub/$dir"; + push @mirrors, "http://ftp.de.kernel.org/pub/$dir"; + push @mirrors, "ftp://ftp.fr.kernel.org/pub/$dir"; + push @mirrors, "http://ftp.fr.kernel.org/pub/$dir"; + } } elsif ($mirror =~ /^\@GNOME\/(.+)$/) { push @mirrors, "http://ftp.gnome.org/pub/GNOME/sources/$1"; push @mirrors, "http://ftp.unina.it/pub/linux/GNOME/sources/$1";