mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-12 21:12:33 +01:00
Fix regex factoids in global namespace not being triggered
This commit is contained in:
parent
750b78cb53
commit
4dbec8001e
@ -772,7 +772,7 @@ sub factfind {
|
|||||||
if($factoids->{$chan}->{$trigger}->{type} eq 'text' or $factoids->{$chan}->{$trigger}->{type} eq 'regex') {
|
if($factoids->{$chan}->{$trigger}->{type} eq 'text' or $factoids->{$chan}->{$trigger}->{type} eq 'regex') {
|
||||||
if($factoids->{$chan}->{$trigger}->{owner} =~ /$owner/i
|
if($factoids->{$chan}->{$trigger}->{owner} =~ /$owner/i
|
||||||
&& $factoids->{$chan}->{$trigger}->{ref_user} =~ /$refby/i
|
&& $factoids->{$chan}->{$trigger}->{ref_user} =~ /$refby/i
|
||||||
&& $factoids->{$chan}->{$trigger}->{edited_by} =~ /$editby/i) {
|
&& (exists $factoids->{$chan}->{$trigger}->{edited_by} ? $factoids->{$chan}->{$trigger}->{edited_by} =~ /$editby/i : 1)) {
|
||||||
next if($arguments ne "" && $factoids->{$chan}->{$trigger}->{action} !~ /$arguments/i && $trigger !~ /$arguments/i);
|
next if($arguments ne "" && $factoids->{$chan}->{$trigger}->{action} !~ /$arguments/i && $trigger !~ /$arguments/i);
|
||||||
|
|
||||||
$i++;
|
$i++;
|
||||||
|
@ -244,18 +244,19 @@ sub find_factoid {
|
|||||||
|
|
||||||
$self->{pbot}->{logger}->log("from: $from\n") if $debug;
|
$self->{pbot}->{logger}->log("from: $from\n") if $debug;
|
||||||
|
|
||||||
my $string = "$keyword" . (defined $arguments ? " $arguments" : "");
|
my $string = $keyword . (defined $arguments ? " $arguments" : "");
|
||||||
|
|
||||||
$self->{pbot}->{logger}->log("string: $string\n") if $debug;
|
$self->{pbot}->{logger}->log("string: $string\n") if $debug;
|
||||||
|
|
||||||
my @result = eval {
|
my @result = eval {
|
||||||
foreach my $channel (sort keys %{ $self->{factoids}->hash }) {
|
foreach my $channel (sort keys %{ $self->{factoids}->hash }) {
|
||||||
if($exact_channel) {
|
if($exact_channel) {
|
||||||
next unless $from eq lc $channel;
|
next unless $from eq lc $channel or $channel eq '.*';
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach my $trigger (keys %{ $self->{factoids}->hash->{$channel} }) {
|
foreach my $trigger (keys %{ $self->{factoids}->hash->{$channel} }) {
|
||||||
if(not $exact_trigger and $self->{factoids}->hash->{$channel}->{$trigger}->{type} eq 'regex') {
|
if(not $exact_trigger and $self->{factoids}->hash->{$channel}->{$trigger}->{type} eq 'regex') {
|
||||||
|
$self->{pbot}->{logger}->log("checking regex $string =~ m/$trigger/i\n") if $debug;
|
||||||
if($string =~ m/$trigger/i) {
|
if($string =~ m/$trigger/i) {
|
||||||
$self->{pbot}->{logger}->log("return regex $channel: $trigger\n") if $debug;
|
$self->{pbot}->{logger}->log("return regex $channel: $trigger\n") if $debug;
|
||||||
return ($channel, $trigger);
|
return ($channel, $trigger);
|
||||||
@ -291,7 +292,7 @@ sub interpreter {
|
|||||||
|
|
||||||
$from = lc $from;
|
$from = lc $from;
|
||||||
|
|
||||||
#$self->{pbot}->{logger}->log("factoids interpreter: from: [$from], ref_from: [" . (defined $ref_from ? $ref_from : "undef") . "]\n");
|
#$self->{pbot}->{logger}->log("factoids interpreter: kw: [$keyword] args: [$arguments] from: [$from], ref_from: [" . (defined $ref_from ? $ref_from : "undef") . "]\n");
|
||||||
|
|
||||||
# search for factoid against global channel and current channel (from unless ref_from is defined)
|
# search for factoid against global channel and current channel (from unless ref_from is defined)
|
||||||
my $original_keyword = $keyword;
|
my $original_keyword = $keyword;
|
||||||
@ -312,15 +313,18 @@ sub interpreter {
|
|||||||
|
|
||||||
# if no match found, attempt to call factoid from another channel if it exists there
|
# if no match found, attempt to call factoid from another channel if it exists there
|
||||||
if(not defined $keyword) {
|
if(not defined $keyword) {
|
||||||
my $chans = "";
|
my $string = "$original_keyword $arguments";
|
||||||
|
my $lc_keyword = lc $original_keyword;
|
||||||
my $comma = "";
|
my $comma = "";
|
||||||
my $found = 0;
|
my $found = 0;
|
||||||
|
my $chans = "";
|
||||||
my ($fwd_chan, $fwd_trig);
|
my ($fwd_chan, $fwd_trig);
|
||||||
|
|
||||||
# build string of which channels contain the keyword, keeping track of the last one and count
|
# build string of which channels contain the keyword, keeping track of the last one and count
|
||||||
foreach my $chan (keys %{ $self->{factoids}->hash }) {
|
foreach my $chan (keys %{ $self->{factoids}->hash }) {
|
||||||
foreach my $trig (keys %{ $self->{factoids}->hash->{$chan} }) {
|
foreach my $trig (keys %{ $self->{factoids}->hash->{$chan} }) {
|
||||||
if(lc $trig eq lc $original_keyword) {
|
my $type = $self->{factoids}->hash->{$chan}->{$trig}->{type};
|
||||||
|
if(($type eq 'text' or $type eq 'module') and lc $trig eq $lc_keyword) {
|
||||||
$chans .= $comma . $chan;
|
$chans .= $comma . $chan;
|
||||||
$comma = ", ";
|
$comma = ", ";
|
||||||
$found++;
|
$found++;
|
||||||
@ -338,7 +342,6 @@ sub interpreter {
|
|||||||
# if there's just one other channel that has this keyword, trigger that instance
|
# if there's just one other channel that has this keyword, trigger that instance
|
||||||
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, $tonick, $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
|
||||||
@ -552,7 +555,7 @@ sub interpreter {
|
|||||||
|
|
||||||
if($@) {
|
if($@) {
|
||||||
$self->{pbot}->{logger}->log("Regex fail: $@\n");
|
$self->{pbot}->{logger}->log("Regex fail: $@\n");
|
||||||
return "/msg $nick $ref_from" . "Fail.";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
return $ref_from . $result;
|
return $ref_from . $result;
|
||||||
|
@ -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 => 790,
|
BUILD_REVISION => 791,
|
||||||
BUILD_DATE => "2014-10-01",
|
BUILD_DATE => "2014-10-13",
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
Loading…
Reference in New Issue
Block a user