nospawnify the rest of the known commands
[spider.git] / cmd / show / hfstats.pl
index 5cee6593e5e758702fb27e9d0df755f856162432..7c22058e5ed8c940d4f380c4e5bbc55b408e6bb9 100644 (file)
 
 use Date::Parse;
 
-my ($self, $line) = @_;
-my @f = split /\s+/, $line;
 my $days = 31;
 my $now;
 my $date = cldate($main::systime);
 my $utime = $main::systime;
-my @out;
 
-while (@f) {
-       my $f = shift @f;
+sub handle
+{
 
-       if ($f =~ /^\d+$/ && $f < 366) {                # no of days
-               $days = $f;
-               next;
+       my ($self, $line) = @_;
+       my @f = split /\s+/, $line;
+       my @out;
+
+       while (@f) {
+               my $f = shift @f;
+
+               if ($f =~ /^\d+$/ && $f < 366) { # no of days
+                       $days = $f;
+                       next;
+               }
+               if (my $ut = Date::Parse::str2time($f)) { # is it a parseable date?
+                       $utime = $ut+3600;
+                       next;
+               }
+               push @out, $self->msg('e33', $f);
        }
-       if (my $ut = Date::Parse::str2time($f)) {       # is it a parseable date?
-               $utime = $ut+3600;
-               next;
+
+       return (1, @out) if @out;
+
+       $now = Julian::Day->new($utime);
+       $now = $now->sub($days);
+       $date = cldate($utime);
+
+       @out = $self->spawn_cmd("show/hfstats $line", sub {
+                                                       });
+
+       if ($self->{_nospawn}) {
+               return (1, generate($self));
+       }
+       else {
+               return (1, $self->spawn_cmd("show/hfstats $line", sub { (generate($self)); }));
        }
-       push @out, $self->msg('e33', $f);
 }
 
-return (1, @out) if @out;
-
-$now = Julian::Day->new($utime);
-$now = $now->sub($days);
-$date = cldate($utime);
 
-@out = $self->spawn_cmd("show/hfstats $line", sub {
-                                                       my %list;
-                                                       my @out;
-                                                       my @in;
-                                                       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 unless $l[0] eq 'TOTALS';
-                                                                       next unless $l[1];
-                                                                       $l[0] = $now; 
-                                                                       push @in, \@l; 
-                                                                       last;
-                                                               }
-                                                               $now = $now->add(1);
-                                                       }
+sub generate
+{
+       my $self = shift;
+       my %list;
+       my @out;
+       my @in;
+       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 unless $l[0] eq 'TOTALS';
+                       next unless $l[1];
+                       $l[0] = $now; 
+                       push @in, \@l; 
+                       last;
+               }
+               $now = $now->add(1);
+       }
                                                        
-                                                       my @tot;
+       my @tot;
                                                        
-                                                       push @out, $self->msg('stathf', $date, $days);
-                                                       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);
-                                                       foreach my $ref (@in) {
-                                                               my $linetot = 0;
-                                                               foreach my $j (4..13) {
-                                                                       $tot[$j] += $ref->[$j];
-                                                                       $tot[0] += $ref->[$j];
-                                                                       $linetot += $ref->[$j];
-                                                               }
-                                                               my $date = $ref->[0]->as_string;
-                                                               $date =~ s/-\d+$//;
-                                                               push @out, join '|', sprintf("%6s|%6d", $date, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[4..13], "";
-                                                       }
-                                                       push @out, join '|', sprintf("%6s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[4..13], "";
-                                                       return @out
-                                               });
-                                               
+       push @out, $self->msg('stathf', $date, $days);
+       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);
+       foreach my $ref (@in) {
+               my $linetot = 0;
+               foreach my $j (4..13) {
+                       $tot[$j] += $ref->[$j];
+                       $tot[0] += $ref->[$j];
+                       $linetot += $ref->[$j];
+               }
+               my $date = $ref->[0]->as_string;
+               $date =~ s/-\d+$//;
+               push @out, join '|', sprintf("%6s|%6d", $date, $linetot), map {$_ ? sprintf("%5d", $_) : '     '} @$ref[4..13], "";
+       }
+       push @out, join '|', sprintf("%6s|%6d", 'Total', $tot[0]), map {$_ ? sprintf("%5d", $_) : '     '} @tot[4..13], "";
+       return @out
 
-return (1, @out);
+}