remove $Id$ strings from everywhere that I can find
[spider.git] / cmd / show / hfstats.pl
1 #
2 # Show total HF DX Spot Stats per day
3 #
4 # Copyright (c) 2001 Dirk Koopman G1TLH
5 #
6 #
7 #
8 # Modified on 2002/10/29 by K1XX for his own use
9 # Valid inputs:
10 #
11 # sh/hfstats
12 #
13 # sh/hfstats <date> <no. of days>
14 #
15 # Known good data formats
16 # dd-mmm-yy
17 # 24-Nov-02 (using - . or / as separator)
18 #
19 # mm-dd-yy
20 # 11/24/02 (using - . or / as separator)
21 #
22 # yymmdd
23 # 021124
24 #
25
26 use Date::Parse;
27
28 my ($self, $line) = @_;
29 my @f = split /\s+/, $line;
30 my $days = 31;
31 my $i;
32 my @in;
33 my $now;
34 my $date = cldate($main::systime);
35 my $utime = $main::systime;
36 my @out;
37
38 while (@f) {
39         my $f = shift @f;
40
41         if ($f =~ /^\d+$/ && $f < 366) {                # no of days
42                 $days = $f;
43                 next;
44         }
45         if (my $ut = Date::Parse::str2time($f)) {       # is it a parseable date?
46                 $utime = $ut+3600;
47                 next;
48         }
49         push @out, $self->msg('e33', $f);
50 }
51
52 return (1, @out) if @out;
53
54 $now = Julian::Day->new($utime);
55 $now = $now->sub($days);
56 $date = cldate($utime);
57
58 # generate the spot list
59 for ($i = 0; $i < $days; $i++) {
60         my $fh = $Spot::statp->open($now); # get the next file
61         unless ($fh) {
62                 Spot::genstats($now);
63                 $fh = $Spot::statp->open($now);
64         }
65         while (<$fh>) {
66                 chomp;
67                 my @l = split /\^/;
68                 next unless $l[0] eq 'TOTALS';
69                 next unless $l[1];
70                 $l[0] = $now; 
71                 push @in, \@l; 
72                 last;
73         }
74         $now = $now->add(1);
75 }
76
77 my @tot;
78
79 push @out, $self->msg('stathf', $date, $days);
80 push @out, sprintf "%6s|%6s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|", qw(Date Total 160m 80m 60m 40m 30m 20m 17m 15m 12m 10m);
81 foreach my $ref (@in) {
82         my $linetot = 0;
83         foreach my $j (4..13) {
84                 $tot[$j] += $ref->[$j];
85                 $tot[0] += $ref->[$j];
86                 $linetot += $ref->[$j];
87         }
88         my $date = $ref->[0]->as_string;
89         $date =~ s/-\d+$//;
90         push @out, join '|', sprintf("%6s|%6d", $date, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[4..13], "";
91 }
92 push @out, join '|', sprintf("%6s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[4..13], "";
93
94 return (1, @out);