]> dxcluster.net Git - spider.git/blob - cmd/talk.pl
minor debugging change
[spider.git] / cmd / talk.pl
1 #
2 # The talk command (improved)
3 #
4 # Copyright (c) 1998 Dirk Koopman G1TLH
5 #
6 #
7 #
8
9 my ($self, $inline) = @_;
10 my $to;
11 my $via;
12 my $line;
13 my $from = $self->call;
14 my @out;
15 return (1, $self->msg('e5')) if $self->remotecmd || $self->inscript;
16
17 # analyse the line there are four situations...
18 # 1) talk call
19 # 2) talk call <text>
20 # 3) talk call>node 
21 # 4) talk call>node text
22 #
23
24 ($to, $via, $line) = $inline =~ /^\s*([A-Za-z0-9\-]+)\s*>([A-Za-z0-9\-]+)(.*)$/;
25 if ($via) {
26         $line =~ s/\s+// if $line;
27 } else {
28         ($to, $line) = split /\s+/, $inline, 2;  
29 }
30
31 return (1, $self->msg('e8')) unless $to;
32
33 $to = uc $to;
34
35 return (1, $self->msg('e22', $to)) unless is_callsign($to);
36 return (1, $self->msg('e28')) unless $self->registered || $to eq $main::myalias;
37
38 $via = uc $via if $via;
39 my $call = $via || $to;
40 my $clref = Route::get($call);     # try an exact call
41 my $dxchan = $clref->dxchan if $clref;
42 push @out, $self->msg('e7', $call) unless $dxchan;
43
44 #$DB::single = 1;
45
46 # default the 'via'
47 #$via ||= '*';
48
49 # if there is a line send it, otherwise add this call to the talk list
50 # and set talk mode for command mode
51 if ($line) {
52         my @bad;
53         Log('talk', $to, $from, '>' . ($via || ($dxchan && $dxchan->call) || '*'), $line);
54         if (@bad = BadWords::check($line)) {
55                 $self->badcount(($self->badcount||0) + @bad);
56                 LogDbg('DXCommand', "$self->{call} swore: $line (with words:" . join(',', @bad) . ")");
57         } else {
58                 $main::me->normal(DXProt::pc93($to, $self->call, $via, $line));
59         }
60 } else {
61         my $s = $to;
62         $s .= ">$via" if $via && $via ne '*';
63         my $ref = $self->talklist;
64         if ($ref) {
65                 unless (grep { $_ eq $s } @$ref) {
66                         $main::me->normal(DXProt::pc93($to, $self->call, $via, $self->msg('talkstart')));
67                         $self->state('talk');
68                         push @$ref, $s;
69                 }
70         } else { 
71                 $self->talklist([ $s ]);
72                 $main::me->normal(DXProt::pc93($to, $self->call, $via, $self->msg('talkstart')));
73                 push @out, $self->msg('talkinst');
74                 $self->state('talk');
75         }
76         Log('talk', $to, $from, '>' . ($via || ($dxchan && $dxchan->call) || '*'), $self->msg('talkstart'));
77         push @out, $self->talk_prompt;
78 }
79
80 return (1, @out);
81