add stats commands
authorminima <minima>
Sun, 9 Sep 2001 15:49:38 +0000 (15:49 +0000)
committerminima <minima>
Sun, 9 Sep 2001 15:49:38 +0000 (15:49 +0000)
cmd/show/dxstats.pl [new file with mode: 0644]
cmd/show/hfstats.pl [new file with mode: 0644]
cmd/show/hftable.pl [new file with mode: 0644]
cmd/show/vhfstats.pl [new file with mode: 0644]
cmd/show/vhftable.pl [new file with mode: 0644]

diff --git a/cmd/show/dxstats.pl b/cmd/show/dxstats.pl
new file mode 100644 (file)
index 0000000..0b60e7a
--- /dev/null
@@ -0,0 +1,48 @@
+#
+# Show total DXStats per day
+#
+# Copyright (c) 2001 Dirk Koopman G1TLH
+#
+# $Id$
+#
+
+my ($self, $line) = @_;
+my @f = split /\s+/, $line;
+my @calls;
+my $days = 31;
+my @dxcc;
+
+my $now = Julian::Day->new(time())->sub(31);
+my $i;
+my @in;
+
+# 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 unless $l[0] eq 'TOTALS';
+               next unless $l[1];
+               $l[0] = $now; 
+               push @in, \@l; 
+               last;
+       }
+       $now = $now->add(1);
+}
+
+my @out;
+my $tot;
+
+push @out, $self->msg('statdx');
+foreach my $ref (@in) {
+       push @out, sprintf "%12s: %7d", $ref->[0]->as_string, $ref->[1];
+       $tot += $ref->[1];
+}
+push @out, sprintf "%12s: %7d", "Total", $tot;
+
+return (1, @out);
diff --git a/cmd/show/hfstats.pl b/cmd/show/hfstats.pl
new file mode 100644 (file)
index 0000000..63a3b56
--- /dev/null
@@ -0,0 +1,51 @@
+#
+# Show total HF DX Spot Stats per day
+#
+# Copyright (c) 2001 Dirk Koopman G1TLH
+#
+# $Id$
+#
+
+my ($self, $line) = @_;
+my @f = split /\s+/, $line;
+my $days = 31;
+my $now = Julian::Day->new(time())->sub(31);
+my $i;
+my @in;
+
+# 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 unless $l[0] eq 'TOTALS';
+               next unless $l[1];
+               $l[0] = $now; 
+               push @in, \@l; 
+               last;
+       }
+       $now = $now->add(1);
+}
+
+my @out;
+my @tot;
+
+push @out, $self->msg('stathf');
+push @out, sprintf "%11s|%6s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|", qw(Date Total 160m 80m 40m 30m 20m 17m 15m 12m 10m);
+foreach my $ref (@in) {
+       my $linetot = 0;
+       foreach my $j (3..11) {
+               $tot[$j] += $ref->[$j];
+               $tot[0] += $ref->[$j];
+               $linetot += $ref->[$j];
+       }
+       push @out, join '|', sprintf("%11s|%6d", $ref->[0]->as_string, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[3..11], "";
+}
+push @out, join '|', sprintf("%11s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[3..11], "";
+
+return (1, @out);
diff --git a/cmd/show/hftable.pl b/cmd/show/hftable.pl
new file mode 100644 (file)
index 0000000..2b83994
--- /dev/null
@@ -0,0 +1,74 @@
+#
+# do an HFSpot table 
+#
+# Copyright (c) 2001 Dirk Koopman G1TLH
+#
+# $Id$
+#
+
+my ($self, $line) = @_;
+my @f = split /\s+/, $line;
+my @calls;
+my $days = 31;
+my @dxcc;
+
+push @dxcc, (61..67) if $self->dxcc >= 61 && $self->dxcc < 67;
+push @dxcc, $self->dxcc unless @dxcc;
+
+my $now = Julian::Day->new(time())->sub(1);
+my %list;
+my $i;
+
+# 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 grep $l[2] eq $_, @dxcc;
+               my $ref = $list{$l[0]} || [0,0,0,0,0,0,0,0,0,0];
+               my $j = 1;
+               foreach my $item (@l[3..11]) {
+                       $ref->[$j] += $item;
+                       $ref->[0] += $item;
+                       $j++;
+               }
+               $list{$l[0]} = $ref if $ref->[0];
+       }
+       $now = $now->sub(1);
+}
+
+my @out;
+my @tot;
+my $nocalls;
+
+push @out, $self->msg('stathft', join(',', @dxcc));
+push @out, sprintf "%10s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|%4s|", qw(Callsign Tot 160m 80m 40m 30m 20m 17m 15m 12m 10m);
+
+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..10) {
+               my $r = $ref->[$j];
+               if ($r) {
+                       $tot[$j] += $r;
+                       $r = sprintf("%4d", $r);
+               } else {
+                       $r = '    ';
+               }
+               push @list, $r;
+       }
+       push @out, join('|', @list);
+}
+
+$nocalls = sprintf "%10s", "$nocalls calls";
+@tot = map {$_ ?  sprintf("%4d", $_) : '    ' } @tot;
+push @out, join('|', $nocalls, @tot, "");
+
+return (1, @out);
diff --git a/cmd/show/vhfstats.pl b/cmd/show/vhfstats.pl
new file mode 100644 (file)
index 0000000..cba3fb8
--- /dev/null
@@ -0,0 +1,51 @@
+#
+# Show total VHF DX Spot Stats per day
+#
+# Copyright (c) 2001 Dirk Koopman G1TLH
+#
+# $Id$
+#
+
+my ($self, $line) = @_;
+my @f = split /\s+/, $line;
+my $days = 31;
+my $now = Julian::Day->new(time())->sub(31);
+my $i;
+my @in;
+
+# 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 unless $l[0] eq 'TOTALS';
+               next unless $l[1];
+               $l[0] = $now; 
+               push @in, \@l; 
+               last;
+       }
+       $now = $now->add(1);
+}
+
+my @out;
+my @tot;
+
+push @out, $self->msg('statvhf');
+push @out, sprintf "%11s|%6s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|", qw(Callsign Total 6m 4m 2m 70cm 23cm 13cm 9cm 6cm 3cm);
+foreach my $ref (@in) {
+       my $linetot = 0;
+       foreach my $j (12..14,16..21) {
+               $tot[$j] += $ref->[$j];
+               $tot[0] += $ref->[$j];
+               $linetot += $ref->[$j];
+       }
+       push @out, join('|', sprintf("%11s|%6d", $ref->[0]->as_string, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[12..14,16..21]) . '|';
+}
+push @out, join('|', sprintf("%11s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[12..14,16..21]) . '|';
+
+return (1, @out);
diff --git a/cmd/show/vhftable.pl b/cmd/show/vhftable.pl
new file mode 100644 (file)
index 0000000..9849db4
--- /dev/null
@@ -0,0 +1,74 @@
+#
+# 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;
+
+push @dxcc, (61..67) if $self->dxcc >= 61 && $self->dxcc < 67;
+push @dxcc, $self->dxcc unless @dxcc;
+
+my $now = Julian::Day->new(time())->sub(1);
+my %list;
+my $i;
+
+# 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 grep $l[2] eq $_, @dxcc;
+               my $ref = $list{$l[0]} || [0,0,0,0,0,0,0,0,0,0];
+               my $j = 1;
+               foreach my $item (@l[12..14, 16..22]) {
+                       $ref->[$j] += $item;
+                       $ref->[0] += $item;
+                       $j++;
+               }
+               $list{$l[0]} = $ref if $ref->[0];
+       }
+       $now = $now->sub(1);
+}
+
+my @out;
+my @tot;
+my $nocalls;
+
+push @out, $self->msg('statvhft', join ',', @dxcc);
+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, "");
+}
+
+$nocalls = sprintf "%10s", "$nocalls calls";
+@tot = map {$_ ?  sprintf("%4d", $_) : '    ' } @tot;
+push @out, join('|', $nocalls, @tot, "");
+
+return (1, @out);