summaryrefslogtreecommitdiff
path: root/jpl/get_jdk/get_jdk.pl
diff options
context:
space:
mode:
authorGurusamy Sarathy <gsar@cpan.org>1998-11-30 01:30:44 +0000
committerGurusamy Sarathy <gsar@cpan.org>1998-11-30 01:30:44 +0000
commit93e0cdbd0f68fd8d8d75c3510f7893c1ebaa26ae (patch)
treea6c84af1c502bc73fa1730324995f4e1fcb207b3 /jpl/get_jdk/get_jdk.pl
parenta8710ca18eb34a984d0dfab8503448f77a53b379 (diff)
parent57dea26d80db9a1b455ef89cc843930fe18b0369 (diff)
downloadperl-93e0cdbd0f68fd8d8d75c3510f7893c1ebaa26ae.tar.gz
branch jpl from perlext to perl
p4raw-id: //depot/perl@2410
Diffstat (limited to 'jpl/get_jdk/get_jdk.pl')
-rwxr-xr-xjpl/get_jdk/get_jdk.pl71
1 files changed, 71 insertions, 0 deletions
diff --git a/jpl/get_jdk/get_jdk.pl b/jpl/get_jdk/get_jdk.pl
new file mode 100755
index 0000000000..d6d399d669
--- /dev/null
+++ b/jpl/get_jdk/get_jdk.pl
@@ -0,0 +1,71 @@
+#!/usr/bin/perl -w
+
+# Based on an ftp client found in the LWP Cookbook and
+# revised by Nathan V. Patwardhan <nvp@ora.com>.
+
+# Copyright 1997 O'Reilly and Associates
+# This package may be copied under the same terms as Perl itself.
+#
+# Code appears in the Unix version of the Perl Resource Kit
+
+use LWP::UserAgent;
+use URI::URL;
+
+my $ua = new LWP::UserAgent;
+
+# check to see if a JDK port exists for the OS. i'd say
+# that we should use solaris by default, but a 9meg tarfile
+# is a hard pill to swallow if it won't work for somebody. :-)
+my $os_type = $^O; my $URL = lookup_jdk_port($os_type);
+die("No JDK port found. Contact your vendor for details. Exiting.\n")
+ if $URL eq '';
+
+print "A JDK port for your OS has been found.\nContacting: ".$URL."\n";
+
+# Now, parse the URL using URI::URL
+my($jdk_file) = (url($URL)->crack)[5];
+$jdk_file =~ /(.+)\/(.+)/; $jdk_file = $2;
+
+print "Attempting to download: $jdk_file\n";
+
+my $expected_length;
+my $bytes_received = 0;
+
+open(OUT, ">".$jdk_file) or die("Can't open $jdk_file: $!");
+$ua->request(HTTP::Request->new('GET', $URL),
+ sub {
+ my($chunk, $res) = @_;
+
+ $bytes_received += length($chunk);
+ unless (defined $expected_length) {
+ $expected_length = $res->content_length || 0;
+ }
+ if ($expected_length) {
+ printf STDERR "%d%% - ",
+ 100 * $bytes_received / $expected_length;
+ }
+ print STDERR "$bytes_received bytes received\n";
+
+ print OUT $chunk;
+ }
+);
+close(OUT);
+
+sub lookup_jdk_port {
+ my($port_os) = @_;
+ my $jdk_hosts = 'jdk_hosts';
+ my %HOSTS = ();
+
+ open(CFG, $jdk_hosts) or die("hosts error: $!");
+ while(<CFG>) {
+ chop;
+ ($os, $host) = split(/\s*=>\s*/, $_);
+ next unless $os eq $port_os;
+ push(@HOSTS, $host);
+ }
+ close(CFG);
+
+ return "" unless @HOSTS;
+ return $HOSTS[rand @HOSTS]; # Pick one at random.
+}
+