summaryrefslogtreecommitdiff
path: root/toke.c
diff options
context:
space:
mode:
authorFather Chrysostomos <sprout@cpan.org>2015-02-07 19:22:00 -0800
committerFather Chrysostomos <sprout@cpan.org>2015-02-07 19:22:00 -0800
commiteea89386b3fb948a8b1eb5ea860ec0a970c9e559 (patch)
tree9ef2b1c60f57ea3d8a457f6a0fb8b9bc46b76a84 /toke.c
parent218721242848e642c0d1399644b6a90969e485e3 (diff)
downloadperl-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.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/toke.c b/toke.c
index fa4de96866..388b272442 100644
--- a/toke.c
+++ b/toke.c
@@ -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 '|':