mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-25 19:44:26 +01:00
Factoids: add some error-checking for expansion modifiers
This commit is contained in:
parent
047b2ec4c5
commit
7e2caa58af
@ -456,8 +456,8 @@ sub parse_expansion_modifiers {
|
|||||||
|
|
||||||
my %settings;
|
my %settings;
|
||||||
|
|
||||||
while ($$modifier =~ s/^://) {
|
while ($$modifier =~ s/^:(?=\w)//) {
|
||||||
if ($$modifier =~ s/^join\s*//) {
|
if ($$modifier =~ s/^join\s*(?=\(.*?(?=\)))//) {
|
||||||
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
||||||
$$modifier = $rest;
|
$$modifier = $rest;
|
||||||
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
||||||
@ -475,7 +475,7 @@ sub parse_expansion_modifiers {
|
|||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($$modifier=~ s/^pick_unique\s*//) {
|
if ($$modifier=~ s/^pick_unique\s*(?=\(.*?(?=\)))//) {
|
||||||
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
||||||
$$modifier = $rest;
|
$$modifier = $rest;
|
||||||
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
||||||
@ -487,15 +487,17 @@ sub parse_expansion_modifiers {
|
|||||||
$settings{'random'} = 1;
|
$settings{'random'} = 1;
|
||||||
$settings{'pick_min'} = $args[0];
|
$settings{'pick_min'} = $args[0];
|
||||||
$settings{'pick_max'} = $args[1];
|
$settings{'pick_max'} = $args[1];
|
||||||
} else {
|
} elsif (@args == 1) {
|
||||||
$settings{'pick_min'} = 1;
|
$settings{'pick_min'} = 1;
|
||||||
$settings{'pick_max'} = $args[0];
|
$settings{'pick_max'} = $args[0];
|
||||||
|
} else {
|
||||||
|
push @{$settings{errors}}, "pick_unique(): missing argument(s)";
|
||||||
}
|
}
|
||||||
|
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($$modifier=~ s/^pick\s*//) {
|
if ($$modifier=~ s/^pick\s*(?=\(.*?(?=\)))//) {
|
||||||
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
||||||
$$modifier = $rest;
|
$$modifier = $rest;
|
||||||
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
||||||
@ -506,25 +508,35 @@ sub parse_expansion_modifiers {
|
|||||||
$settings{'random'} = 1;
|
$settings{'random'} = 1;
|
||||||
$settings{'pick_min'} = $args[0];
|
$settings{'pick_min'} = $args[0];
|
||||||
$settings{'pick_max'} = $args[1];
|
$settings{'pick_max'} = $args[1];
|
||||||
} else {
|
} elsif (@args == 1) {
|
||||||
$settings{'pick_min'} = 1;
|
$settings{'pick_min'} = 1;
|
||||||
$settings{'pick_max'} = $args[0];
|
$settings{'pick_max'} = $args[0];
|
||||||
|
} else {
|
||||||
|
push @{$settings{errors}}, "pick(): missing argument(s)";
|
||||||
}
|
}
|
||||||
|
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($$modifier=~ s/^index\s*//) {
|
if ($$modifier=~ s/^index\s*(?=\(.*?(?=\)))//) {
|
||||||
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
my ($params, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($$modifier, '(', ')', '', 1);
|
||||||
$$modifier = $rest;
|
$$modifier = $rest;
|
||||||
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
my @args = $self->{pbot}->{interpreter}->split_line($params, strip_quotes => 1, strip_commas => 1);
|
||||||
$settings{'index'} = $args[0];
|
if (@args == 1) {
|
||||||
|
$settings{'index'} = $args[0];
|
||||||
|
} else {
|
||||||
|
push @{$settings{errors}}, "index(): missing argument";
|
||||||
|
}
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
# catch-all for any word modifier
|
if ($$modifier =~ s/^(enumerate|comma|uc|lc|ucfirst|title)//) {
|
||||||
if ($$modifier =~ s/^(\w+)//) {
|
|
||||||
$settings{$1} = 1;
|
$settings{$1} = 1;
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($$modifier =~ s/^(\w+)//) {
|
||||||
|
push @{$settings{errors}}, "Unknown modifier `$1`";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,6 +624,10 @@ sub select_item {
|
|||||||
|
|
||||||
my %settings = $self->parse_expansion_modifiers($modifier);
|
my %settings = $self->parse_expansion_modifiers($modifier);
|
||||||
|
|
||||||
|
if (exists $settings{errors}) {
|
||||||
|
return "[Error: " . join ('; ', @{$settings{errors}}) . ']';
|
||||||
|
}
|
||||||
|
|
||||||
my $item;
|
my $item;
|
||||||
|
|
||||||
if (exists $settings{'index'}) {
|
if (exists $settings{'index'}) {
|
||||||
@ -650,7 +666,6 @@ sub select_item {
|
|||||||
|
|
||||||
my $choice = $self->select_weighted_item_from_list($list);
|
my $choice = $self->select_weighted_item_from_list($list);
|
||||||
|
|
||||||
|
|
||||||
push @choices, $choice;
|
push @choices, $choice;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user