projects
/
spider.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add gitbranch to pc18
[spider.git]
/
perl
/
AnnTalk.pm
diff --git
a/perl/AnnTalk.pm
b/perl/AnnTalk.pm
index b48dc7e0ca56f58a1bc8ed5693541cf89d6bbc93..ee7ea51570164916e925f08f34eb24c79dae46ee 100644
(file)
--- a/
perl/AnnTalk.pm
+++ b/
perl/AnnTalk.pm
@@
-3,7
+3,7
@@
#
# Copyright (c) 2000 Dirk Koopman
#
#
# Copyright (c) 2000 Dirk Koopman
#
-#
$Id$
+#
#
package AnnTalk;
#
package AnnTalk;
@@
-17,8
+17,8
@@
use DXVars;
use vars qw(%dup $duplth $dupage $filterdef);
use vars qw(%dup $duplth $dupage $filterdef);
-$duplth =
6
0; # the length of text to use in the deduping
-$dupage =
5*24*3600; # the length of time to hold spot
dups
+$duplth =
3
0; # the length of text to use in the deduping
+$dupage =
18*3600; # the length of time to hold ann
dups
$filterdef = bless ([
# tag, sort, field, priv, special parser
['by', 'c', 0],
$filterdef = bless ([
# tag, sort, field, priv, special parser
['by', 'c', 0],
@@
-34,27
+34,24
@@
$filterdef = bless ([
['origin_dxcc', 'nc', 10],
['origin_itu', 'ni', 11],
['origin_zone', 'nz', 12],
['origin_dxcc', 'nc', 10],
['origin_itu', 'ni', 11],
['origin_zone', 'nz', 12],
+ ['by_state', 'nz', 13],
+ ['origin_state', 'nz', 14],
], 'Filter::Cmd');
], 'Filter::Cmd');
-use vars qw($VERSION $BRANCH);
-$VERSION = sprintf( "%d.%03d", q$Revision$ =~ /(\d+)\.(\d+)/ );
-$BRANCH = sprintf( "%d.%03d", q$Revision$ =~ /\d+\.\d+\.(\d+)\.(\d+)/ ) || 0;
-$main::build += $VERSION;
-$main::branch += $BRANCH;
-
# enter the spot for dup checking and return true if it is already a dup
sub dup
{
# enter the spot for dup checking and return true if it is already a dup
sub dup
{
- my ($call, $to, $text) = @_;
+ my ($call, $to, $text
, $t
) = @_;
+ $t ||= $main::systime + $dupage;
chomp $text;
unpad($text);
$text =~ s/\%([0-9A-F][0-9A-F])/chr(hex($1))/eg;
chomp $text;
unpad($text);
$text =~ s/\%([0-9A-F][0-9A-F])/chr(hex($1))/eg;
+# $text = Encode::encode("iso-8859-1", $text) if $main::can_encode && Encode::is_utf8($text, 1);
+ $text =~ s/[^\#a-zA-Z0-9]//g;
$text = substr($text, 0, $duplth) if length $text > $duplth;
$text = substr($text, 0, $duplth) if length $text > $duplth;
- $text = pack("C*", map {$_ & 127} unpack("C*", $text));
- $text =~ s/[^a-zA-Z0-9]//g;
- my $dupkey = "A$to|\L$text";
- return DXDupe::check($dupkey, $main::systime + $dupage);
+ my $dupkey = "A$call|$to|\L$text";
+ return DXDupe::check($dupkey, $t);
}
sub listdups
}
sub listdups
@@
-62,6
+59,22
@@
sub listdups
return DXDupe::listdups('A', $dupage, @_);
}
return DXDupe::listdups('A', $dupage, @_);
}
+# is this text field a likely announce to talk substitution?
+# this may involve all sorts of language dependant heuristics, but
+# then again, it might not
+sub is_talk_candidate
+{
+ my ($from, $text) = @_;
+ my $call;
+ ($call) = $text =~ /^\s*(?:[Xx]|[Tt][Oo]?:?)\s+([\w-]+)/;
+ ($call) = $text =~ /^\s*>\s*([\w-]+)\b/ unless $call;
+ ($call) = $text =~ /^\s*([\w-]+):?\b/ unless $call;
+ if ($call) {
+ $call = uc $call;
+ return is_callsign($call);
+ }
+ return undef;
+}
1;
1;