]> dxcluster.net Git - spider.git/commitdiff
fixed uninit var in dbshow
authordjk <djk>
Tue, 9 Nov 1999 17:58:00 +0000 (17:58 +0000)
committerdjk <djk>
Tue, 9 Nov 1999 17:58:00 +0000 (17:58 +0000)
changed qra format, added lat/log -> qra conversion

cmd/dbshow.pl
cmd/show/qra.pl

index 10cce96071a593369f30f8da4715551ee671172d..967cb469e90ff6b3e3112593a78d07b96799fb69 100644 (file)
@@ -44,7 +44,7 @@ foreach  $n (@db) {
                push @out, "@f";
                for (@f) {
                        push @out, $db->name . " $_";
-                       my $value = $db->getkey($_);
+                       my $value = $db->getkey($_) || "";
                        push @out, $db->name . ": $_ : $value";
                        if ($value) {
                                push @out, split /\n/, $value;
index 90c5bb1a864231da0fd0fd6b33ef9a8ebea7e10d..2bbb606f6206689fdbf27c4722781c13aed23aa0 100644 (file)
@@ -10,6 +10,8 @@ my ($self, $line) = @_;
 my @list = split /\s+/, $line;               # generate a list of callsigns
 
 my @out;
+my $fll;
+my $tll;
 my $lat = $self->user->lat;
 my $long = $self->user->long;
 if (!$long && !$lat) {
@@ -18,8 +20,16 @@ if (!$long && !$lat) {
        $long = $main::mylongitude;
 }
 
+my $fqra = DXBearing::is_qra($list[0]);
+my $sqra = $list[0] =~ /^[A-Za-z][A-Za-z]\d\d$/;
+my $ll = $line =~ /^\d+\s+\d+\s*[NSns]\s+\d+\s+\d+\s*[EWew]/;
 return (1, $self->msg('qrashe1')) unless @list > 0;
-return (1, $self->msg('qrae2', $list[0])) unless (DXBearing::is_qra($list[0]) || $list[0] =~ /^[A-Za-z][A-Za-z]\d\d$/);
+return (1, $self->msg('qrae2', $list[0])) unless $fqra || $sqra || $ll;
+
+if ($ll) {
+       my ($llat, $llong) = DXBearing::stoll($line);
+       return (1, "QRA $line = " . DXBearing::lltoqra($llat, $llong)); 
+}
 
 #print "$lat $long\n";
 
@@ -30,6 +40,7 @@ if (@list > 1) {
        $f = $l;
        $f .= 'MM' if $f =~ /^[A-Z][A-Z]\d\d$/;
        ($lat, $long) = DXBearing::qratoll($f);
+       $fll = DXBearing::lltos($lat, $long);
     #print "$lat $long\n";
        
        return (1, $self->msg('qrae2', $list[1])) unless (DXBearing::is_qra($list[1]) || $list[1] =~ /^[A-Za-z][A-Za-z]\d\d$/);
@@ -40,13 +51,18 @@ $l .= 'MM' if $l =~ /^[A-Z][A-Z]\d\d$/;
                
 my ($qlat, $qlong) = DXBearing::qratoll($l);
 #print "$qlat $qlong\n";
+$fll = DXBearing::lltos($lat, $long);
+$fll =~ s/\s+([NSEW])/$1/g;
+$tll = DXBearing::lltos($qlat, $qlong);
+$tll =~ s/\s+([NSEW])/$1/g;
+
 my ($b, $dx) = DXBearing::bdist($lat, $long, $qlat, $qlong);
 my ($r, $rdx) = DXBearing::bdist($qlat, $qlong, $lat, $long);
 my $to = '';
 
-$to = " -> $list[1]" if $f;
-my $from = $list[0];
+$to = "->\U$list[1]($tll)" if $f;
+my $from = "\U$list[0]($fll)" ;
 
-push @out, sprintf "$list[0]$to Bearing: %.0f Deg. Recip: %.0f Deg. %.0fMi. %.0fKm.", $b, $r, $dx * 0.62133785, $dx;
+push @out, sprintf "$from$to To: %.0f Fr: %.0f Dst: %.0fMi %.0fKm", $b, $r, $dx * 0.62133785, $dx;
 
 return (1, @out);