mirror of
https://github.com/pragma-/pbot.git
synced 2025-10-14 15:07:22 +02:00
Core/Factoids: properly restore invalid $variable expansions
This commit is contained in:
parent
876d5a88bf
commit
597820c053
@ -61,35 +61,37 @@ sub expand_factoid_vars($self, $context, $action, %opts) {
|
|||||||
while ($rest =~ s/(.*?)(?<!\\)\$([\w|{])/$2/ms) {
|
while ($rest =~ s/(.*?)(?<!\\)\$([\w|{])/$2/ms) {
|
||||||
$result .= $1;
|
$result .= $1;
|
||||||
|
|
||||||
my $var;
|
my ($var, $orig_var);
|
||||||
|
my $modifiers;
|
||||||
my $extract_method;
|
my $extract_method;
|
||||||
|
|
||||||
if ($rest =~ /^\{.*?\}/) {
|
if ($rest =~ /^\{.*?\}/) {
|
||||||
($var, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($rest, '{', '}');
|
($var, $rest) = $self->{pbot}->{interpreter}->extract_bracketed($rest, '{', '}');
|
||||||
|
$orig_var = $var;
|
||||||
|
|
||||||
if ($var =~ /:/) {
|
if ($var =~ /:/) {
|
||||||
my @stuff = split /:/, $var, 2;
|
my @stuff = split /:/, $var, 2;
|
||||||
$var = $stuff[0];
|
$var = $stuff[0];
|
||||||
$rest = ':' . $stuff[1] . $rest;
|
$modifiers = ':' . $stuff[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
$extract_method = 'bracket';
|
$extract_method = 'bracket';
|
||||||
} else {
|
} else {
|
||||||
$rest =~ s/^(\w+)//;
|
$rest =~ s/^(\w+)//;
|
||||||
$var = $1;
|
$var = $orig_var = $1;
|
||||||
$extract_method = 'regex';
|
$extract_method = 'regex';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($var =~ /^(?:_.*|[[:punct:]0-9]+|a|b|nick|channel|randomnick|arglen|args|arg\[.+\])$/i) {
|
if ($var =~ /^(?:_.*|[[:punct:]0-9]+|a|b|nick|channel|randomnick|arglen|args|arg\[.+\])$/i) {
|
||||||
# skip identifiers with leading underscores, etc
|
# skip identifiers with leading underscores, etc
|
||||||
$result .= $extract_method eq 'bracket' ? '${' . $var . '}' : '$' . $var;
|
$result .= $extract_method eq 'bracket' ? '${' . $orig_var . '}' : '$' . $orig_var;
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
$matches++;
|
$matches++;
|
||||||
|
|
||||||
# extract channel expansion modifier
|
# extract channel expansion modifier
|
||||||
if ($rest =~ s/^:(#[^:]+|global)//i) {
|
if ($var =~ s/:(#[^: ]+|global)//i || $rest =~ s/^:(#[^: ]+|global)//i) {
|
||||||
$from = $1;
|
$from = $1;
|
||||||
$from = '.*' if lc $from eq 'global';
|
$from = '.*' if lc $from eq 'global';
|
||||||
}
|
}
|
||||||
@ -101,7 +103,7 @@ sub expand_factoid_vars($self, $context, $action, %opts) {
|
|||||||
my @factoids = $self->{pbot}->{factoids}->{data}->find($from, $var, exact_channel => 2, exact_trigger => 2);
|
my @factoids = $self->{pbot}->{factoids}->{data}->find($from, $var, exact_channel => 2, exact_trigger => 2);
|
||||||
|
|
||||||
if (not @factoids or not $factoids[0]) {
|
if (not @factoids or not $factoids[0]) {
|
||||||
$result .= $extract_method eq 'bracket' ? '${' . $var . '}' : '$' . $var;
|
$result .= $extract_method eq 'bracket' ? '${' . $orig_var . '}' : '$' . $orig_var;
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,13 +115,17 @@ sub expand_factoid_vars($self, $context, $action, %opts) {
|
|||||||
|
|
||||||
if (++$recurse > 100) {
|
if (++$recurse > 100) {
|
||||||
$self->{pbot}->{logger}->log("Factoids: variable expansion recursion limit reached\n");
|
$self->{pbot}->{logger}->log("Factoids: variable expansion recursion limit reached\n");
|
||||||
$result .= $extract_method eq 'bracket' ? '${' . $var . '}' : '$' . $var;
|
$result .= $extract_method eq 'bracket' ? '${' . $orig_var . '}' : '$' . $orig_var;
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
goto ALIAS;
|
goto ALIAS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($modifiers) {
|
||||||
|
$rest = $modifiers . $rest;
|
||||||
|
}
|
||||||
|
|
||||||
my $copy = $rest;
|
my $copy = $rest;
|
||||||
my %settings = $self->{pbot}->{factoids}->{modifiers}->parse(\$copy);
|
my %settings = $self->{pbot}->{factoids}->{modifiers}->parse(\$copy);
|
||||||
|
|
||||||
@ -182,7 +188,7 @@ sub expand_factoid_vars($self, $context, $action, %opts) {
|
|||||||
|
|
||||||
$expansions++;
|
$expansions++;
|
||||||
} else {
|
} else {
|
||||||
$result .= $extract_method eq 'bracket' ? '${' . $var . '}' : '$' . $var;
|
$result .= $extract_method eq 'bracket' ? '${' . $orig_var . '}' : '$' . $orig_var;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 => 4801,
|
BUILD_REVISION => 4803,
|
||||||
BUILD_DATE => "2024-10-15",
|
BUILD_DATE => "2024-10-15",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user