mirror of
git://scm.dxcluster.org/scm/spider
synced 2024-09-21 15:57:12 +00:00
127 lines
2.5 KiB
Perl
127 lines
2.5 KiB
Perl
#
|
|
# do an VHFSpot table
|
|
#
|
|
# Copyright (c) 2001 Dirk Koopman G1TLH
|
|
#
|
|
# $Id$
|
|
#
|
|
|
|
my ($self, $line) = @_;
|
|
my @f = split /\s+/, $line;
|
|
my @calls;
|
|
my $days = 31;
|
|
my @dxcc;
|
|
my $limit = 100;
|
|
my %list;
|
|
my $i;
|
|
my $now;
|
|
my @pref;
|
|
my @out;
|
|
my $date;
|
|
my $all;
|
|
|
|
#$DB::single = 1;
|
|
|
|
while (@f) {
|
|
my $f = shift @f;
|
|
|
|
if ($f =~ /^\d+$/ && $f < 366) { # no of days
|
|
$days = $f;
|
|
next;
|
|
}
|
|
if (my $utime = Date::Parse::str2time($f)) { # is it a parseable date?
|
|
$utime += 3600;
|
|
$now = Julian::Day->new($utime);
|
|
$date = cldate($utime);
|
|
next;
|
|
}
|
|
$f = uc $f;
|
|
if (is_callsign($f)) {
|
|
push @dxcc, [$f, 0];
|
|
push @pref, $f;
|
|
} else {
|
|
if ($f eq 'ALL' ) {
|
|
$all++;
|
|
push @pref, $f;
|
|
next;
|
|
}
|
|
if (my @ciz = Prefix::to_ciz('nc', $f)) {
|
|
push @dxcc, map {[$_, 2]} @ciz;
|
|
push @pref, $f;
|
|
} else {
|
|
push @out, $self->msg('e27', $f);
|
|
}
|
|
}
|
|
}
|
|
|
|
# return error messages if any
|
|
return (1, @out) if @out;
|
|
|
|
# default prefixes
|
|
unless (@pref) { # no prefix or callsign, use default prefix
|
|
push @dxcc, [$_, 2] for @main::my_cc;
|
|
push @pref, $main::mycall;
|
|
}
|
|
|
|
# default date
|
|
unless ($now) {
|
|
$now = Julian::Day->new(time); #no starting date
|
|
$date = cldate(time);
|
|
}
|
|
|
|
# generate the spot list
|
|
for ($i = 0; $i < $days; $i++) {
|
|
my $fh = $Spot::statp->open($now); # get the next file
|
|
unless ($fh) {
|
|
Spot::genstats($now);
|
|
$fh = $Spot::statp->open($now);
|
|
}
|
|
while (<$fh>) {
|
|
chomp;
|
|
my @l = split /\^/;
|
|
next if $l[0] eq 'TOTALS';
|
|
next unless $all || grep $l[$_->[1]] eq $_->[0], @dxcc;
|
|
my $ref = $list{$l[0]} || [0,0,0,0,0,0,0,0,0,0];
|
|
my $j = 1;
|
|
foreach my $item (@l[14..16, 18..23]) {
|
|
$ref->[$j] += $item;
|
|
$ref->[0] += $item;
|
|
$j++;
|
|
}
|
|
$list{$l[0]} = $ref if $ref->[0];
|
|
}
|
|
$now = $now->sub(1);
|
|
}
|
|
|
|
my @tot;
|
|
my $nocalls;
|
|
|
|
my $l = join ',', @pref;
|
|
push @out, $self->msg('statvhft', $l, $date, $days);
|
|
#push @out, $self->msg('statvhft', join(',', @dxcc), cldate(time));
|
|
push @out, sprintf "%10s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|", qw(Callsign Tot 6m 4m 2m 70cm 23cm 13cm 9cm 6cm 3cm);
|
|
|
|
for (sort {$list{$b}->[0] <=> $list{$a}->[0] || $a cmp $b} keys %list) {
|
|
my $ref = $list{$_};
|
|
$nocalls++;
|
|
my @list = (sprintf "%10s", $_);
|
|
foreach my $j (0..9) {
|
|
my $r = $ref->[$j];
|
|
if ($r) {
|
|
$tot[$j] += $r;
|
|
$r = sprintf("%4d", $r);
|
|
} else {
|
|
$r = ' ';
|
|
}
|
|
push @list, $r;
|
|
}
|
|
push @out, join('|', @list, "");
|
|
last if $limit && $nocalls >= $limit;
|
|
}
|
|
|
|
$nocalls = sprintf "%10s", "$nocalls calls";
|
|
@tot = map {$_ ? sprintf("%4d", $_) : ' ' } @tot;
|
|
push @out, join('|', $nocalls, @tot, "");
|
|
|
|
return (1, @out);
|