Keep It Simple, Stupid | |
PerlMonks |
comment on |
( [id://3333]=superdoc: print w/replies, xml ) | Need Help?? |
I believe that for this exact case (for @array) it is safe, despite the warning which has been there very long time, and despite there being no tests for it I've done it in 5.005 and 5.016 and it worked as expected :) and its perfectly logical, it can't go wrong ( unlike shrinking the size of the array) I believe the only situation for which the warning applies is shrinking the array (pop/unshift), or replacing parts of it (splice) http://search.cpan.org/dist/perl5.005/pod/perlsyn.pod#Foreach_Loops
In any case, warnings doesn't warn you about iterating over an array while you splice over it, but it could In any case, the tests should be amended to test out the possibilities, to narrow down what is safe and what isn't :) So write up a test and perlbug-it brave soul :) Also a Perl::Critic policy should be easy to write, see Perl::Critic::Policy::ValuesAndExpressions::UndefinedBehaviourMaybeQuoteit / $1 not quoted (value not frozen) undefined behaviour In reply to Re: Is it safe to append to the array you are iterating over (yes)
by Anonymous Monk
|
|