diff options
author | Father Chrysostomos <sprout@cpan.org> | 2015-03-01 14:01:27 -0800 |
---|---|---|
committer | Father Chrysostomos <sprout@cpan.org> | 2015-03-01 14:01:27 -0800 |
commit | 57db463f603fcd67bf53a35aa482bb24aa2c6950 (patch) | |
tree | a542917cc078a209238c44a0ddc736f468649672 | |
parent | 9f021be64d99e25c9277e6c3e36d224ca74edaed (diff) | |
download | perl-57db463f603fcd67bf53a35aa482bb24aa2c6950.tar.gz |
[perl #123848] Allow OPpTARGET_MY on qr
// in the scope of lexical $_ gets the OPpTARGET_MY flag set. If it
is used as an operand to smartmatch, it gets converted to a qr op.
There is no need to turn off the flag, since it is harmless at run
time. But we need to allow the flag on this op type to avoid asser-
tion failures when it is freed.
-rw-r--r-- | lib/B/Op_private.pm | 4 | ||||
-rw-r--r-- | opcode.h | 313 | ||||
-rw-r--r-- | regen/op_private | 2 | ||||
-rw-r--r-- | t/comp/parser.t | 6 |
4 files changed, 165 insertions, 160 deletions
diff --git a/lib/B/Op_private.pm b/lib/B/Op_private.pm index 52d1c13d30..f42286cb6d 100644 --- a/lib/B/Op_private.pm +++ b/lib/B/Op_private.pm @@ -150,7 +150,7 @@ $bits{$_}{7} = 'OPpPV_IS_UTF8' for qw(dump goto last next redo); $bits{$_}{6} = 'OPpREFCOUNTED' for qw(leave leaveeval leavesub leavesublv leavewrite); $bits{$_}{6} = 'OPpRUNTIME' for qw(match pushre qr subst substcont); $bits{$_}{2} = 'OPpSLICEWARNING' for qw(aslice hslice padav padhv rv2av rv2hv); -$bits{$_}{4} = 'OPpTARGET_MY' for qw(abs add atan2 chdir chmod chomp chown chr chroot complement concat cos crypt divide exec exp flock getpgrp getppid getpriority hex i_add i_divide i_modulo i_multiply i_ncmp i_subtract index int kill left_shift length link log match mkdir modulo multiply nbit_and nbit_or nbit_xor ncomplement oct ord pow push pushre rand rename repeat right_shift rindex rmdir schomp scmp scomplement setpgrp setpriority sin sleep split sqrt srand stringify subst subtract symlink system time trans transr unlink unshift utime vec wait waitpid); +$bits{$_}{4} = 'OPpTARGET_MY' for qw(abs add atan2 chdir chmod chomp chown chr chroot complement concat cos crypt divide exec exp flock getpgrp getppid getpriority hex i_add i_divide i_modulo i_multiply i_ncmp i_subtract index int kill left_shift length link log match mkdir modulo multiply nbit_and nbit_or nbit_xor ncomplement oct ord pow push pushre qr rand rename repeat right_shift rindex rmdir schomp scmp scomplement setpgrp setpriority sin sleep split sqrt srand stringify subst subtract symlink system time trans transr unlink unshift utime vec wait waitpid); $bits{$_}{5} = 'OPpTRANS_COMPLEMENT' for qw(trans transr); $bits{$_}{7} = 'OPpTRANS_DELETE' for qw(trans transr); $bits{$_}{0} = 'OPpTRANS_FROM_UTF' for qw(trans transr); @@ -792,7 +792,7 @@ our %ops_using = ( OPpSORT_DESCEND => [qw(sort)], OPpSPLIT_IMPLIM => [qw(split)], OPpSUBSTR_REPL_FIRST => [qw(substr)], - OPpTARGET_MY => [qw(abs add atan2 chdir chmod chomp chown chr chroot complement concat cos crypt divide exec exp flock getpgrp getppid getpriority hex i_add i_divide i_modulo i_multiply i_ncmp i_subtract index int kill left_shift length link log match mkdir modulo multiply nbit_and nbit_or nbit_xor ncomplement oct ord pow push pushre rand rename repeat right_shift rindex rmdir schomp scmp scomplement setpgrp setpriority sin sleep split sqrt srand stringify subst subtract symlink system time trans transr unlink unshift utime vec wait waitpid)], + OPpTARGET_MY => [qw(abs add atan2 chdir chmod chomp chown chr chroot complement concat cos crypt divide exec exp flock getpgrp getppid getpriority hex i_add i_divide i_modulo i_multiply i_ncmp i_subtract index int kill left_shift length link log match mkdir modulo multiply nbit_and nbit_or nbit_xor ncomplement oct ord pow push pushre qr rand rename repeat right_shift rindex rmdir schomp scmp scomplement setpgrp setpriority sin sleep split sqrt srand stringify subst subtract symlink system time trans transr unlink unshift utime vec wait waitpid)], OPpTRANS_COMPLEMENT => [qw(trans transr)], ); @@ -2464,17 +2464,17 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* regcreset */ 0, /* regcomp */ 26, /* match */ - 55, /* qr */ + 26, /* qr */ 26, /* subst */ - 56, /* substcont */ - 58, /* trans */ - 58, /* transr */ - 66, /* sassign */ - 69, /* aassign */ + 55, /* substcont */ + 57, /* trans */ + 57, /* transr */ + 65, /* sassign */ + 68, /* aassign */ 0, /* chop */ 0, /* schop */ - 72, /* chomp */ - 72, /* schomp */ + 71, /* chomp */ + 71, /* schomp */ 0, /* defined */ 0, /* undef */ 0, /* study */ @@ -2487,22 +2487,22 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* i_postinc */ 0, /* postdec */ 0, /* i_postdec */ - 74, /* pow */ - 74, /* multiply */ - 74, /* i_multiply */ - 74, /* divide */ - 74, /* i_divide */ - 74, /* modulo */ - 74, /* i_modulo */ - 76, /* repeat */ - 74, /* add */ - 74, /* i_add */ - 74, /* subtract */ - 74, /* i_subtract */ - 74, /* concat */ - 79, /* stringify */ - 74, /* left_shift */ - 74, /* right_shift */ + 73, /* pow */ + 73, /* multiply */ + 73, /* i_multiply */ + 73, /* divide */ + 73, /* i_divide */ + 73, /* modulo */ + 73, /* i_modulo */ + 75, /* repeat */ + 73, /* add */ + 73, /* i_add */ + 73, /* subtract */ + 73, /* i_subtract */ + 73, /* concat */ + 78, /* stringify */ + 73, /* left_shift */ + 73, /* right_shift */ 12, /* lt */ 12, /* i_lt */ 12, /* gt */ @@ -2516,131 +2516,131 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 12, /* ne */ 12, /* i_ne */ 12, /* ncmp */ - 74, /* i_ncmp */ + 73, /* i_ncmp */ 12, /* slt */ 12, /* sgt */ 12, /* sle */ 12, /* sge */ 12, /* seq */ 12, /* sne */ - 74, /* scmp */ + 73, /* scmp */ 12, /* bit_and */ 12, /* bit_xor */ 12, /* bit_or */ - 74, /* nbit_and */ - 74, /* nbit_xor */ - 74, /* nbit_or */ + 73, /* nbit_and */ + 73, /* nbit_xor */ + 73, /* nbit_or */ 12, /* sbit_and */ 12, /* sbit_xor */ 12, /* sbit_or */ 0, /* negate */ 0, /* i_negate */ 0, /* not */ - 72, /* complement */ - 72, /* ncomplement */ - 72, /* scomplement */ + 71, /* complement */ + 71, /* ncomplement */ + 71, /* scomplement */ 12, /* smartmatch */ - 79, /* atan2 */ - 72, /* sin */ - 72, /* cos */ - 79, /* rand */ - 79, /* srand */ - 72, /* exp */ - 72, /* log */ - 72, /* sqrt */ - 72, /* int */ - 72, /* hex */ - 72, /* oct */ - 72, /* abs */ - 72, /* length */ - 81, /* substr */ - 84, /* vec */ - 79, /* index */ - 79, /* rindex */ + 78, /* atan2 */ + 71, /* sin */ + 71, /* cos */ + 78, /* rand */ + 78, /* srand */ + 71, /* exp */ + 71, /* log */ + 71, /* sqrt */ + 71, /* int */ + 71, /* hex */ + 71, /* oct */ + 71, /* abs */ + 71, /* length */ + 80, /* substr */ + 83, /* vec */ + 78, /* index */ + 78, /* rindex */ 49, /* sprintf */ 49, /* formline */ - 72, /* ord */ - 72, /* chr */ - 79, /* crypt */ + 71, /* ord */ + 71, /* chr */ + 78, /* crypt */ 0, /* ucfirst */ 0, /* lcfirst */ 0, /* uc */ 0, /* lc */ 0, /* quotemeta */ - 87, /* rv2av */ - 93, /* aelemfast */ - 93, /* aelemfast_lex */ - 94, /* aelem */ - 99, /* aslice */ - 102, /* kvaslice */ + 86, /* rv2av */ + 92, /* aelemfast */ + 92, /* aelemfast_lex */ + 93, /* aelem */ + 98, /* aslice */ + 101, /* kvaslice */ 0, /* aeach */ 0, /* akeys */ 0, /* avalues */ 0, /* each */ 0, /* values */ 40, /* keys */ - 103, /* delete */ - 106, /* exists */ - 108, /* rv2hv */ - 94, /* helem */ - 99, /* hslice */ - 102, /* kvhslice */ - 116, /* multideref */ + 102, /* delete */ + 105, /* exists */ + 107, /* rv2hv */ + 93, /* helem */ + 98, /* hslice */ + 101, /* kvhslice */ + 115, /* multideref */ 49, /* unpack */ 49, /* pack */ - 123, /* split */ + 122, /* split */ 49, /* join */ - 126, /* list */ + 125, /* list */ 12, /* lslice */ 49, /* anonlist */ 49, /* anonhash */ 49, /* splice */ - 79, /* push */ + 78, /* push */ 0, /* pop */ 0, /* shift */ - 79, /* unshift */ - 128, /* sort */ - 135, /* reverse */ - 137, /* grepstart */ - 137, /* grepwhile */ - 137, /* mapstart */ - 137, /* mapwhile */ + 78, /* unshift */ + 127, /* sort */ + 134, /* reverse */ + 136, /* grepstart */ + 136, /* grepwhile */ + 136, /* mapstart */ + 136, /* mapwhile */ 0, /* range */ - 139, /* flip */ - 139, /* flop */ + 138, /* flip */ + 138, /* flop */ 0, /* and */ 0, /* or */ 12, /* xor */ 0, /* dor */ - 141, /* cond_expr */ + 140, /* cond_expr */ 0, /* andassign */ 0, /* orassign */ 0, /* dorassign */ 0, /* method */ - 143, /* entersub */ - 150, /* leavesub */ - 150, /* leavesublv */ - 152, /* caller */ + 142, /* entersub */ + 149, /* leavesub */ + 149, /* leavesublv */ + 151, /* caller */ 49, /* warn */ 49, /* die */ 49, /* reset */ -1, /* lineseq */ - 154, /* nextstate */ - 154, /* dbstate */ + 153, /* nextstate */ + 153, /* dbstate */ -1, /* unstack */ -1, /* enter */ - 155, /* leave */ + 154, /* leave */ -1, /* scope */ - 157, /* enteriter */ - 161, /* iter */ + 156, /* enteriter */ + 160, /* iter */ -1, /* enterloop */ - 162, /* leaveloop */ + 161, /* leaveloop */ -1, /* return */ - 164, /* last */ - 164, /* next */ - 164, /* redo */ - 164, /* dump */ - 164, /* goto */ + 163, /* last */ + 163, /* next */ + 163, /* redo */ + 163, /* dump */ + 163, /* goto */ 49, /* exit */ 0, /* method_named */ 0, /* method_super */ @@ -2652,7 +2652,7 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* leavewhen */ -1, /* break */ -1, /* continue */ - 166, /* open */ + 165, /* open */ 49, /* close */ 49, /* pipe_op */ 49, /* fileno */ @@ -2668,7 +2668,7 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 49, /* getc */ 49, /* read */ 49, /* enterwrite */ - 150, /* leavewrite */ + 149, /* leavewrite */ -1, /* prtf */ -1, /* print */ -1, /* say */ @@ -2682,7 +2682,7 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 49, /* truncate */ 49, /* fcntl */ 49, /* ioctl */ - 79, /* flock */ + 78, /* flock */ 49, /* send */ 49, /* recv */ 49, /* socket */ @@ -2698,45 +2698,45 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* getpeername */ 0, /* lstat */ 0, /* stat */ - 171, /* ftrread */ - 171, /* ftrwrite */ - 171, /* ftrexec */ - 171, /* fteread */ - 171, /* ftewrite */ - 171, /* fteexec */ - 176, /* ftis */ - 176, /* ftsize */ - 176, /* ftmtime */ - 176, /* ftatime */ - 176, /* ftctime */ - 176, /* ftrowned */ - 176, /* fteowned */ - 176, /* ftzero */ - 176, /* ftsock */ - 176, /* ftchr */ - 176, /* ftblk */ - 176, /* ftfile */ - 176, /* ftdir */ - 176, /* ftpipe */ - 176, /* ftsuid */ - 176, /* ftsgid */ - 176, /* ftsvtx */ - 176, /* ftlink */ - 176, /* fttty */ - 176, /* fttext */ - 176, /* ftbinary */ - 79, /* chdir */ - 79, /* chown */ - 72, /* chroot */ - 79, /* unlink */ - 79, /* chmod */ - 79, /* utime */ - 79, /* rename */ - 79, /* link */ - 79, /* symlink */ + 170, /* ftrread */ + 170, /* ftrwrite */ + 170, /* ftrexec */ + 170, /* fteread */ + 170, /* ftewrite */ + 170, /* fteexec */ + 175, /* ftis */ + 175, /* ftsize */ + 175, /* ftmtime */ + 175, /* ftatime */ + 175, /* ftctime */ + 175, /* ftrowned */ + 175, /* fteowned */ + 175, /* ftzero */ + 175, /* ftsock */ + 175, /* ftchr */ + 175, /* ftblk */ + 175, /* ftfile */ + 175, /* ftdir */ + 175, /* ftpipe */ + 175, /* ftsuid */ + 175, /* ftsgid */ + 175, /* ftsvtx */ + 175, /* ftlink */ + 175, /* fttty */ + 175, /* fttext */ + 175, /* ftbinary */ + 78, /* chdir */ + 78, /* chown */ + 71, /* chroot */ + 78, /* unlink */ + 78, /* chmod */ + 78, /* utime */ + 78, /* rename */ + 78, /* link */ + 78, /* symlink */ 0, /* readlink */ - 79, /* mkdir */ - 72, /* rmdir */ + 78, /* mkdir */ + 71, /* rmdir */ 49, /* open_dir */ 0, /* readdir */ 0, /* telldir */ @@ -2744,22 +2744,22 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* rewinddir */ 0, /* closedir */ -1, /* fork */ - 180, /* wait */ - 79, /* waitpid */ - 79, /* system */ - 79, /* exec */ - 79, /* kill */ - 180, /* getppid */ - 79, /* getpgrp */ - 79, /* setpgrp */ - 79, /* getpriority */ - 79, /* setpriority */ - 180, /* time */ + 179, /* wait */ + 78, /* waitpid */ + 78, /* system */ + 78, /* exec */ + 78, /* kill */ + 179, /* getppid */ + 78, /* getpgrp */ + 78, /* setpgrp */ + 78, /* getpriority */ + 78, /* setpriority */ + 179, /* time */ -1, /* tms */ 0, /* localtime */ 49, /* gmtime */ 0, /* alarm */ - 79, /* sleep */ + 78, /* sleep */ 49, /* shmget */ 49, /* shmctl */ 49, /* shmread */ @@ -2774,8 +2774,8 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* require */ 0, /* dofile */ -1, /* hintseval */ - 181, /* entereval */ - 150, /* leaveeval */ + 180, /* entereval */ + 149, /* leaveeval */ 0, /* entertry */ -1, /* leavetry */ 0, /* ghbyname */ @@ -2816,17 +2816,17 @@ EXTCONST I16 PL_op_private_bitdef_ix[] = { 0, /* reach */ 40, /* rkeys */ 0, /* rvalues */ - 187, /* coreargs */ + 186, /* coreargs */ 3, /* runcv */ 0, /* fc */ -1, /* padcv */ -1, /* introcv */ -1, /* clonecv */ - 191, /* padrange */ - 193, /* refassign */ - 199, /* lvref */ - 205, /* lvrefslice */ - 206, /* lvavref */ + 190, /* padrange */ + 192, /* refassign */ + 198, /* lvref */ + 204, /* lvrefslice */ + 205, /* lvavref */ 0, /* anonconst */ }; @@ -2856,14 +2856,13 @@ EXTCONST U16 PL_op_private_bitdefs[] = { 0x29dc, 0x3bd8, 0x0257, /* padsv */ 0x29dc, 0x3bd8, 0x2acc, 0x38c9, /* padav */ 0x29dc, 0x3bd8, 0x0534, 0x05d0, 0x2acc, 0x38c9, /* padhv */ - 0x3698, 0x3ef1, /* pushre, match, subst */ + 0x3698, 0x3ef1, /* pushre, match, qr, subst */ 0x29dc, 0x1758, 0x0256, 0x2acc, 0x2cc8, 0x3c84, 0x0003, /* rv2gv */ 0x29dc, 0x2ef8, 0x0256, 0x3c84, 0x0003, /* rv2sv */ 0x2acc, 0x0003, /* av2arylen, pos, keys, rkeys */ 0x2c3c, 0x0b98, 0x08f4, 0x028c, 0x3e48, 0x3c84, 0x0003, /* rv2cv */ 0x012f, /* bless, glob, sprintf, formline, unpack, pack, join, anonlist, anonhash, splice, warn, die, reset, exit, close, pipe_op, fileno, umask, binmode, tie, dbmopen, sselect, select, getc, read, enterwrite, sysopen, sysseek, sysread, syswrite, eof, tell, seek, truncate, fcntl, ioctl, send, recv, socket, sockpair, bind, connect, listen, accept, shutdown, gsockopt, ssockopt, open_dir, seekdir, gmtime, shmget, shmctl, shmread, shmwrite, msgget, msgctl, msgsnd, msgrcv, semop, semget, semctl, ghbyaddr, gnbyaddr, gpbynumber, gsbyname, gsbyport, syscall */ 0x30dc, 0x2ff8, 0x24b4, 0x23f0, 0x0003, /* backtick */ - 0x3699, /* qr */ 0x3698, 0x0003, /* substcont */ 0x0c9c, 0x1dd8, 0x0834, 0x3ef0, 0x3a0c, 0x2168, 0x01e4, 0x0141, /* trans, transr */ 0x0adc, 0x0458, 0x0067, /* sassign */ @@ -2950,7 +2949,7 @@ EXTCONST U8 PL_op_private_valid[] = { /* REGCRESET */ (OPpARG1_MASK), /* REGCOMP */ (OPpARG1_MASK), /* MATCH */ (OPpTARGET_MY|OPpRUNTIME), - /* QR */ (OPpRUNTIME), + /* QR */ (OPpTARGET_MY|OPpRUNTIME), /* SUBST */ (OPpTARGET_MY|OPpRUNTIME), /* SUBSTCONT */ (OPpARG1_MASK|OPpRUNTIME), /* TRANS */ (OPpTRANS_FROM_UTF|OPpTRANS_TO_UTF|OPpTRANS_IDENTICAL|OPpTRANS_SQUASH|OPpTARGET_MY|OPpTRANS_COMPLEMENT|OPpTRANS_GROWS|OPpTRANS_DELETE), diff --git a/regen/op_private b/regen/op_private index 5a95555099..06ebca6f76 100644 --- a/regen/op_private +++ b/regen/op_private @@ -381,7 +381,7 @@ addbits($_, 4 => qw(OPpTARGET_MY TARGMY)) for ops_with_flag('T'), # This flag is also used to indicate matches against implicit $_, # where $_ is lexical; e.g. my $_; ....; /foo/ - qw(match subst pushre trans transr); + qw(match subst pushre qr trans transr); ; diff --git a/t/comp/parser.t b/t/comp/parser.t index a84cfc2c08..a4ae0524a9 100644 --- a/t/comp/parser.t +++ b/t/comp/parser.t @@ -534,6 +534,12 @@ eval{$1=eval{a:}}; eval "map+map"; eval "grep+grep"; +# ALso failed an assertion [perl #123848] +{ + local $SIG{__WARN__} = sub{}; + eval 'my $_; m// ~~ 0'; +} + # Add new tests HERE (above this line) # bug #74022: Loop on characters in \p{OtherIDContinue} |