diff options
-rw-r--r-- | pad.c | 3 | ||||
-rw-r--r-- | t/op/state.t | 17 |
2 files changed, 19 insertions, 1 deletions
@@ -1517,6 +1517,9 @@ Perl_cv_clone(pTHX_ CV *proto) else sv = newSV(0); SvPADMY_on(sv); + /* reset the 'assign only once' flag on each state var */ + if (SvPAD_STATE(namesv)) + SvPADSTALE_on(sv); } } else if (IS_PADGV(ppad[ix]) || IS_PADCONST(ppad[ix])) { diff --git a/t/op/state.t b/t/op/state.t index c372bf6e12..1c4fc8ca81 100644 --- a/t/op/state.t +++ b/t/op/state.t @@ -10,7 +10,7 @@ BEGIN { use strict; use feature ":5.10"; -plan tests => 119; +plan tests => 123; ok( ! defined state $uninit, q(state vars are undef by default) ); @@ -333,6 +333,21 @@ foreach my $spam (@spam) { is $f[1]->(), 1; } +# each copy of an anon sub should get its own 'once block' + +{ + my $x; # used to force a closure + my @f; + push @f, sub { $x; state $s = $_[0]; $s } for 1..2; + is $f[0]->(1), 1; + is $f[0]->(2), 1; + is $f[1]->(3), 3; + is $f[1]->(4), 3; +} + + + + foreach my $forbidden (<DATA>) { chomp $forbidden; no strict 'vars'; |