X-Git-Url: http://dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FDXCommandmode.pm;h=fe5a484295f7bc9c0a9948946dfa362559e11506;hb=c3b95a4f495e27291491bd38a8baeadc23cd884f;hp=4601ec21df0ca34d01ca99b7beb64f9f9996bdd8;hpb=55f3823f3ad86d76e1e995b0f255f1804684de18;p=spider.git diff --git a/perl/DXCommandmode.pm b/perl/DXCommandmode.pm index 4601ec21..fe5a4842 100644 --- a/perl/DXCommandmode.pm +++ b/perl/DXCommandmode.pm @@ -155,9 +155,9 @@ sub start # do we need to send a forward/opernam? my $lastoper = $user->lastoper || 0; my $homenode = $user->homenode || ""; - if ($homenode eq $main::mycall && $lastoper + $DXUser::lastoperinterval < $main::systime) { + if ($homenode eq $main::mycall && $main::systime >= $lastoper + $DXUser::lastoperinterval) { run_cmd($main::me, "forward/opernam $call"); - $user->lastoper($main::systime); + $user->lastoper($main::systime + ((int rand(10)) * 86400)); } # run a script send the output to the punter @@ -265,9 +265,24 @@ sub normal } $self->state('prompt'); delete $self->{talklist}; - } elsif ($cmdline =~ m(^/\w+)) { - $cmdline =~ s(^/)(); - $self->send_ans(run_cmd($self, $cmdline)); + } elsif ($cmdline =~ m|^/+\w+|) { + $cmdline =~ s|^/||; + my $sendit = $cmdline =~ s|^/+||; + my @in = $self->run_cmd($cmdline); + $self->send_ans(@in); + if ($sendit && $self->{talklist} && @{$self->{talklist}}) { + foreach my $l (@in) { + my @bad; + if (@bad = BadWords::check($l)) { + $self->badcount(($self->badcount||0) + @bad); + Log('DXCommand', "$self->{call} swore: $l"); + } else { + for (@{$self->{talklist}}) { + $self->send_talks($_, $l); + } + } + } + } $self->send($self->talk_prompt); } elsif ($self->{talklist} && @{$self->{talklist}}) { # send what has been said to whoever is in this person's talk list @@ -631,7 +646,7 @@ sub clear_cmd_cache no strict 'refs'; for (keys %Cache) { - undef *{$_}; + undef *{$_} unless /cmd_cache/; dbg("Undefining cmd $_") if isdbg('command'); } %cmd_cache = ();