mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-25 19:44:26 +01:00
Spinach categories can now be filtered
This commit is contained in:
parent
2afeb697eb
commit
85841ea45c
@ -215,7 +215,7 @@ sub spinach_cmd {
|
|||||||
my ($self, $from, $nick, $user, $host, $arguments) = @_;
|
my ($self, $from, $nick, $user, $host, $arguments) = @_;
|
||||||
$arguments =~ s/^\s+|\s+$//g;
|
$arguments =~ s/^\s+|\s+$//g;
|
||||||
|
|
||||||
my $usage = "Usage: spinach join|exit|ready|unready|choose|lie|reroll|skip|score|show|kick|abort; for more information about a command: spinach help <command>";
|
my $usage = "Usage: spinach join|exit|ready|unready|choose|lie|reroll|skip|score|show|categories|filter|kick|abort; for more information about a command: spinach help <command>";
|
||||||
|
|
||||||
my $command;
|
my $command;
|
||||||
($command, $arguments) = split / /, $arguments, 2;
|
($command, $arguments) = split / /, $arguments, 2;
|
||||||
@ -283,6 +283,14 @@ sub spinach_cmd {
|
|||||||
}
|
}
|
||||||
|
|
||||||
when ('show') {
|
when ('show') {
|
||||||
|
return "Show the current question again.";
|
||||||
|
}
|
||||||
|
|
||||||
|
when ('categories') {
|
||||||
|
return "Help is coming soon.";
|
||||||
|
}
|
||||||
|
|
||||||
|
when ('filter') {
|
||||||
return "Help is coming soon.";
|
return "Help is coming soon.";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -751,6 +759,76 @@ sub spinach_cmd {
|
|||||||
return "$nick: There is nothing to show right now.";
|
return "$nick: There is nothing to show right now.";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
when ('categories') {
|
||||||
|
if (not length $arguments) {
|
||||||
|
return "Usage: spinach categories <regex>";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $result = eval {
|
||||||
|
use re::engine::RE2 -strict => 1;
|
||||||
|
my @categories = grep { /$arguments/i } keys %{$self->{categories}};
|
||||||
|
if (not @categories) {
|
||||||
|
return "No categories found.";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $text = "";
|
||||||
|
my $comma = "";
|
||||||
|
foreach my $cat (sort @categories) {
|
||||||
|
$text .= "$comma$cat: " . keys %{$self->{categories}{$cat}};
|
||||||
|
$comma = ", ";
|
||||||
|
}
|
||||||
|
return $text;
|
||||||
|
};
|
||||||
|
|
||||||
|
return "$arguments: $@" if $@;
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
when ('filter') {
|
||||||
|
my ($cmd, $args) = split / /, $arguments, 2;
|
||||||
|
$cmd = lc $cmd;
|
||||||
|
|
||||||
|
if (not length $cmd) {
|
||||||
|
return "Usage: spinach filter set <regex> | show | clear";
|
||||||
|
}
|
||||||
|
|
||||||
|
given ($cmd) {
|
||||||
|
when ('set') {
|
||||||
|
if (not length $args) {
|
||||||
|
return "Usage: spinach filter set <regex>";
|
||||||
|
}
|
||||||
|
|
||||||
|
eval { "" =~ /$args/ };
|
||||||
|
return "Bad filter $args: $@" if $@;
|
||||||
|
|
||||||
|
my @categories = grep { /$args/i } keys %{$self->{categories}};
|
||||||
|
if (not @categories) {
|
||||||
|
return "Bad filter: No categories match. Try again.";
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{category_filter} = $args;
|
||||||
|
return "Spinach filter set.";
|
||||||
|
}
|
||||||
|
|
||||||
|
when ('clear') {
|
||||||
|
delete $self->{category_filter};
|
||||||
|
return "Spinach filter cleared.";
|
||||||
|
}
|
||||||
|
|
||||||
|
when ('show') {
|
||||||
|
if (not exists $self->{category_filter}) {
|
||||||
|
return "There is no Spinach filter set.";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "Spinach filter set to: " . $self->{category_filter};
|
||||||
|
}
|
||||||
|
|
||||||
|
default {
|
||||||
|
return "Unknown filter command '$cmd'.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
default {
|
default {
|
||||||
return $usage;
|
return $usage;
|
||||||
}
|
}
|
||||||
@ -1372,7 +1450,13 @@ sub choosecategory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
my @choices;
|
my @choices;
|
||||||
my @categories = keys %{$self->{categories}};
|
my @categories;
|
||||||
|
|
||||||
|
if (exists $self->{category_filter}) {
|
||||||
|
@categories = grep { /$self->{category_filter}/i } keys %{$self->{categories}};
|
||||||
|
} else {
|
||||||
|
@categories = keys %{$self->{categories}};
|
||||||
|
}
|
||||||
|
|
||||||
my $no_infinite_loops = 0;
|
my $no_infinite_loops = 0;
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -1391,7 +1475,7 @@ sub choosecategory {
|
|||||||
push @choices, $cat;
|
push @choices, $cat;
|
||||||
}
|
}
|
||||||
|
|
||||||
last if @choices == 6;
|
last if @choices == 7;
|
||||||
}
|
}
|
||||||
|
|
||||||
push @choices, 'RANDOM CATEGORY';
|
push @choices, 'RANDOM CATEGORY';
|
||||||
@ -1966,7 +2050,7 @@ sub getplayers {
|
|||||||
$state->{tocked} = 1;
|
$state->{tocked} = 1;
|
||||||
|
|
||||||
if (not $unready) {
|
if (not $unready) {
|
||||||
$self->send_message($self->{channel}, "Game cannot begin with only one player.");
|
$self->send_message($self->{channel}, "Game cannot begin with one player.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (++$state->{counter} > 6) {
|
if (++$state->{counter} > 6) {
|
||||||
|
Loading…
Reference in New Issue
Block a user