add an RBN line to progress
[spider.git] / perl / Spot.pm
index b3eff00c280173abee504a4de3e765fd98c1d3bf..0761f07d0522f865ad10d4c950df4d12033f7f02 100644 (file)
@@ -49,12 +49,21 @@ $filterdef = bless ([
                                         ['by_zone', 'nz', 11],
                                         ['call_state', 'ns', 12],
                                         ['by_state', 'ns', 13],
-                                        ['channel', 'c', 14],
-                                        ['rbn', 'a', 4, 0, \&filterrbnspot],
-                        ], 'Filter::Cmd');
+                                        ['ip', 'c', 14],
+#                                       ['channel', 'c', 15],
+#                                       ['rbn', 'a', 4, 0, \&filterrbnspot],
+                                       ], 'Filter::Cmd');
 $totalspots = $hfspots = $vhfspots = 0;
 $use_db_for_search = 0;
 
+our $usetac = 0;
+our $readback;
+
+if ($usetac) {
+       $readback = `which tac`;
+       chomp $readback;
+}
+
 # create a Spot Object
 sub new
 {
@@ -213,7 +222,7 @@ sub add
        }
        if ($_[3] =~ /(?:QSL|VIA)/i) {
                my $q = QSL::get($_[1]) || new QSL $_[1];
-               $q->update($_[3], $_[2], $_[4]);
+               $q->update($_[3], $_[2], $_[4]) if $q;
        }
 }
 
@@ -231,7 +240,7 @@ sub add
 #   $f5 = spotted dxcc country
 #   $f6 = spotter dxcc country
 #   $f7 = origin
-#
+#   $f8 = ip address
 #
 # In addition you can specify a range of days, this means that it will start searching
 # from <n> days less than today to <m> days less than today
@@ -298,31 +307,50 @@ sub search
                                   my \@s = split /\\^/;
                    $checkfilter;
                    push \@spots, \\\@s;
+                   shift \@spots if \@spots > $to + 2; 
                           }
                           my \$c;
                           my \$ref;
-                          for (\$c = \$#spots; \$c >= 0; \$c--) {
-                                       \$ref = \$spots[\$c];
-                                       if ($expr) {
-                                               \$count++;
-                                               next if \$count < \$from; # wait until from 
-                                               push(\@out, \$ref);
-                                               last if \$count >= \$to; # stop after to
-                                       }
-                               }
+               if (\$readback) {
+                   foreach \$ref (\@spots) {
+                              if ($expr) {
+                                                  \$count++;
+                                                  next if \$count < $from; # wait until from 
+                                                  push(\@out, \$ref);
+                                                  last if \$count >= $to; # stop after to
+                                  }         
+                   }
+               } else {
+                             for (\$c = \$#spots; \$c >= 0; \$c--) {
+                                          \$ref = \$spots[\$c];
+                                          if ($expr) {
+                                                  \$count++;
+                                                  next if \$count < $from; # wait until from 
+                                                  push(\@out, \$ref);
+                                                  last if \$count >= $to; # stop after to
+                                          }
+                                  }
+               }
                          );
+                
+       
     
        dbg("Spot eval: $eval") if isdbg('searcheval');
        
-
-       $fp->close;                                     # close any open files
-
+       my $fh;
+       my $now = $fromdate;
        for ($i = $count = 0; $i < $maxdays; ++$i) {    # look thru $maxdays worth of files only
-               my $now = $fromdate->sub($i); # but you can pick which $maxdays worth
-               last if $now->cmp($todate) <= 0;         
-       
-               my @spots = ();
-               my $fh = $fp->open($now); # get the next file
+               my @spots;
+               last if $now->cmp($todate) <= 0;
+               
+               if ($readback) {
+                       my $fn = $fp->fn($now->sub($i));
+                       dbg("search using tac fn: $fn $i") if isdbg('search');
+                       $fh = IO::File->new("$readback $fn |");
+               } else {
+                       $fh = $fp->open($now->sub($i));      # get the next file
+                       dbg("search fn: $fp->{fn} $i") if isdbg('search');
+               }
                if ($fh) {
                        my $in;
                        eval $eval;                     # do the search on this file