mirror of
https://github.com/pragma-/pbot.git
synced 2024-12-31 23:22:37 +01:00
Improved find command by adding optional -owner and -by search parameters
This commit is contained in:
parent
a743261059
commit
21e4415289
@ -9,9 +9,9 @@
|
|||||||
#
|
#
|
||||||
# TODO: Ignorelist needs to save and load from file, use regex hash keys/search parameters.
|
# TODO: Ignorelist needs to save and load from file, use regex hash keys/search parameters.
|
||||||
#
|
#
|
||||||
# 0.6.2-beta (03/25/10): 'list messages' command significant improved -- can use regexs search parameters.
|
# 0.6.3-beta (03/26/10): Improved !find command by adding optional -owner and -by search parameters.
|
||||||
|
# 0.6.2-beta (03/25/10): 'list messages' command significantly improved -- can use regexs search parameters.
|
||||||
# Added optional regex search to 'rq' quotegrab command to match against quotegrab text.
|
# Added optional regex search to 'rq' quotegrab command to match against quotegrab text.
|
||||||
# Channel chat messages easier to read in log (from anti-flood module).
|
|
||||||
# 0.6.1-beta (03/23/10): Quotegrab ids properly adjusted when deleting quotegrab.
|
# 0.6.1-beta (03/23/10): Quotegrab ids properly adjusted when deleting quotegrab.
|
||||||
# Admins loads from file, uses regex hash keys.
|
# Admins loads from file, uses regex hash keys.
|
||||||
# Lots of misc tweaks and improvements throughout.
|
# Lots of misc tweaks and improvements throughout.
|
||||||
|
@ -265,7 +265,7 @@ sub histogram {
|
|||||||
$i++;
|
$i++;
|
||||||
last if $i >= 10;
|
last if $i >= 10;
|
||||||
}
|
}
|
||||||
return "$factoid_count factoid_count, top 10 submitters: $text";
|
return "$factoid_count factoids, top 10 submitters: $text";
|
||||||
}
|
}
|
||||||
|
|
||||||
sub show {
|
sub show {
|
||||||
@ -422,35 +422,77 @@ sub find {
|
|||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($from, $nick, $user, $host, $arguments) = @_;
|
my ($from, $nick, $user, $host, $arguments) = @_;
|
||||||
my $factoids = $self->{pbot}->factoids->factoids;
|
my $factoids = $self->{pbot}->factoids->factoids;
|
||||||
my $i = 0;
|
|
||||||
my $text;
|
my $text;
|
||||||
my $type;
|
my $type;
|
||||||
|
|
||||||
foreach my $command (sort keys %{ $factoids }) {
|
if(not defined $arguments) {
|
||||||
if(exists $factoids->{$command}{text} || exists $factoids->{$command}{regex}) {
|
return "/msg $nick Usage: !find [-owner nick] [-by nick] [text]";
|
||||||
$type = 'text' if(exists $factoids->{$command}{text});
|
}
|
||||||
$type = 'regex' if(exists $factoids->{$command}{regex});
|
|
||||||
# $self->{pbot}->logger->log("Checking [$command], type: [$type]\n");
|
my ($owner, $by);
|
||||||
eval {
|
|
||||||
my $regex = qr/$arguments/;
|
$owner = $1 if $arguments =~ s/-owner\s+([^\b\s]+)//i;
|
||||||
if($factoids->{$command}{$type} =~ /$regex/i || $command =~ /$regex/i)
|
$by = $1 if $arguments =~ s/-by\s+([^\b\s]+)//i;
|
||||||
{
|
|
||||||
$i++;
|
$owner = '.*' if not defined $owner;
|
||||||
$text .= "$command ";
|
$by = '.*' if not defined $by;
|
||||||
}
|
|
||||||
};
|
$arguments =~ s/^\s+//;
|
||||||
return "/msg $nick $arguments: $@" if $@;
|
$arguments =~ s/\s+$//;
|
||||||
|
$arguments =~ s/\s+/ /g;
|
||||||
|
|
||||||
|
my $argtype = undef;
|
||||||
|
|
||||||
|
if($owner ne '.*') {
|
||||||
|
$argtype = "owned by $owner";
|
||||||
|
}
|
||||||
|
|
||||||
|
if($by ne '.*') {
|
||||||
|
if(not defined $argtype) {
|
||||||
|
$argtype = "last referenced by $by";
|
||||||
|
} else {
|
||||||
|
$argtype .= " and last referenced by $by";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($arguments ne "") {
|
||||||
|
if(not defined $argtype) {
|
||||||
|
$argtype = "with text matching '$arguments'";
|
||||||
|
} else {
|
||||||
|
$argtype .= " and with text matching '$arguments'";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(not defined $argtype) {
|
||||||
|
return "/msg $nick Usage: !find [-owner nick] [-by nick] [text]";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $i = 0;
|
||||||
|
eval {
|
||||||
|
foreach my $command (sort keys %{ $factoids }) {
|
||||||
|
if(exists $factoids->{$command}{text} || exists $factoids->{$command}{regex}) {
|
||||||
|
$type = 'text' if(exists $factoids->{$command}{text});
|
||||||
|
$type = 'regex' if(exists $factoids->{$command}{regex});
|
||||||
|
|
||||||
|
if($factoids->{$command}{owner} =~ /$owner/i && $factoids->{$command}{ref_user} =~ /$by/i) {
|
||||||
|
next if($arguments ne "" && $factoids->{$command}{$type} !~ /$arguments/i && $command !~ /$arguments/i);
|
||||||
|
$i++;
|
||||||
|
$text .= "$command ";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return "/msg $nick $arguments: $@" if $@;
|
||||||
|
|
||||||
if($i == 1) {
|
if($i == 1) {
|
||||||
chop $text;
|
chop $text;
|
||||||
$type = 'text' if exists $factoids->{$text}{text};
|
$type = 'text' if exists $factoids->{$text}{text};
|
||||||
$type = 'regex' if exists $factoids->{$text}{regex};
|
$type = 'regex' if exists $factoids->{$text}{regex};
|
||||||
return "found one match: '$text' is '$factoids->{$text}{$type}'";
|
return "found one factoid " . $argtype . ": '$text' is '$factoids->{$text}{$type}'";
|
||||||
} else {
|
} else {
|
||||||
return "$i factoids contain '$arguments': $text" unless $i == 0;
|
return "$i factoids " . $argtype . ": $text" unless $i == 0;
|
||||||
return "No factoids contain '$arguments'";
|
return "No factoids " . $argtype;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,7 +9,7 @@ use strict;
|
|||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
use vars qw($VERSION);
|
use vars qw($VERSION);
|
||||||
$VERSION = "0.6.2-beta";
|
$VERSION = "0.6.3-beta";
|
||||||
|
|
||||||
# unbuffer stdout
|
# unbuffer stdout
|
||||||
STDOUT->autoflush(1);
|
STDOUT->autoflush(1);
|
||||||
|
Loading…
Reference in New Issue
Block a user