mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-25 11:34:15 +01:00
Improvements in interpreter; tell <nick> about <command>; etc
This commit is contained in:
parent
09cb762c6f
commit
ccf1d35a54
@ -165,6 +165,7 @@ sub ack_die {
|
|||||||
}
|
}
|
||||||
|
|
||||||
sub export {
|
sub export {
|
||||||
|
my $self = shift;
|
||||||
my ($from, $nick, $user, $host, $arguments) = @_;
|
my ($from, $nick, $user, $host, $arguments) = @_;
|
||||||
|
|
||||||
if(not defined $arguments) {
|
if(not defined $arguments) {
|
||||||
|
@ -119,8 +119,8 @@ sub check_unban_timeouts {
|
|||||||
if($self->{unban_timeout}->hash->{$mask}{timeout} < $now) {
|
if($self->{unban_timeout}->hash->{$mask}{timeout} < $now) {
|
||||||
$self->unban_user($mask, $self->{unban_timeout}->hash->{$mask}{channel});
|
$self->unban_user($mask, $self->{unban_timeout}->hash->{$mask}{channel});
|
||||||
} else {
|
} else {
|
||||||
#my $timediff = $unban_timeout{$mask}{timeout} - $now;
|
# my $timediff = $self->{unban_timeout}->hash->{$mask}{timeout} - $now;
|
||||||
#$logger->log "ban: $mask has $timediff seconds remaining\n"
|
# $self->{pbot}->logger->log("ban: $mask has $timediff seconds remaining\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -132,9 +132,10 @@ sub check_opped_timeouts {
|
|||||||
foreach my $channel (keys %{ $self->{is_opped} }) {
|
foreach my $channel (keys %{ $self->{is_opped} }) {
|
||||||
if($self->{is_opped}->{$channel}{timeout} < $now) {
|
if($self->{is_opped}->{$channel}{timeout} < $now) {
|
||||||
$self->lose_ops($channel);
|
$self->lose_ops($channel);
|
||||||
|
delete $self->{is_opped}->{$channel}; # assume chanserv is alive and deop will succeed
|
||||||
} else {
|
} else {
|
||||||
# my $timediff = $is_opped{$channel}{timeout} - $now;
|
# my $timediff = $self->{is_opped}->{$channel}{timeout} - $now;
|
||||||
# $logger->log("deop $channel in $timediff seconds\n");
|
# $self->{pbot}->logger->log("deop $channel in $timediff seconds\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -135,6 +135,10 @@ sub execute_module {
|
|||||||
$self->{pbot}->logger->log("($from): $nick!$user\@$host) sent to $tonick\n");
|
$self->{pbot}->logger->log("($from): $nick!$user\@$host) sent to $tonick\n");
|
||||||
$text = `$module_dir/$module $arguments`;
|
$text = `$module_dir/$module $arguments`;
|
||||||
if(defined $text && length $text > 0) {
|
if(defined $text && length $text > 0) {
|
||||||
|
# get rid of original caller's nick
|
||||||
|
$text =~ s/^\/([^ ]+) \Q$nick\E:\s+/\/$1 /;
|
||||||
|
$text =~ s/^\Q$nick\E:\s+//;
|
||||||
|
|
||||||
return "$tonick: $text";
|
return "$tonick: $text";
|
||||||
} else {
|
} else {
|
||||||
return "";
|
return "";
|
||||||
|
@ -259,7 +259,7 @@ sub interpreter {
|
|||||||
elsif($found == 1) {
|
elsif($found == 1) {
|
||||||
$pbot->logger->log("Found '$original_keyword' as '$fwd_trig' in [$fwd_chan]\n");
|
$pbot->logger->log("Found '$original_keyword' as '$fwd_trig' in [$fwd_chan]\n");
|
||||||
|
|
||||||
return $pbot->factoids->interpreter($from, $nick, $user, $host, $count, $fwd_trig, $arguments, undef, $fwd_chan);
|
return $pbot->factoids->interpreter($from, $nick, $user, $host, $count, $fwd_trig, $arguments, $tonick, $fwd_chan);
|
||||||
}
|
}
|
||||||
# otherwise keyword hasn't been found, display similiar matches for all channels
|
# otherwise keyword hasn't been found, display similiar matches for all channels
|
||||||
else {
|
else {
|
||||||
@ -293,7 +293,7 @@ sub interpreter {
|
|||||||
$self->factoids->hash->{$channel}->{$keyword}->{ref_user} = $nick;
|
$self->factoids->hash->{$channel}->{$keyword}->{ref_user} = $nick;
|
||||||
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_on} = gettimeofday;
|
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_on} = gettimeofday;
|
||||||
|
|
||||||
return $pbot->interpreter->interpret($from, $nick, $user, $host, $count, $command);
|
return $pbot->interpreter->interpret($from, $nick, $user, $host, $count, $command, $tonick);
|
||||||
}
|
}
|
||||||
|
|
||||||
my $last_ref_in = 0;
|
my $last_ref_in = 0;
|
||||||
@ -338,24 +338,7 @@ sub interpreter {
|
|||||||
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_on} = gettimeofday;
|
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_on} = gettimeofday;
|
||||||
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_in} = $from || "stdin";
|
$self->factoids->hash->{$channel}->{$keyword}->{last_referenced_in} = $from || "stdin";
|
||||||
|
|
||||||
if(defined $tonick) { # !tell foo about bar
|
$result = $self->factoids->hash->{$channel}->{$keyword}->{action};
|
||||||
$self->{pbot}->logger->log("($from): $nick!$user\@$host) sent to $tonick\n");
|
|
||||||
my $fromnick = $self->{pbot}->admins->loggedin($from, "$nick!$user\@$host") ? "" : "$nick wants you to know: ";
|
|
||||||
$result = $self->factoids->hash->{$channel}->{$keyword}->{action};
|
|
||||||
|
|
||||||
my $botnick = $self->{pbot}->botnick;
|
|
||||||
|
|
||||||
if($result =~ s/^\/say\s+//i || $result =~ s/^\/me\s+/* $botnick /i
|
|
||||||
|| $result =~ /^\/msg\s+/i) {
|
|
||||||
$result = "/msg $tonick $fromnick$result";
|
|
||||||
} else {
|
|
||||||
$result = "/msg $tonick $fromnick$keyword is $result";
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{pbot}->logger->log("result set to [$result]\n");
|
|
||||||
} else {
|
|
||||||
$result = $self->factoids->hash->{$channel}->{$keyword}->{action};
|
|
||||||
}
|
|
||||||
|
|
||||||
if(length $arguments) {
|
if(length $arguments) {
|
||||||
if(exists $self->factoids->hash->{$channel}->{$keyword}->{action_with_args}) {
|
if(exists $self->factoids->hash->{$channel}->{$keyword}->{action_with_args}) {
|
||||||
@ -378,7 +361,29 @@ sub interpreter {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# no arguments supplied
|
# no arguments supplied
|
||||||
$result =~ s/\$args/$nick/gi;
|
if(defined $tonick) {
|
||||||
|
$result =~ s/\$args/$tonick/gi;
|
||||||
|
} else {
|
||||||
|
$result =~ s/\$args/$nick/gi;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(defined $tonick) { # !tell foo about bar
|
||||||
|
$self->{pbot}->logger->log("($from): $nick!$user\@$host) sent to $tonick\n");
|
||||||
|
my $botnick = $self->{pbot}->botnick;
|
||||||
|
|
||||||
|
# get rid of original caller's nick
|
||||||
|
$result =~ s/^\/([^ ]+) \Q$nick\E:\s+/\/$1 /;
|
||||||
|
$result =~ s/^\Q$nick\E:\s+//;
|
||||||
|
|
||||||
|
if($result =~ s/^\/say\s+//i || $result =~ s/^\/me\s+/* $botnick /i
|
||||||
|
|| $result =~ /^\/msg\s+/i) {
|
||||||
|
$result = "/say $tonick: $result";
|
||||||
|
} else {
|
||||||
|
$result = "/say $tonick: $keyword is $result";
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{pbot}->logger->log("result set to [$result]\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{pbot}->logger->log("(" . (defined $from ? $from : "(undef)") . "): $nick!$user\@$host): $keyword: Displaying text \"" . $result . "\"\n");
|
$self->{pbot}->logger->log("(" . (defined $from ? $from : "(undef)") . "): $nick!$user\@$host): $keyword: Displaying text \"" . $result . "\"\n");
|
||||||
@ -442,7 +447,7 @@ sub interpreter {
|
|||||||
$cmd = $self->factoids->hash->{$channel}->{$keyword}->{action};
|
$cmd = $self->factoids->hash->{$channel}->{$keyword}->{action};
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = $pbot->interpreter->interpret($from, $nick, $user, $host, $count, $cmd);
|
$result = $pbot->interpreter->interpret($from, $nick, $user, $host, $count, $cmd, $tonick);
|
||||||
return $result;
|
return $result;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -106,12 +106,12 @@ sub process_line {
|
|||||||
|
|
||||||
my $preserve_whitespace = 0;
|
my $preserve_whitespace = 0;
|
||||||
|
|
||||||
if($text =~ /^.?$mynick.?\s+(.*?)([?!.]*)$/i) {
|
if($text =~ /^\Q$pbot->{trigger}\E(.*)$/) {
|
||||||
$command = "$1" . (defined $2 and length $2 >= 2 ? substr $2, 1, 1 : "");
|
$command = $1;
|
||||||
} elsif($text =~ /^(.*?),?\s+$mynick([?!.]*)$/i) {
|
} elsif($text =~ /^.?$mynick.?\s+(.*?)$/i) {
|
||||||
$command = "$1" . (defined $2 and length $2 >= 2 ? substr $2, 1, 1 : "");
|
$command = $1;
|
||||||
} elsif($text =~ /^\Q$pbot->{trigger}\E(.*?)([?!.]*)$/) {
|
} elsif($text =~ /^(.*?),?\s+$mynick[?!.]*$/i) {
|
||||||
$command = "$1" . (defined $2 and length $2 >= 2 ? substr $2, 1, 1 : "");
|
$command = $1;
|
||||||
} elsif($text =~ /https?:\/\/([^\s]+)/i) {
|
} elsif($text =~ /https?:\/\/([^\s]+)/i) {
|
||||||
$has_url = $1;
|
$has_url = $1;
|
||||||
} elsif($text =~ /^\s*([^,:\(\)\+\*\/ ]+)[,:]*\s*{\s*(.*)\s*}\s*$/) {
|
} elsif($text =~ /^\s*([^,:\(\)\+\*\/ ]+)[,:]*\s*{\s*(.*)\s*}\s*$/) {
|
||||||
@ -198,8 +198,8 @@ sub process_line {
|
|||||||
|
|
||||||
sub interpret {
|
sub interpret {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($from, $nick, $user, $host, $count, $command) = @_;
|
my ($from, $nick, $user, $host, $count, $command, $tonick) = @_;
|
||||||
my ($keyword, $arguments, $tonick);
|
my ($keyword, $arguments) = ("", "");
|
||||||
my $text;
|
my $text;
|
||||||
my $pbot = $self->pbot;
|
my $pbot = $self->pbot;
|
||||||
|
|
||||||
@ -234,10 +234,14 @@ sub interpret {
|
|||||||
} elsif($command =~ /^(.*?)\s+(.*)$/) {
|
} elsif($command =~ /^(.*?)\s+(.*)$/) {
|
||||||
($keyword, $arguments) = ($1, $2);
|
($keyword, $arguments) = ($1, $2);
|
||||||
} else {
|
} else {
|
||||||
$keyword = $1 if $command =~ /^(.*)$/;
|
$keyword = $command;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($keyword ne "factadd" and $keyword ne "add" and $keyword ne "msg") {
|
||||||
|
$keyword =~ s/(\w+)([?!.]+)$/$1/;
|
||||||
|
$arguments =~ s/(\w+)([?!.]+)$/$1/;
|
||||||
|
$arguments =~ s/(?<![\w\/\-])me\b/$nick/gi if defined $arguments;
|
||||||
}
|
}
|
||||||
|
|
||||||
$arguments =~ s/(?<![\w\/])me\b/$nick/gi if defined $arguments;
|
|
||||||
|
|
||||||
if(defined $arguments && $arguments =~ m/^(your|him|her|its|it|them|their)(self|selves)$/i) {
|
if(defined $arguments && $arguments =~ m/^(your|him|her|its|it|them|their)(self|selves)$/i) {
|
||||||
return "Why would I want to do that to myself?";
|
return "Why would I want to do that to myself?";
|
||||||
|
@ -13,8 +13,8 @@ use warnings;
|
|||||||
# These are set automatically by the build/commit script
|
# These are set automatically by the build/commit script
|
||||||
use constant {
|
use constant {
|
||||||
BUILD_NAME => "PBot",
|
BUILD_NAME => "PBot",
|
||||||
BUILD_REVISION => 378,
|
BUILD_REVISION => 379,
|
||||||
BUILD_DATE => "2012-08-17",
|
BUILD_DATE => "2012-08-23",
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -27,6 +27,7 @@ exit if($arguments =~ m/wiki.osdev.org/i);
|
|||||||
exit if($arguments =~ m/wikipedia.org/i);
|
exit if($arguments =~ m/wikipedia.org/i);
|
||||||
exit if($arguments =~ m/everfall.com/i);
|
exit if($arguments =~ m/everfall.com/i);
|
||||||
exit if($arguments =~ m/\/paste\//i);
|
exit if($arguments =~ m/\/paste\//i);
|
||||||
|
exit if($arguments =~ m/paste\./i);
|
||||||
exit if($arguments =~ m/pastie/i);
|
exit if($arguments =~ m/pastie/i);
|
||||||
exit if($arguments =~ m/ideone.com/i);
|
exit if($arguments =~ m/ideone.com/i);
|
||||||
exit if($arguments =~ m/codepad.org/i);
|
exit if($arguments =~ m/codepad.org/i);
|
||||||
|
@ -12,7 +12,7 @@ $matches = 1;
|
|||||||
|
|
||||||
if ($#ARGV < 0)
|
if ($#ARGV < 0)
|
||||||
{
|
{
|
||||||
print "Usage: !google [number of results] query\n";
|
print "Usage: google [number of results] query\n";
|
||||||
die;
|
die;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user