some detail changes to do with -w flags etc
[spider.git] / cmd / dx.pl
index 394cb7ab6820495eaf71e72978147bdd741d9dd6..763bf9b0aace735bd8e7db629724c2c594fe15d6 100644 (file)
--- a/cmd/dx.pl
+++ b/cmd/dx.pl
@@ -17,15 +17,17 @@ my @out;
 my $valid = 0;
 
 # first lets see if we think we have a callsign as the first argument
-if ($f[0] =~ /[A-Za-z]/) {
-  $spotter = uc $f[0];
-  $freq = $f[1];
-  $spotted = uc $f[2];
-  $line =~ s/^$f[0]\s+$f[1]\s+$f[2]\s*//;
-} else {
-  $freq = $f[0];
-  $spotted = uc $f[1]; 
-  $line =~ s/^$f[0]\s+$f[1]\s*//;
+if (defined @f && @f >= 3 && $f[0] =~ /[A-Za-z]/) {
+       $spotter = uc $f[0];
+       $freq = $f[1];
+       $spotted = uc $f[2];
+       $line =~ s/^$f[0]\s+$f[1]\s+$f[2]\s*//;
+} elsif (defined @f && @f >= 2) {
+       $freq = $f[0];
+       $spotted = uc $f[1]; 
+       $line =~ s/^$f[0]\s+$f[1]\s*//;
+} elsif (!defined @f || @f < 2) {
+       return (1, $self->msg('dx2'));
 }
 
 # bash down the list of bands until a valid one is reached
@@ -36,13 +38,13 @@ my $i;
 # first in KHz
 L1:
 foreach $bandref (Bands::get_all()) {
-  @bb = @{$bandref->band};
-  for ($i = 0; $i < @bb; $i += 2) {
-    if ($freq >= $bb[$i] && $freq <= $bb[$i+1]) {
-         $valid = 1;
-         last L1;
+       @bb = @{$bandref->band};
+       for ($i = 0; $i < @bb; $i += 2) {
+               if ($freq >= $bb[$i] && $freq <= $bb[$i+1]) {
+                       $valid = 1;
+                       last L1;
+               }
        }
-  }
 }
 
 if (!$valid) {
@@ -50,7 +52,7 @@ if (!$valid) {
        # try again in MHZ 
        $freq = $freq * 1000 if $freq;
 
-L2:
+ L2:
     foreach $bandref (Bands::get_all()) {
                @bb = @{$bandref->band};
                for ($i = 0; $i < @bb; $i += 2) {
@@ -70,20 +72,20 @@ push @out, $self->msg('dx1', $freq) if !$valid;
 if ($spotted le ' ') {
        push @out, $self->msg('dx2');
        
-  $valid = 0;
+       $valid = 0;
 }
 
 return (1, @out) if !$valid;
 
 # Store it here
 if (Spot::add($freq, $spotted, $main::systime, $line, $spotter)) {
-  # send orf to the users
-  my $buf = Spot::formatb($freq, $spotted, $main::systime, $line, $spotter);
-  DXProt::broadcast_users($buf);
+       # send orf to the users
+       my $buf = Spot::formatb($freq, $spotted, $main::systime, $line, $spotter);
+       DXProt::broadcast_users($buf);
 
 
-  # send it orf to the cluster (hang onto your tin helmets)!
-  DXProt::broadcast_ak1a(DXProt::pc11($spotter, $freq, $spotted, $line));
+       # send it orf to the cluster (hang onto your tin helmets)!
+       DXProt::broadcast_ak1a(DXProt::pc11($spotter, $freq, $spotted, $line));
 }
 
 return (1, @out);