[Rt-commit] rt branch, 4.4/copy-lifecycle-before-modify, created. rt-4.4.3-19-g068cc2e51
Jim Brandt
jbrandt at bestpractical.com
Thu Jul 5 14:29:10 EDT 2018
The branch, 4.4/copy-lifecycle-before-modify has been created
at 068cc2e5168bbc7525e21d31790c62102ae89d1a (commit)
- Log -----------------------------------------------------------------
commit 068cc2e5168bbc7525e21d31790c62102ae89d1a
Author: Jim Brandt <jbrandt at bestpractical.com>
Date: Thu Jul 5 14:24:34 2018 -0400
Copy lifecycle array before iterating and possibly modifying
Inside the loop we may modify @res and remove a value. In some
versions of perl (at least 5.16), the inner @res and aliased $_
values used in the grep can iterate over the undef'd values,
resulting in warnings like:
Use of uninitialized value in string eq
Create a copy to avoid this.
diff --git a/lib/RT/Lifecycle.pm b/lib/RT/Lifecycle.pm
index 36ab6f3db..281232afb 100644
--- a/lib/RT/Lifecycle.pm
+++ b/lib/RT/Lifecycle.pm
@@ -524,8 +524,9 @@ sub Actions {
@{ $self->{'data'}{'actions'} };
# skip '* -> x' if there is '$from -> x'
+ my @temp; # Create a copy for the inner grep since we modify in the loop
foreach my $e ( grep $_->{'from'} eq '*', @res ) {
- $e = undef if grep $_->{'from'} ne '*' && $_->{'to'} eq $e->{'to'}, @res;
+ $e = undef if grep $_->{'from'} ne '*' && $_->{'to'} eq $e->{'to'}, @temp;
}
return grep defined, @res;
}
-----------------------------------------------------------------------
More information about the rt-commit
mailing list