1964a23ab60550f9023db22feb74ac22ac9ed3be
[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 sub handle
29 {
30
31         my ($self, $line) = @_;
32         my @f = split /\s+/, $line;
33         my @out;
34         my $days = 31;
35
36         my $utime = $main::systime;
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                 } elsif (my $ut = Date::Parse::str2time($f)) { # is it a parseable date?
45                         $utime = $ut+3600;
46                         next;
47                 }
48                 push @out, $self->msg('e33', $f);
49         }
50
51         return (1, @out) if @out;
52
53         my $now = Julian::Day->new($utime);
54         $now = $now->sub($days);
55         my $today = cldate($utime);
56
57 #       @out = $self->spawn_cmd("show/hfstats $line", sub {
58 #                                                       });
59
60         if ($self->{_nospawn}) {
61                 return (1, generate($self, $days, $now, $today));
62         }
63         else {
64                 return (1, $self->spawn_cmd("show/hfstats $line", sub { (generate($self, $days, $now, $today )); }));
65         }
66 }
67
68
69 sub generate
70 {
71         my ($self, $days, $now, $today) = @_;
72         
73         my %list;
74         my @out;
75         my @in;
76         my $i;
77         # generate the spot list
78         for ($i = 0; $i < $days; $i++) {
79                 my $fh = $Spot::statp->open($now); # get the next file
80                 unless ($fh) {
81                         Spot::genstats($now);
82                         $fh = $Spot::statp->open($now);
83                 }
84                 while (<$fh>) {
85                         chomp;
86                         my @l = split /\^/;
87                         next unless $l[0] eq 'TOTALS';
88                         next unless $l[1];
89                         $l[0] = $now; 
90                         push @in, \@l; 
91                         last;
92                 }
93                 $now = $now->add(1);
94         }
95                                                         
96         my @tot;
97                                                         
98         push @out, $self->msg('stathf', $today, $days);
99         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);
100         foreach my $ref (@in) {
101                 my $linetot = 0;
102                 foreach my $j (4..13) {
103                         $tot[$j] += $ref->[$j];
104                         $tot[0] += $ref->[$j];
105                         $linetot += $ref->[$j];
106                 }
107                 my $today = $ref->[0]->as_string;
108                 $today =~ s/-\d+$//;
109                 push @out, join '|', sprintf("%6s|%6d", $today, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[4..13], "";
110         }
111         push @out, join '|', sprintf("%6s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[4..13], "";
112         return @out
113
114 }