improve DXQsl handling and fix crashes?
authorDirk Koopman <djk@tobit.co.uk>
Tue, 10 Sep 2019 16:02:53 +0000 (17:02 +0100)
committerDirk Koopman <djk@tobit.co.uk>
Tue, 10 Sep 2019 16:02:53 +0000 (17:02 +0100)
Changes
cmd/load/dxqsl.pl [new file with mode: 0644]
cmd/load/qsl.pl [changed from file to symlink]
perl/DXUtil.pm
perl/QSL.pm

diff --git a/Changes b/Changes
index a8d71b44799e054e61c8e5ba9636f69cab0e29cb..3473184f7ab7608f6d2e956539dd2abfda34e471 100644 (file)
--- a/Changes
+++ b/Changes
@@ -1,3 +1,6 @@
+10Sep19=======================================================================
+1. Improve DXSql database filtering to exclude most via <locator> type 
+   reports.
 14Jul18=======================================================================
 1. Add CTY-2808 prefixes + wpxloc.raw
 23Jan18=======================================================================
diff --git a/cmd/load/dxqsl.pl b/cmd/load/dxqsl.pl
new file mode 100644 (file)
index 0000000..ddf51d3
--- /dev/null
@@ -0,0 +1,7 @@
+#
+# load the QSL file after changing it
+#
+my $self = shift;
+return (1, $self->msg('e5')) if $self->priv < 9;
+my $r = QSL::init(1);
+return (1, $r ? $self->msg('ok') : $self->msg('e2', "$!"));
deleted file mode 100644 (file)
index ddf51d34d34219133ac1a2ac8672b4cdf4d9e410..0000000000000000000000000000000000000000
+++ /dev/null
@@ -1,7 +0,0 @@
-#
-# load the QSL file after changing it
-#
-my $self = shift;
-return (1, $self->msg('e5')) if $self->priv < 9;
-my $r = QSL::init(1);
-return (1, $r ? $self->msg('ok') : $self->msg('e2', "$!"));
new file mode 120000 (symlink)
index 0000000000000000000000000000000000000000..1adfae50f84f1efcc3827e06cd26dc18dbf56e39
--- /dev/null
@@ -0,0 +1 @@
+dxqsl.pl
\ No newline at end of file
index 4e442140b82e9394422492bc639f5d3fd6ed8903..abb20a96a4ec3c184d118a363d07f67530307a2a 100644 (file)
@@ -435,7 +435,8 @@ sub is_digits
 # does it look like a qra locator?
 sub is_qra
 {
-       return $_[0] =~ /^[A-Ra-r][A-Ra-r]\d\d[A-Xa-x][A-Xa-x]$/;
+       return unless length $_[0] == 4 || length $_[0] == 6;
+       return $_[0] =~ /^[A-Ra-r][A-Ra-r]\d\d(?:[A-Xa-x][A-Xa-x])?$/;
 }
 
 # does it look like a valid lat/long
index 20d5c6143f139e656ab3a4c325fa7a1872fa78da..1031c953eaa9523142c19b8b7ea55faf2c578e0d 100644 (file)
@@ -14,9 +14,10 @@ use DB_File;
 use DXDebug;
 use Prefix;
 
-use vars qw($qslfn $dbm);
+use vars qw($qslfn $dbm $maxentries);
 $qslfn = 'qsl';
 $dbm = undef;
+$maxentries = 50;
 
 sub init
 {
@@ -37,6 +38,7 @@ sub init
        }
        import Storable qw(nfreeze freeze thaw);
        my %u;
+       undef $dbm;
        if ($mode) {
                $dbm = tie (%u, 'DB_File', $ufn, O_CREAT|O_RDWR, 0666, $DB_BTREE) or confess "can't open qsl file: $qslfn ($!)";
        } else {
@@ -65,19 +67,24 @@ sub update
        my $t = shift;
        my $by = shift;
        my $changed;
-                       
+
+       return unless length $line && $line =~ /\b(?:QSL|VIA)\b/i;
        foreach my $man (split /\b/, uc $line) {
                my $tok;
                
-               if (is_callsign($man)) {
+               if (is_callsign($man) && !is_qra($man)) {
                        my @pre = Prefix::extract($man);
                        $tok = $man if @pre && $pre[0] ne 'Q';
                } elsif ($man =~ /^BUR/) {
                        $tok = 'BUREAU';
+               } elsif ($man =~ /^LOTW/) {
+                       $tok = 'LOTW';
                } elsif ($man eq 'HC' || $man =~ /^HOM/ || $man =~ /^DIR/) {
                        $tok = 'HOME CALL';
                } elsif ($man =~ /^QRZ/) {
                        $tok = 'QRZ.com';
+               } else {
+                       next;
                }
                if ($tok) {
                        my ($r) = grep {$_->[0] eq $tok} @{$self->[1]};
@@ -93,6 +100,8 @@ sub update
                                unshift @{$self->[1]}, $r;
                                $changed++;
                        }
+                       # prune the number of entries
+                       pop @{$self->[1]} while (@{$self->[1]} > $maxentries);
                }
        }
        $self->put if $changed;