3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-23 10:34:52 +01:00

Factoids: variable modifiers such as :ucfirst now pass through to replacements

This commit is contained in:
Pragmatic Software 2019-06-07 13:16:54 -07:00
parent 8f35fa3430
commit 5d1310adb3

View File

@ -430,18 +430,24 @@ sub expand_factoid_vars {
my ($a, $v) = ($1, $2); my ($a, $v) = ($1, $2);
$a = '' if not defined $a; $a = '' if not defined $a;
next if not defined $v; next if not defined $v;
$v =~ s/(.):$/$1/; # remove trailing : only if at least one character precedes it
next if $v =~ m/^_/; # special character prefix skipped for shell/code-factoids/etc my $original_v = $v;
next if $v =~ m/^(?:nick|channel|randomnick|arglen|args|arg\[.+\]|[_0])(?:\:json)*$/i; # don't override special variables my $test_v = $v;
next if @exclude && grep { $v =~ m/^\Q$_\E$/i } @exclude;
$test_v =~ s/(.):$/$1/; # remove trailing : only if at least one character precedes it
next if $test_v =~ m/^_/; # special character prefix skipped for shell/code-factoids/etc
next if $test_v =~ m/^(?:nick|channel|randomnick|arglen|args|arg\[.+\]|[_0])(?:\:json)*$/i; # don't override special variables
next if @exclude && grep { $test_v =~ m/^\Q$_\E$/i } @exclude;
last if ++$depth >= 1000; last if ++$depth >= 1000;
$self->{pbot}->{logger}->log("v: [$v]\n") if $debug; $self->{pbot}->{logger}->log("v: [$original_v], test v: [$test_v]\n") if $debug;
$matches++; $matches++;
$test_v =~ s/\{(.+)\}/$1/;
my $modifier = ''; my $modifier = '';
if ($v =~ s/(:.*)$//) { if ($test_v =~ s/(:.*)$//) {
$modifier = $1; $modifier = $1;
} }
@ -451,8 +457,6 @@ sub expand_factoid_vars {
} }
my $recurse = 0; my $recurse = 0;
my $test_v = $v;
$test_v =~ s/\{(.+)\}/$1/;
ALIAS: ALIAS:
my @factoids = $self->find_factoid($from, $test_v, undef, 2, 2); my @factoids = $self->find_factoid($from, $test_v, undef, 2, 2);
next if not @factoids or not $factoids[0]; next if not @factoids or not $factoids[0];
@ -478,6 +482,22 @@ sub expand_factoid_vars {
} }
foreach my $mod (split /:/, $modifier) { foreach my $mod (split /:/, $modifier) {
next if not length $mod;
if ($mylist[$line] =~ /^\$\{\$([a-zA-Z0-9_:#]+)\}(.*)$/) {
$mylist[$line] = "\${\$$1:$mod}$2";
next;
} elsif ($mylist[$line] =~ /^\$\{([a-zA-Z0-9_:#]+)\}(.*)$/) {
$mylist[$line] = "\${$1:$mod}$2";
next;
} elsif ($mylist[$line] =~ /^\$\$([a-zA-Z0-9_:#]+)(.*)$/) {
$mylist[$line] = "\${\$$1:$mod}$2";
next;
} elsif ($mylist[$line] =~ /^\$([a-zA-Z0-9_:#]+)(.*)$/) {
$mylist[$line] = "\${$1:$mod}$2";
next;
}
given ($mod) { given ($mod) {
when ('uc') { when ('uc') {
$mylist[$line] = uc $mylist[$line]; $mylist[$line] = uc $mylist[$line];
@ -507,17 +527,18 @@ sub expand_factoid_vars {
$self->{pbot}->{logger}->log(("-" x 40) . "\n"); $self->{pbot}->{logger}->log(("-" x 40) . "\n");
} }
$v = quotemeta $v; $original_v = quotemeta $original_v;
$original_v =~ s/\\:/:/g;
if (not length $mylist[$line]) { if (not length $mylist[$line]) {
$self->{pbot}->{logger}->log("No length!\n") if $debug; $self->{pbot}->{logger}->log("No length!\n") if $debug;
if ($debug) { if ($debug) {
$self->{pbot}->{logger}->log("before: v: $v, offset: $offset\n"); $self->{pbot}->{logger}->log("before: v: $original_v, offset: $offset\n");
$self->{pbot}->{logger}->log("$action\n"); $self->{pbot}->{logger}->log("$action\n");
$self->{pbot}->{logger}->log((" " x $offset) . "^\n"); $self->{pbot}->{logger}->log((" " x $offset) . "^\n");
} }
substr($action, $offset) =~ s/\s*$a\$$v$modifier//; substr($action, $offset) =~ s/\s*$a\$$original_v//;
$offset += $-[0]; $offset += $-[0];
if ($debug) { if ($debug) {
@ -527,12 +548,12 @@ sub expand_factoid_vars {
} }
} else { } else {
if ($debug) { if ($debug) {
$self->{pbot}->{logger}->log("before: v: $v, offset: $offset\n"); $self->{pbot}->{logger}->log("before: v: $original_v, offset: $offset\n");
$self->{pbot}->{logger}->log("$action\n"); $self->{pbot}->{logger}->log("$action\n");
$self->{pbot}->{logger}->log((" " x $offset) . "^\n"); $self->{pbot}->{logger}->log((" " x $offset) . "^\n");
} }
substr($action, $offset) =~ s/$a\$$v$modifier/$mylist[$line]/; substr($action, $offset) =~ s/$a\$$original_v/$mylist[$line]/;
$offset += $-[0] + length $mylist[$line]; $offset += $-[0] + length $mylist[$line];
if ($debug) { if ($debug) {