diff options
author | Pascal Rigaux <pixel@mandriva.com> | 2003-09-01 11:59:23 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 2003-09-01 11:59:23 +0000 |
commit | 17f6eb7c68a62594784e0cb802e5fe3af9d866e3 (patch) | |
tree | 7d7d48c369a9a19129e956331f5cf353ae2a0b29 /tools | |
parent | b4332bfb638829f316611b1de25917dbe1c99b4c (diff) | |
download | drakx-17f6eb7c68a62594784e0cb802e5fe3af9d866e3.tar drakx-17f6eb7c68a62594784e0cb802e5fe3af9d866e3.tar.gz drakx-17f6eb7c68a62594784e0cb802e5fe3af9d866e3.tar.bz2 drakx-17f6eb7c68a62594784e0cb802e5fe3af9d866e3.tar.xz drakx-17f6eb7c68a62594784e0cb802e5fe3af9d866e3.zip |
update to new timezone.pm and adapt to new web page listing ntp servers
Diffstat (limited to 'tools')
-rw-r--r-- | tools/ntp_servers.pl | 51 |
1 files changed, 28 insertions, 23 deletions
diff --git a/tools/ntp_servers.pl b/tools/ntp_servers.pl index 62640557c..d0a4b6cc2 100644 --- a/tools/ntp_servers.pl +++ b/tools/ntp_servers.pl @@ -1,7 +1,7 @@ #!/usr/bin/perl -open F, "links -dump http://www.eecis.udel.edu/~mills/ntp/clock1.htm|"; -open G, "links -dump http://www.eecis.udel.edu/~mills/ntp/clock2.htm|"; +#open F, "/usr/bin/lynx -dump http://www.eecis.udel.edu/~mills/ntp/clock1a.html|"; +open(my $G, "/usr/bin/lynx -dump http://www.eecis.udel.edu/~mills/ntp/clock2a.html|"); # Chris Kloiber <ckloiber@redhat.com> writes: # > It's not considered polite to use the Stratum 1 servers for purposes that @@ -9,45 +9,50 @@ open G, "links -dump http://www.eecis.udel.edu/~mills/ntp/clock2.htm|"; # > the few nanoseconds difference. #parse() while <F>; -parse() while <G>; +parse($_) while <$G>; +my @all; +my ($l, $nb); sub parse { - /\0/ .. 1 or return; - if (/^ [\d\0]\d\./) { - push @all, { name => $name, indic => $indic, %l } if $name; - %l = (); + local ($_) = @_; + /Active Servers/ .. /Discontinued Service/ or return; + if (/^\s+\d+\. ([A-Z ]*[A-Z]);?\s+([.\w-]+)/) { + push @all, $l = { name => $2, indic => $1 }; $nb = 0; } else { s/^\s*//; s/\s*$//; - if ($nb == 2) { - s/US CA:/US CA/; - ($indic, $name) = /([A-Z ]*[A-Z])\s+([.\w-]+)/ or die "bad line $_"; + my ($field, $val) = /^(.*):\s*(.*)/; + if ($field =~ /policy/i) { + $field = "policy"; + $val = lc join(' ', split(' ', $val)); + $val =~ s/glad to receive a note//; + $val =~ s/(but )?please send (a )?message to notify//; + $val =~ s/an email note is appreciated//; + $val =~ s/please send a message with the//; + $val =~ s/no need to notify//; + $val =~ s/[(), .;]*$//; + $val = "open access" if $val eq "public"; + warn "$val ($all[-1]{name})\n" if $val ne 'open access'; + } elsif ($field =~ /^Contact|Synchroni[sz]ation|Location|Geographic\s+Coordinates|Service\s+Area|Note$/i) { } else { - s/^(.*):\s*/$field = $1; ''/e; - $field = lc $field; - if ($field =~ /policy/) { - $field = "policy"; - $_ = lc $_; - s/glad to receive a note//; - s/[(), ]*$//; - $_ = "open access" if $_ eq "public"; - } - $l{$field} .= ($l{$field} && ' ') . $_; +# warn "bad line ($field) $_\n"; + return; } + $l->{$field} .= ($l->{$field} && ' ') . $val; } $nb++; } use Data::Dumper; -#print Dumper(\@all); +#warn Dumper(\@all); foreach (grep { $_->{policy} eq 'open access' } @all) { - ($country, $state) = split ' ', $_->{indic}; + my ($country, $state) = split ' ', $_->{indic}; $country = ucfirst(lc $country_codes{$country}); $country .= " $state" if $state; - print "$country (", lc($_->{name}), ")\n"; + printf "\t'%s' => '%s',\n", lc($_->{name}), $country; } BEGIN { |