diff options
author | Father Chrysostomos <sprout@cpan.org> | 2015-02-07 19:22:00 -0800 |
---|---|---|
committer | Father Chrysostomos <sprout@cpan.org> | 2015-02-07 19:22:00 -0800 |
commit | eea89386b3fb948a8b1eb5ea860ec0a970c9e559 (patch) | |
tree | 9ef2b1c60f57ea3d8a457f6a0fb8b9bc46b76a84 /toke.c | |
parent | 218721242848e642c0d1399644b6a90969e485e3 (diff) | |
download | perl-eea89386b3fb948a8b1eb5ea860ec0a970c9e559.tar.gz |
[perl #123753] Assert fail with &{+foo} and errors
This fixes the problem mentioned in 3c47da3c2e with an op address
being used as flags. '&' not followed by a identifier was being fed
to the parser with a stale token value, left over from the previous
token that had a value, which might be an op address. This would
cause the flags on the op to vary randomly.
Usually the rv2cv op created this way is nulled, but if there is a
syntax error it may be freed before that happens. And it is when the
op is freed that the private flags are checked to make sure no invalid
flags have been set.
The test added to t/op/lex.t used to fail an assertion (for me) more
than half the time, but not always, because the 0x10 bit was being set
in op_private (rv2cv does not use that bit).
Diffstat (limited to 'toke.c')
-rw-r--r-- | toke.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -5752,12 +5752,12 @@ Perl_yylex(pTHX) PL_tokenbuf[0] = '&'; s = scan_ident(s - 1, PL_tokenbuf + 1, sizeof PL_tokenbuf - 1, TRUE); + pl_yylval.ival = (OPpENTERSUB_AMPER<<8); if (PL_tokenbuf[1]) { force_ident_maybe_lex('&'); } else PREREF('&'); - pl_yylval.ival = (OPpENTERSUB_AMPER<<8); TERM('&'); case '|': |