3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-22 18:14:48 +01:00

Remove add_nick mess from ProcessManager

This commit is contained in:
Pragmatic Software 2021-07-27 21:27:03 -07:00
parent 8cff244256
commit 59140d4096
5 changed files with 23 additions and 47 deletions

View File

@ -97,7 +97,7 @@ sub get_meta {
} }
# main entry point for PBot::Core::Interpreter to interpret a registered bot command # main entry point for PBot::Core::Interpreter to interpret a registered bot command
# see also PBot::Core::Factoids::interpreter() for factoid commands # see also PBot::Core::Factoids::Interpreter for factoid commands
sub interpreter { sub interpreter {
my ($self, $context) = @_; my ($self, $context) = @_;
@ -168,6 +168,11 @@ sub interpreter {
$context->{preserve_whitespace} = 1; $context->{preserve_whitespace} = 1;
} }
# tell PBot::Core::Interpreter to prepend caller's nick to output
if ($self->get_meta($keyword, 'add_nick')) {
$context->{add_nick} = 1;
}
unless ($self->get_meta($keyword, 'dont-replace-pronouns')) { unless ($self->get_meta($keyword, 'dont-replace-pronouns')) {
$context->{arguments} = $self->{pbot}->{factoids}->{variables}->expand_factoid_vars($context, $context->{arguments}); $context->{arguments} = $self->{pbot}->{factoids}->{variables}->expand_factoid_vars($context, $context->{arguments});
$context->{arglist} = $self->{pbot}->{interpreter}->make_args($context->{arguments}); $context->{arglist} = $self->{pbot}->{interpreter}->make_args($context->{arguments});

View File

@ -219,6 +219,11 @@ sub interpreter {
return $usage; return $usage;
} }
# tell PBot::Core::Interpreter to prepend caller's nick to output
if ($self->{pbot}->{factoids}->{data}->{storage}->get_data($channel, $keyword, 'add_nick')) {
$context->{add_nick} = 1;
}
# factoid action # factoid action
my $action; my $action;

View File

@ -890,15 +890,21 @@ sub output_result {
if ($context->{nickprefix} && (! $context->{nickprefix_disabled} || $context->{nickprefix_forced})) { if ($context->{nickprefix} && (! $context->{nickprefix_disabled} || $context->{nickprefix_forced})) {
$output = "$context->{nickprefix}: $output"; $output = "$context->{nickprefix}: $output";
} }
elsif ($context->{add_nick}) {
$output = "$context->{nick}: $output";
}
# send the message to the channel/user # send the message to the channel/user
$self->{pbot}->{conn}->privmsg($to, $output); $self->{pbot}->{conn}->privmsg($to, $output);
} }
elsif ($type eq 'action') { elsif ($type eq 'action') {
# append nickprefix to output # append nickprefix to output
if ($context->{nickprefix} && (! $context->{nickprefix_disabled} || $context->{nickprefix_forced})) { #
$output = "$output (for $context->{nickprefix})"; # TODO: probably going to remove this code.
} #
# if ($context->{nickprefix} && (! $context->{nickprefix_disabled} || $context->{nickprefix_forced})) {
# $output = "$output (for $context->{nickprefix})";
# }
# CTCP ACTION the message to the channel/user # CTCP ACTION the message to the channel/user
$self->{pbot}->{conn}->me($to, $output); $self->{pbot}->{conn}->me($to, $output);

View File

@ -109,7 +109,7 @@ sub execute_process {
# execute the provided subroutine, results are stored in $context # execute the provided subroutine, results are stored in $context
eval { eval {
local $SIG{ALRM} = sub { die "Process `$context->{commands}->[0]` timed-out" }; local $SIG{ALRM} = sub { die "Process `$context->{commands}->[0]` timed-out\n" };
alarm $timeout; alarm $timeout;
$subref->($context); $subref->($context);
alarm 0; alarm 0;
@ -119,13 +119,9 @@ sub execute_process {
if ($@) { if ($@) {
$context->{result} = $@; $context->{result} = $@;
$context->{'timed-out'} = 1 if $context->{result} =~ /^Process .* timed-out at PBot\/ProcessManager/; $context->{'timed-out'} = 1 if $context->{result} =~ /^Process .* timed-out/;
$self->{pbot}->{logger}->log("Error executing process: $context->{result}\n"); $self->{pbot}->{logger}->log("Error executing process: $context->{result}\n");
# strip internal PBot source data for IRC output
$context->{result} =~ s/ at PBot.*$//ms;
$context->{result} =~ s/\s+...propagated at .*$//ms;
} }
# print $context to pipe # print $context to pipe
@ -189,42 +185,6 @@ sub process_pipe_reader {
$context->{result} = $self->{pbot}->{factoids}->{interpreter}->handle_action($context, $context->{result}); $context->{result} = $self->{pbot}->{factoids}->{interpreter}->handle_action($context, $context->{result});
} }
# if nick isn't overridden yet, check for a potential nick prefix
# TODO: this stuff should be moved to Interpreter::output_result
if (not $context->{nickprefix}) {
$context->{trigger} //= '';
# if add_nick is set on the factoid, set the nick override to the caller's nick
if (exists $context->{special} and $context->{special} ne 'code-factoid'
and $self->{pbot}->{factoids}->{data}->{storage}->exists($context->{channel}, $context->{trigger}, 'add_nick')
and $self->{pbot}->{factoids}->{data}->{storage}->get_data($context->{channel}, $context->{trigger}, 'add_nick') != 0)
{
$context->{nickprefix} = $context->{nick};
$context->{nickprefix_disabled} = 0;
$context->{nickprefix_forced} = 1;
} else {
# extract nick-like thing from process result
if ($context->{result} =~ s/^(\S+): //) {
my $nick = $1;
if (lc $nick eq "usage") {
# put it back on result if it's a usage message
$context->{result} = "$nick: $context->{result}";
} else {
my $present = $self->{pbot}->{nicklist}->is_present($context->{channel}, $nick);
if ($present) {
# nick is present in channel
$context->{nickprefix} = $present;
} else {
# nick not present, put it back on result
$context->{result} = "$nick: $context->{result}";
}
}
}
}
}
# send the result off to the bot to be handled # send the result off to the bot to be handled
$context->{checkflood} = 1; $context->{checkflood} = 1;
$self->{pbot}->{interpreter}->handle_result($context); $self->{pbot}->{interpreter}->handle_result($context);

View File

@ -22,7 +22,7 @@ package PBot::VERSION;
# These are set by the /misc/update_version script # These are set by the /misc/update_version script
use constant { use constant {
BUILD_NAME => "PBot", BUILD_NAME => "PBot",
BUILD_REVISION => 4318, BUILD_REVISION => 4319,
BUILD_DATE => "2021-07-27", BUILD_DATE => "2021-07-27",
}; };