3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-25 19:44:26 +01:00

Interpreter: find factoid channel for dont-replace-pronouns metadata

This commit is contained in:
Pragmatic Software 2021-07-28 18:05:14 -07:00
parent 12cedcd60e
commit 7c4c5847ab
3 changed files with 27 additions and 11 deletions

View File

@ -129,7 +129,7 @@ sub find {
my $debug = 0; my $debug = 0;
$from = '.*' if not defined $from or $from !~ /^#/; $from = '.*' if $from !~ /^#/;
$from = lc $from; $from = lc $from;
$keyword = lc $keyword; $keyword = lc $keyword;
@ -138,9 +138,12 @@ sub find {
my @result = eval { my @result = eval {
my @results; my @results;
my ($channel, $trigger); my ($channel, $trigger);
for (my $depth = 0; $depth < 15; $depth++) { for (my $depth = 0; $depth < 15; $depth++) {
my $action; my $action;
my $string = $keyword . (length $arguments ? " $arguments" : ''); my $string = $keyword . (length $arguments ? " $arguments" : '');
$self->{pbot}->{logger}->log("string: $string\n") if $debug; $self->{pbot}->{logger}->log("string: $string\n") if $debug;
if ($opts{exact_channel} and $opts{exact_trigger}) { if ($opts{exact_channel} and $opts{exact_trigger}) {
@ -187,6 +190,7 @@ sub find {
CHECK_ALIAS: CHECK_ALIAS:
if ($opts{find_alias}) { if ($opts{find_alias}) {
$action = $self->{storage}->get_data($channel, $trigger, 'action') if not defined $action; $action = $self->{storage}->get_data($channel, $trigger, 'action') if not defined $action;
if ($action =~ m{^/call\s+(.*)$}ms) { if ($action =~ m{^/call\s+(.*)$}ms) {
my $command; my $command;
if (length $arguments) { if (length $arguments) {
@ -233,8 +237,11 @@ sub find {
goto NEXT_DEPTH; goto NEXT_DEPTH;
} }
if ($opts{exact_channel} == 1) { return ($channel, $trigger); } if ($opts{exact_channel} == 1) {
else { push @results, [$channel, $trigger]; } return ($channel, $trigger);
} else {
push @results, [$channel, $trigger];
}
} }
} }
} }
@ -247,11 +254,13 @@ sub find {
} }
if ($debug) { if ($debug) {
if (not @results) { $self->{pbot}->{logger}->log("Factoids: find: no match\n"); } if (not @results) {
else { $self->{pbot}->{logger}->log("Factoids: find: no match\n");
} else {
$self->{pbot}->{logger}->log("Factoids: find: got results: " . (join ', ', map { "$_->[0] -> $_->[1]" } @results) . "\n"); $self->{pbot}->{logger}->log("Factoids: find: got results: " . (join ', ', map { "$_->[0] -> $_->[1]" } @results) . "\n");
} }
} }
return @results; return @results;
}; };

View File

@ -416,20 +416,27 @@ sub interpret {
# unescape any escaped pipes # unescape any escaped pipes
$arguments =~ s/\\\|\s*\{/| {/g; $arguments =~ s/\\\|\s*\{/| {/g;
my $from = $context->{from}; # find factoid channel for dont-replace-pronouns metadata
my ($fact_channel, $fact_trigger);
my @factoids = $self->{pbot}->{factoids}->{data}->find($context->{from}, $keyword, exact_trigger => 1);
$from = '.*' unless $from =~ /^#/; if (@factoids == 1) {
# found the factoid's channel
($fact_channel, $fact_trigger) = $factoids[0];
} else {
# more than one factoid found, normally we would prompt to disambiguate
# but in this case we'll just go ahead and assume global
($fact_channel, $fact_trigger) = ('.*', $keyword);
}
if ($self->{pbot}->{commands}->get_meta($keyword, 'dont-replace-pronouns') if ($self->{pbot}->{commands}->get_meta($keyword, 'dont-replace-pronouns')
or $self->{pbot}->{factoids}->{data}->get_meta($from, $keyword, 'dont-replace-pronouns')) or $self->{pbot}->{factoids}->{data}->get_meta($fact_channel, $fact_trigger, 'dont-replace-pronouns'))
{ {
$context->{'dont-replace-pronouns'} = 1; $context->{'dont-replace-pronouns'} = 1;
} }
# replace pronouns like "i", "my", etc, with "nick", "nick's", etc # replace pronouns like "i", "my", etc, with "nick", "nick's", etc
if (not $context->{'dont-replace-pronouns'}) { if (not $context->{'dont-replace-pronouns'}) {
$self->{pbot}->{logger}->log("Replacing pronouns for $context->{from}.$keyword\n");
# if command recipient is "me" then replace it with invoker's nick # if command recipient is "me" then replace it with invoker's nick
# e.g., "!tell me about date" or "!give me date", etc # e.g., "!tell me about date" or "!give me date", etc
if (defined $context->{nickprefix} and lc $context->{nickprefix} eq 'me') { if (defined $context->{nickprefix} and lc $context->{nickprefix} eq 'me') {

View File

@ -25,7 +25,7 @@ use PBot::Imports;
# 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 => 4325, BUILD_REVISION => 4326,
BUILD_DATE => "2021-07-28", BUILD_DATE => "2021-07-28",
}; };