mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-12 04:52:37 +01:00
Improve handling of interpreter result and module execution
This commit is contained in:
parent
4a110848e9
commit
36b7e1fa6f
@ -38,12 +38,11 @@ sub initialize {
|
|||||||
Carp::croak("Missing pbot reference to PBot::FactoidModuleLauncher");
|
Carp::croak("Missing pbot reference to PBot::FactoidModuleLauncher");
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{child} = 0;
|
|
||||||
$self->{pbot} = $pbot;
|
$self->{pbot} = $pbot;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub execute_module {
|
sub execute_module {
|
||||||
my ($self, $from, $tonick, $nick, $user, $host, $keyword, $arguments) = @_;
|
my ($self, $from, $tonick, $nick, $user, $host, $command, $keyword, $arguments, $preserve_whitespace) = @_;
|
||||||
my $text;
|
my $text;
|
||||||
|
|
||||||
$arguments = "" if not defined $arguments;
|
$arguments = "" if not defined $arguments;
|
||||||
@ -51,7 +50,8 @@ sub execute_module {
|
|||||||
my ($channel, $trigger) = $self->{pbot}->factoids->find_factoid($from, $keyword);
|
my ($channel, $trigger) = $self->{pbot}->factoids->find_factoid($from, $keyword);
|
||||||
|
|
||||||
if(not defined $trigger) {
|
if(not defined $trigger) {
|
||||||
return "/msg $nick Failed to find module for '$keyword' in channel $from\n";
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", "/msg $nick Failed to find module for '$keyword' in channel $from\n", 1, 0);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
my $module = $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{action};
|
my $module = $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{action};
|
||||||
@ -110,16 +110,21 @@ sub execute_module {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pipe(my $reader, my $writer);
|
||||||
my $pid = fork;
|
my $pid = fork;
|
||||||
|
|
||||||
if(not defined $pid) {
|
if(not defined $pid) {
|
||||||
$self->{pbot}->logger->log("Could not fork module: $!\n");
|
$self->{pbot}->logger->log("Could not fork module: $!\n");
|
||||||
return "/me groans loudly.";
|
close $reader;
|
||||||
|
close $writer;
|
||||||
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", "/me groans loudly.\n", 1, 0);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
# FIXME -- add check to ensure $module} exists
|
# FIXME -- add check to ensure $module exists
|
||||||
|
|
||||||
if($pid == 0) { # start child block
|
if($pid == 0) { # start child block
|
||||||
$self->{child} = 1; # set to be killed after returning
|
close $reader;
|
||||||
|
|
||||||
# don't quit the IRC client when the child dies
|
# don't quit the IRC client when the child dies
|
||||||
no warnings;
|
no warnings;
|
||||||
@ -142,25 +147,37 @@ sub execute_module {
|
|||||||
$text =~ s/^\/([^ ]+) \Q$nick\E:\s+/\/$1 /;
|
$text =~ s/^\/([^ ]+) \Q$nick\E:\s+/\/$1 /;
|
||||||
$text =~ s/^\Q$nick\E:\s+//;
|
$text =~ s/^\Q$nick\E:\s+//;
|
||||||
|
|
||||||
return "$tonick: $text";
|
print $writer "$from $tonick: $text\n";
|
||||||
} else {
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", "$tonick: $text", 0, $preserve_whitespace);
|
||||||
return "";
|
|
||||||
}
|
}
|
||||||
|
exit 0;
|
||||||
} else {
|
} else {
|
||||||
if(exists $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{add_nick} and $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{add_nick} != 0) {
|
if(exists $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{add_nick} and $self->{pbot}->factoids->factoids->hash->{$channel}->{$trigger}->{add_nick} != 0) {
|
||||||
return "$nick: $text";
|
print $writer "$from $nick: $text";
|
||||||
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", "$nick: $text", 0, $preserve_whitespace);
|
||||||
} else {
|
} else {
|
||||||
return $text;
|
print $writer "$from $text";
|
||||||
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", $text, 0, $preserve_whitespace);
|
||||||
}
|
}
|
||||||
|
exit 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return "/me moans loudly."; # er, didn't execute the module?
|
# er, didn't execute the module?
|
||||||
|
print $writer "$from /me moans loudly.\n";
|
||||||
|
$self->{pbot}->{interpreter}->handle_result($from, $nick, $user, $host, $command, "$keyword $arguments", "/me moans loudly.", 0, 0);
|
||||||
|
exit 0;
|
||||||
} # end child block
|
} # end child block
|
||||||
else {
|
else {
|
||||||
$self->{child} = 0;
|
close $writer;
|
||||||
|
$self->{pbot}->{select_handler}->add_reader($reader, sub { $self->module_pipe_reader(@_) });
|
||||||
|
return "";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ""; # child returns bot command, not parent -- so return blank/no command
|
sub module_pipe_reader {
|
||||||
|
my ($self, $buf) = @_;
|
||||||
|
my ($channel, $text) = split / /, $buf, 2;
|
||||||
|
$self->{pbot}->antiflood->check_flood($channel, $self->{pbot}->{botnick}, $self->{pbot}->{username}, 'localhost', $text, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -388,7 +388,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";
|
||||||
|
|
||||||
return $ref_from . $self->{factoidmodulelauncher}->execute_module($from, $tonick, $nick, $user, $host, $keyword, $arguments);
|
return $ref_from . $self->{factoidmodulelauncher}->execute_module($from, $tonick, $nick, $user, $host, "$keyword $arguments", $keyword, $arguments, 1);
|
||||||
}
|
}
|
||||||
elsif($self->factoids->hash->{$channel}->{$keyword}->{type} eq 'text') {
|
elsif($self->factoids->hash->{$channel}->{$keyword}->{type} eq 'text') {
|
||||||
$self->{pbot}->logger->log("Found factoid\n");
|
$self->{pbot}->logger->log("Found factoid\n");
|
||||||
|
@ -87,7 +87,7 @@ sub process_line {
|
|||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($from, $nick, $user, $host, $text) = @_;
|
my ($from, $nick, $user, $host, $text) = @_;
|
||||||
|
|
||||||
my ($command, $args, $result);
|
my $command;
|
||||||
my $has_url;
|
my $has_url;
|
||||||
my $has_code;
|
my $has_code;
|
||||||
my $nick_override;
|
my $nick_override;
|
||||||
@ -133,14 +133,23 @@ sub process_line {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(defined $has_url) {
|
if(defined $has_url) {
|
||||||
$result = $self->{pbot}->factoids->{factoidmodulelauncher}->execute_module($from, undef, $nick, $user, $host, "title", "$nick http://$has_url");
|
$self->{pbot}->factoids->{factoidmodulelauncher}->execute_module($from, undef, $nick, $user, $host, $text, "title", "$nick http://$has_url", $preserve_whitespace);
|
||||||
} elsif(defined $has_code) {
|
} elsif(defined $has_code) {
|
||||||
$result = $self->{pbot}->factoids->{factoidmodulelauncher}->execute_module($from, undef, $nick, $user, $host, "compiler_block", (defined $nick_override ? $nick_override : $nick) . " $from $has_code }");
|
$self->{pbot}->factoids->{factoidmodulelauncher}->execute_module($from, undef, $nick, $user, $host, $text, "compiler_block", (defined $nick_override ? $nick_override : $nick) . " $from $has_code }", $preserve_whitespace);
|
||||||
} else {
|
} else {
|
||||||
$result = $self->interpret($from, $nick, $user, $host, 1, $command);
|
$self->handle_result($from, $nick, $user, $host, $text, $command, $self->interpret($from, $nick, $user, $host, 1, $command), 1, $preserve_whitespace);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub handle_result {
|
||||||
|
my ($self, $from, $nick, $user, $host, $text, $command, $result, $checkflood, $preserve_whitespace) = @_;
|
||||||
|
my ($pbot, $mynick) = ($self->{pbot}, $self->{pbot}->{botnick});
|
||||||
|
|
||||||
|
if(not defined $result or length $result == 0) {
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(defined $result && length $result > 0) {
|
|
||||||
my $original_result = $result;
|
my $original_result = $result;
|
||||||
$result =~ s/[\n\r]+/ /g;
|
$result =~ s/[\n\r]+/ /g;
|
||||||
|
|
||||||
@ -166,14 +175,14 @@ sub process_line {
|
|||||||
substr($result, $trunc_len - length $trunc) = $trunc;
|
substr($result, $trunc_len - length $trunc) = $trunc;
|
||||||
}
|
}
|
||||||
|
|
||||||
$pbot->logger->log("Final result: $result\n");
|
$pbot->logger->log("Final result: [$result]\n");
|
||||||
|
|
||||||
if($result =~ s/^\/say\s+//i) {
|
if($result =~ s/^\/say\s+//i) {
|
||||||
$pbot->conn->privmsg($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
$pbot->conn->privmsg($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
||||||
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0);
|
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0) if $checkflood;
|
||||||
} elsif($result =~ s/^\/me\s+//i) {
|
} elsif($result =~ s/^\/me\s+//i) {
|
||||||
$pbot->conn->me($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
$pbot->conn->me($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
||||||
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', '/me ' . $result, 0, 0, 0);
|
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', '/me ' . $result, 0, 0, 0) if $checkflood;
|
||||||
} elsif($result =~ s/^\/msg\s+([^\s]+)\s+//i) {
|
} elsif($result =~ s/^\/msg\s+([^\s]+)\s+//i) {
|
||||||
my $to = $1;
|
my $to = $1;
|
||||||
if($to =~ /,/) {
|
if($to =~ /,/) {
|
||||||
@ -184,27 +193,17 @@ sub process_line {
|
|||||||
}
|
}
|
||||||
elsif($result =~ s/^\/me\s+//i) {
|
elsif($result =~ s/^\/me\s+//i) {
|
||||||
$pbot->conn->me($to, $result) if $to !~ /\Q$mynick\E/i;
|
$pbot->conn->me($to, $result) if $to !~ /\Q$mynick\E/i;
|
||||||
$pbot->antiflood->check_flood($to, $pbot->{botnick}, $pbot->{username}, 'localhost', '/me ' . $result, 0, 0, 0);
|
$pbot->antiflood->check_flood($to, $pbot->{botnick}, $pbot->{username}, 'localhost', '/me ' . $result, 0, 0, 0) if $checkflood;
|
||||||
} else {
|
} else {
|
||||||
$result =~ s/^\/say\s+//i;
|
$result =~ s/^\/say\s+//i;
|
||||||
$pbot->conn->privmsg($to, $result) if $to !~ /\Q$mynick\E/i;
|
$pbot->conn->privmsg($to, $result) if $to !~ /\Q$mynick\E/i;
|
||||||
$pbot->antiflood->check_flood($to, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0);
|
$pbot->antiflood->check_flood($to, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0) if $checkflood;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$pbot->conn->privmsg($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
$pbot->conn->privmsg($from, $result) if defined $from && $from !~ /\Q$mynick\E/i;
|
||||||
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0);
|
$pbot->antiflood->check_flood($from, $pbot->{botnick}, $pbot->{username}, 'localhost', $result, 0, 0, 0) if $checkflood;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
$pbot->logger->log("---------------------------------------------\n");
|
$pbot->logger->log("---------------------------------------------\n");
|
||||||
|
|
||||||
# TODO: move this to FactoidModuleLauncher somehow, completely out of Interpreter!
|
|
||||||
if($pbot->factoids->{factoidmodulelauncher}->{child} != 0) {
|
|
||||||
# if this process is a child, it must die now
|
|
||||||
$pbot->logger->log("Terminating module.\n");
|
|
||||||
exit 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub interpret {
|
sub interpret {
|
||||||
|
@ -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 => 524,
|
BUILD_REVISION => 525,
|
||||||
BUILD_DATE => "2014-03-13",
|
BUILD_DATE => "2014-03-14",
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
Loading…
Reference in New Issue
Block a user