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:37:34 +0000 (17:37 +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 9008e88ec3c2ad0ec95d4b173bbe8e0c8aca897c..2ebf47200baec9026590a89154a080da005239fa 100644 (file)
--- a/Changes
+++ b/Changes
@@ -1,4 +1,6 @@
-14Jul18=======================================================================
+10Sep19=======================================================================
+1. Improve DXSql database filtering to exclude most via <locator> type 
+   reports.
 16Jun18=======================================================================
 1. add more modes to rbn.pl
 23Jan18=======================================================================
diff --git a/cmd/load/dxqsl.pl b/cmd/load/dxqsl.pl
new file mode 100644 (file)
index 0000000..b173822
--- /dev/null
@@ -0,0 +1,8 @@
+#
+# load the QSL file after changing it
+#
+my $self = shift;
+return (1, $self->msg('e5')) if $self->priv < 9;
+QSL::finish();
+my $r = QSL::init(1);
+return (1, $r ? $self->msg('ok') : $self->msg('e2', "$!"));
deleted file mode 100644 (file)
index b17382294f6e17cb4f20833a088a3688533e79ff..0000000000000000000000000000000000000000
+++ /dev/null
@@ -1,8 +0,0 @@
-#
-# load the QSL file after changing it
-#
-my $self = shift;
-return (1, $self->msg('e5')) if $self->priv < 9;
-QSL::finish();
-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 3e47f6e9d1980583bb540c271fe882aaaaf96075..bad92927dff99fea8340977746ddd0c8c92792f4 100644 (file)
@@ -427,7 +427,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 6649c7a76f9f30b68c78b876fe1f4dd0fd283e34..0df7570ba24f615ac1fccce38cde2d59955588ca 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;
 
 localdata_mv("$qslfn.v1");
 
@@ -39,6 +40,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 {
@@ -69,19 +71,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]};
@@ -97,6 +104,8 @@ sub update
                                unshift @{$self->[1]}, $r;
                                $changed++;
                        }
+                       # prune the number of entries
+                       pop @{$self->[1]} while (@{$self->[1]} > $maxentries);
                }
        }
        $self->put if $changed;