X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FFilter.pm;h=0ca71917db987cb5637ebe5bec404b1ddb611e64;hb=52fd47abd1cd7b1764a18b6bb6c69e1454952725;hp=bf7ff65c18a24c82df8eb4c45e7c7e7695b2e04d;hpb=dbf7523a9b228dbdf1d03109afde351b8b194fab;p=spider.git diff --git a/perl/Filter.pm b/perl/Filter.pm index bf7ff65c..0ca71917 100644 --- a/perl/Filter.pm +++ b/perl/Filter.pm @@ -490,24 +490,15 @@ sub parse } $s .= "(" . join(' || ', @t) . ")"; } elsif ($fref->[1] =~ /^n[ciz]$/ ) { # for DXCC, ITU, CQ Zone - my @n; my $cmd = $fref->[1]; - foreach my $v (@val) { - if ($v =~ /^\d+$/) { - push @n, $v unless grep $_ eq $v, @n; - } else { - my @pre = Prefix::extract($v); - return ('numpre', $dxchan->msg('e27', $_)) unless @pre; - shift @pre; - foreach my $p (@pre) { - my $n = $p->dxcc if $cmd eq 'nc' ; - $n = $p->itu if $cmd eq 'ni' ; - $n = $p->cq if $cmd eq 'nz' ; - push @n, $n unless grep $_ eq $n, @n; - } - } - } - $s .= "(" . join(' || ', map {"\$r->[$fref->[2]]==$_"} @n) . ")"; + my @pre = Prefix::to_ciz($cmd, @val); + return ('numpre', $dxchan->msg('e27', $_)) unless @pre; + $s .= "(" . join(' || ', map {"\$r->[$fref->[2]]==$_"} @pre) . ")"; + } elsif ($fref->[1] =~ /^ns$/ ) { # for DXCC, ITU, CQ Zone + my $cmd = $fref->[1]; + my @pre = Prefix::to_ciz($cmd, @val); + return ('numpre', $dxchan->msg('e27', $_)) unless @pre; + $s .= "(" . "!\$USDB::present || grep \$r->[$fref->[2]] eq \$_, qw(" . join(' ' ,map {uc} @pre) . "))"; } elsif ($fref->[1] eq 'r') { my @t; for (@val) {