Improve M$ Windows compatibility
[spider.git] / cmd / show / hftable.pl
index 2b83994aea6e19f02508eaffc44ef0f529751daa..bc3153ef7ad9899dd6b333e06af04c6e57cb327e 100644 (file)
-#
+ #
 # do an HFSpot table 
 #
 # Copyright (c) 2001 Dirk Koopman G1TLH
 #
-# $Id$
+#
+#
+# Modified on 2002/10/27 by K1XX for his own use
+# Valid inputs (and then tarted up by G1TLH to include in the
+# main distribution):
+#
+# sh/hftable (original operation, starts from today for own prefix)
+#
+# sh/hftable [<date>] [<no. of days>] [prefix] [prefix] [prefix] ..
+#
+# sh/hftable [<date>] [<no. of days>]  (data from your own prefix)
+# 
+# sh/hftable [<date>] [<no. of days>] [callsign] [callsign] [callsign] ..
+#
+# sh/hftable [<date>] [<no of days>] all
+#  
+#
+# Known good data formats
+# dd-mmm-yy
+# 24-Nov-02 (using - . or / as separator)
+# 24nov02 (ie no separators)
+# 24nov2002
+#
+# mm-dd-yy (this depends on your locale settings)
+# 11-24-02 (using - . or / as separator) 
+#
+# yymmdd
+# 021124
+# 20021124
 #
 
-my ($self, $line) = @_;
-my @f = split /\s+/, $line;
-my @calls;
-my $days = 31;
-my @dxcc;
+ my @calls;
+ my $days = 31;
+ my @dxcc;
+ my $limit = 100;
+ my $now;
+ my @pref;
+ my $date;
+ my $all;
 
-push @dxcc, (61..67) if $self->dxcc >= 61 && $self->dxcc < 67;
-push @dxcc, $self->dxcc unless @dxcc;
+ sub handle
+ {
+        my ($self, $line) = @_;
 
-my $now = Julian::Day->new(time())->sub(1);
-my %list;
-my $i;
+        my @out;
 
-# 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 @f = split /\s+/, $line;
+
+        #$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);
+        }
 
-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);
+        if ($self->{_nospawn} || $main::is_win == 1) {
+                @out = generate($self);
+        } else {
+                @out = $self->spawn_cmd("show/hftable $line", sub { return (generate($self)); });
+        }
 
-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 = '    ';
+        return (1, @out);
+ }
+
+sub generate
+ {
+        my $self = shift;
+        
+       my @out;
+       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 $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[4..13]) {
+                               $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('stathft', $l, $date, $days);
+       push @out, sprintf "%9s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|%5s|", qw(Callsign Tot 160m 80m 60m 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 "%9s", $_);
+               foreach my $j (0..11) {
+                       my $r = $ref->[$j];
+                       if ($r) {
+                               $tot[$j] += $r;
+                               $r = sprintf("%5d", $r);
+                       }
+                       else {
+                               $r = '     ';
+                       }
+                       push @list, $r;
                }
-               push @list, $r;
+               push @out, join('|', @list);
+               last if $limit && $nocalls >= $limit;
        }
-       push @out, join('|', @list);
+       
+       $nocalls = sprintf "%9s", "$nocalls calls";
+       @tot = map {$_ ?  sprintf("%5d", $_) : '     ' } @tot;
+       push @out, join('|', $nocalls, @tot,"");
+       return @out;
 }
-
-$nocalls = sprintf "%10s", "$nocalls calls";
-@tot = map {$_ ?  sprintf("%4d", $_) : '    ' } @tot;
-push @out, join('|', $nocalls, @tot, "");
-
-return (1, @out);