X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/8635e3c238f87f82dab918053e6f0b6a1a2525e6..9fb4aef8dd5425397148cefa4dbd8db6d0697216:/perly.act diff --git a/perly.act b/perly.act index a6f5522..2b71fe4 100644 --- a/perly.act +++ b/perly.act @@ -5,14 +5,14 @@ */ case 2: -#line 115 "perly.y" +#line 118 "perly.y" { parser->expect = XSTATE; ;} break; case 3: -#line 119 "perly.y" +#line 122 "perly.y" { newPROG(block_end((ps[(3) - (4)].val.ival),(ps[(4) - (4)].val.opval))); PL_compiling.cop_seq = 0; @@ -21,14 +21,14 @@ case 2: break; case 4: -#line 125 "perly.y" +#line 128 "perly.y" { parser->expect = XTERM; ;} break; case 5: -#line 129 "perly.y" +#line 132 "perly.y" { PL_eval_root = (ps[(3) - (3)].val.opval); (yyval.ival) = 0; @@ -36,14 +36,14 @@ case 2: break; case 6: -#line 134 "perly.y" +#line 137 "perly.y" { parser->expect = XBLOCK; ;} break; case 7: -#line 138 "perly.y" +#line 141 "perly.y" { PL_pad_reset_pending = TRUE; PL_eval_root = (ps[(3) - (3)].val.opval); @@ -54,14 +54,14 @@ case 2: break; case 8: -#line 146 "perly.y" +#line 149 "perly.y" { parser->expect = XSTATE; ;} break; case 9: -#line 150 "perly.y" +#line 153 "perly.y" { PL_pad_reset_pending = TRUE; PL_eval_root = (ps[(3) - (3)].val.opval); @@ -72,14 +72,14 @@ case 2: break; case 10: -#line 158 "perly.y" +#line 161 "perly.y" { parser->expect = XSTATE; ;} break; case 11: -#line 162 "perly.y" +#line 165 "perly.y" { PL_pad_reset_pending = TRUE; PL_eval_root = (ps[(3) - (3)].val.opval); @@ -90,14 +90,14 @@ case 2: break; case 12: -#line 170 "perly.y" +#line 173 "perly.y" { parser->expect = XSTATE; ;} break; case 13: -#line 174 "perly.y" +#line 177 "perly.y" { PL_eval_root = (ps[(3) - (3)].val.opval); (yyval.ival) = 0; @@ -105,7 +105,7 @@ case 2: break; case 14: -#line 182 "perly.y" +#line 185 "perly.y" { if (parser->copline > (line_t)(ps[(1) - (4)].val.ival)) parser->copline = (line_t)(ps[(1) - (4)].val.ival); (yyval.opval) = block_end((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval)); @@ -113,7 +113,7 @@ case 2: break; case 15: -#line 190 "perly.y" +#line 193 "perly.y" { if (parser->copline > (line_t)(ps[(1) - (7)].val.ival)) parser->copline = (line_t)(ps[(1) - (7)].val.ival); (yyval.opval) = block_end((ps[(2) - (7)].val.ival), (ps[(5) - (7)].val.opval)); @@ -121,12 +121,13 @@ case 2: break; case 16: -#line 197 "perly.y" - { (yyval.ival) = block_start(TRUE); ;} +#line 200 "perly.y" + { (yyval.ival) = block_start(TRUE); + parser->parsed_sub = 0; ;} break; case 17: -#line 201 "perly.y" +#line 205 "perly.y" { if (parser->copline > (line_t)(ps[(1) - (4)].val.ival)) parser->copline = (line_t)(ps[(1) - (4)].val.ival); (yyval.opval) = block_end((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval)); @@ -134,17 +135,18 @@ case 2: break; case 18: -#line 208 "perly.y" - { (yyval.ival) = block_start(FALSE); ;} +#line 212 "perly.y" + { (yyval.ival) = block_start(FALSE); + parser->parsed_sub = 0; ;} break; case 19: -#line 213 "perly.y" +#line 218 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; case 20: -#line 215 "perly.y" +#line 220 "perly.y" { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[(1) - (2)].val.opval), (ps[(2) - (2)].val.opval)); PL_pad_reset_pending = TRUE; if ((ps[(1) - (2)].val.opval) && (ps[(2) - (2)].val.opval)) @@ -153,12 +155,12 @@ case 2: break; case 21: -#line 224 "perly.y" +#line 229 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; case 22: -#line 226 "perly.y" +#line 231 "perly.y" { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[(1) - (2)].val.opval), (ps[(2) - (2)].val.opval)); PL_pad_reset_pending = TRUE; if ((ps[(1) - (2)].val.opval) && (ps[(2) - (2)].val.opval)) @@ -167,51 +169,51 @@ case 2: break; case 23: -#line 235 "perly.y" +#line 240 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval) ? newSTATEOP(0, NULL, (ps[(1) - (1)].val.opval)) : NULL; ;} break; case 24: -#line 239 "perly.y" +#line 244 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; case 25: -#line 243 "perly.y" +#line 248 "perly.y" { (yyval.opval) = newSTATEOP(SVf_UTF8 * (ps[(1) - (2)].val.pval)[strlen((ps[(1) - (2)].val.pval))+1], (ps[(1) - (2)].val.pval), (ps[(2) - (2)].val.opval)); ;} break; case 26: -#line 247 "perly.y" +#line 252 "perly.y" { (yyval.opval) = newSTATEOP(SVf_UTF8 * (ps[(1) - (2)].val.pval)[strlen((ps[(1) - (2)].val.pval))+1], (ps[(1) - (2)].val.pval), (ps[(2) - (2)].val.opval)); ;} break; case 27: -#line 254 "perly.y" +#line 259 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; case 28: -#line 256 "perly.y" +#line 261 "perly.y" { CV *fmtcv = PL_compcv; newFORM((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval), (ps[(4) - (4)].val.opval)); (yyval.opval) = (OP*)NULL; if (CvOUTSIDE(fmtcv) && !CvEVAL(CvOUTSIDE(fmtcv))) { - SvREFCNT_inc_simple_void(fmtcv); - pad_add_anon(fmtcv, OP_NULL); + pad_add_weakref(fmtcv); } + parser->parsed_sub = 1; ;} break; case 29: -#line 266 "perly.y" +#line 271 "perly.y" { if ((ps[(2) - (3)].val.opval)->op_type == OP_CONST) { const char *const name = @@ -236,7 +238,7 @@ case 2: break; case 30: -#line 288 "perly.y" +#line 293 "perly.y" { SvREFCNT_inc_simple_void(PL_compcv); (ps[(2) - (7)].val.opval)->op_type == OP_CONST @@ -245,11 +247,57 @@ case 2: ; (yyval.opval) = (OP*)NULL; intro_my(); + parser->parsed_sub = 1; ;} break; case 31: -#line 298 "perly.y" +#line 304 "perly.y" + { + if ((ps[(2) - (3)].val.opval)->op_type == OP_CONST) { + const char *const name = + SvPV_nolen_const(((SVOP*)(ps[(2) - (3)].val.opval))->op_sv); + if (strEQ(name, "BEGIN") || strEQ(name, "END") + || strEQ(name, "INIT") || strEQ(name, "CHECK") + || strEQ(name, "UNITCHECK")) + CvSPECIAL_on(PL_compcv); + } + else + /* State subs inside anonymous subs need to be + clonable themselves. */ + if (CvANON(CvOUTSIDE(PL_compcv)) + || CvCLONE(CvOUTSIDE(PL_compcv)) + || !PadnameIsSTATE(PadlistNAMESARRAY(CvPADLIST( + CvOUTSIDE(PL_compcv) + ))[(ps[(2) - (3)].val.opval)->op_targ])) + CvCLONE_on(PL_compcv); + parser->in_my = 0; + parser->in_my_stash = NULL; + ;} + break; + + case 32: +#line 326 "perly.y" + { + OP *body; + if (parser->copline > (line_t)(ps[(8) - (10)].val.ival)) + parser->copline = (line_t)(ps[(8) - (10)].val.ival); + body = block_end((ps[(5) - (10)].val.ival), + op_append_list(OP_LINESEQ, (ps[(6) - (10)].val.opval), (ps[(9) - (10)].val.opval))); + + SvREFCNT_inc_simple_void(PL_compcv); + (ps[(2) - (10)].val.opval)->op_type == OP_CONST + ? newATTRSUB((ps[(3) - (10)].val.ival), (ps[(2) - (10)].val.opval), NULL, (ps[(7) - (10)].val.opval), body) + : newMYSUB((ps[(3) - (10)].val.ival), (ps[(2) - (10)].val.opval), NULL, (ps[(7) - (10)].val.opval), body) + ; + (yyval.opval) = (OP*)NULL; + intro_my(); + parser->parsed_sub = 1; + ;} + break; + + case 33: +#line 343 "perly.y" { package((ps[(3) - (4)].val.opval)); if ((ps[(2) - (4)].val.opval)) @@ -258,22 +306,23 @@ case 2: ;} break; - case 32: -#line 305 "perly.y" + case 34: +#line 350 "perly.y" { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ ;} break; - case 33: -#line 307 "perly.y" + case 35: +#line 352 "perly.y" { SvREFCNT_inc_simple_void(PL_compcv); utilize((ps[(1) - (7)].val.ival), (ps[(2) - (7)].val.ival), (ps[(4) - (7)].val.opval), (ps[(5) - (7)].val.opval), (ps[(6) - (7)].val.opval)); + parser->parsed_sub = 1; (yyval.opval) = (OP*)NULL; ;} break; - case 34: -#line 313 "perly.y" + case 36: +#line 359 "perly.y" { (yyval.opval) = block_end((ps[(3) - (7)].val.ival), newCONDOP(0, (ps[(4) - (7)].val.opval), op_scope((ps[(6) - (7)].val.opval)), (ps[(7) - (7)].val.opval))); @@ -281,41 +330,35 @@ case 2: ;} break; - case 35: -#line 319 "perly.y" + case 37: +#line 365 "perly.y" { (yyval.opval) = block_end((ps[(3) - (7)].val.ival), - newCONDOP(0, (ps[(4) - (7)].val.opval), op_scope((ps[(6) - (7)].val.opval)), (ps[(7) - (7)].val.opval))); + newCONDOP(0, (ps[(4) - (7)].val.opval), (ps[(7) - (7)].val.opval), op_scope((ps[(6) - (7)].val.opval)))); parser->copline = (line_t)(ps[(1) - (7)].val.ival); ;} break; - case 36: -#line 325 "perly.y" + case 38: +#line 371 "perly.y" { - const PADOFFSET offset = pad_findmy_pvs("$_", 0); - (yyval.opval) = block_end((ps[(3) - (6)].val.ival), - newGIVENOP((ps[(4) - (6)].val.opval), op_scope((ps[(6) - (6)].val.opval)), - offset == NOT_IN_PAD - || PAD_COMPNAME_FLAGS_isOUR(offset) - ? 0 - : offset)); + (yyval.opval) = block_end((ps[(3) - (6)].val.ival), newGIVENOP((ps[(4) - (6)].val.opval), op_scope((ps[(6) - (6)].val.opval)), 0)); parser->copline = (line_t)(ps[(1) - (6)].val.ival); ;} break; - case 37: -#line 336 "perly.y" + case 39: +#line 376 "perly.y" { (yyval.opval) = block_end((ps[(3) - (6)].val.ival), newWHENOP((ps[(4) - (6)].val.opval), op_scope((ps[(6) - (6)].val.opval)))); ;} break; - case 38: -#line 338 "perly.y" + case 40: +#line 378 "perly.y" { (yyval.opval) = newWHENOP(0, op_scope((ps[(2) - (2)].val.opval))); ;} break; - case 39: -#line 340 "perly.y" + case 41: +#line 380 "perly.y" { (yyval.opval) = block_end((ps[(3) - (8)].val.ival), newWHILEOP(0, 1, (LOOP*)(OP*)NULL, @@ -324,8 +367,8 @@ case 2: ;} break; - case 40: -#line 347 "perly.y" + case 42: +#line 387 "perly.y" { (yyval.opval) = block_end((ps[(3) - (8)].val.ival), newWHILEOP(0, 1, (LOOP*)(OP*)NULL, @@ -334,18 +377,18 @@ case 2: ;} break; - case 41: -#line 354 "perly.y" + case 43: +#line 394 "perly.y" { parser->expect = XTERM; ;} break; - case 42: -#line 356 "perly.y" + case 44: +#line 396 "perly.y" { parser->expect = XTERM; ;} break; - case 43: -#line 359 "perly.y" + case 45: +#line 399 "perly.y" { OP *initop = (ps[(4) - (13)].val.opval); OP *forop = newWHILEOP(0, 1, (LOOP*)(OP*)NULL, @@ -356,21 +399,22 @@ case 2: newOP(OP_UNSTACK, OPf_SPECIAL), forop)); } + PL_hints |= HINT_BLOCK_SCOPE; (yyval.opval) = block_end((ps[(3) - (13)].val.ival), forop); parser->copline = (line_t)(ps[(1) - (13)].val.ival); ;} break; - case 44: -#line 373 "perly.y" + case 46: +#line 414 "perly.y" { (yyval.opval) = block_end((ps[(3) - (9)].val.ival), newFOROP(0, (ps[(4) - (9)].val.opval), (ps[(6) - (9)].val.opval), (ps[(8) - (9)].val.opval), (ps[(9) - (9)].val.opval))); parser->copline = (line_t)(ps[(1) - (9)].val.ival); ;} break; - case 45: -#line 378 "perly.y" + case 47: +#line 419 "perly.y" { (yyval.opval) = block_end((ps[(4) - (8)].val.ival), newFOROP(0, op_lvalue((ps[(2) - (8)].val.opval), OP_ENTERLOOP), (ps[(5) - (8)].val.opval), (ps[(7) - (8)].val.opval), (ps[(8) - (8)].val.opval))); @@ -378,29 +422,29 @@ case 2: ;} break; - case 46: -#line 384 "perly.y" - { parser->in_my = 0; (yyval.opval) = my((ps[(5) - (5)].val.opval)); ;} + case 48: +#line 425 "perly.y" + { parser->in_my = 0; (yyval.opval) = my((ps[(4) - (4)].val.opval)); ;} break; - case 47: -#line 386 "perly.y" + case 49: +#line 427 "perly.y" { (yyval.opval) = block_end( - (ps[(4) - (11)].val.ival), + (ps[(3) - (10)].val.ival), newFOROP(0, op_lvalue( newUNOP(OP_REFGEN, 0, - (ps[(6) - (11)].val.opval)), + (ps[(5) - (10)].val.opval)), OP_ENTERLOOP), - (ps[(8) - (11)].val.opval), (ps[(10) - (11)].val.opval), (ps[(11) - (11)].val.opval)) + (ps[(7) - (10)].val.opval), (ps[(9) - (10)].val.opval), (ps[(10) - (10)].val.opval)) ); - parser->copline = (line_t)(ps[(1) - (11)].val.ival); + parser->copline = (line_t)(ps[(1) - (10)].val.ival); ;} break; - case 48: -#line 399 "perly.y" + case 50: +#line 440 "perly.y" { (yyval.opval) = block_end((ps[(5) - (9)].val.ival), newFOROP( 0, op_lvalue(newUNOP(OP_REFGEN, 0, @@ -410,8 +454,8 @@ case 2: ;} break; - case 49: -#line 407 "perly.y" + case 51: +#line 448 "perly.y" { (yyval.opval) = block_end((ps[(3) - (7)].val.ival), newFOROP(0, (OP*)NULL, (ps[(4) - (7)].val.opval), (ps[(6) - (7)].val.opval), (ps[(7) - (7)].val.opval))); @@ -419,8 +463,8 @@ case 2: ;} break; - case 50: -#line 413 "perly.y" + case 52: +#line 454 "perly.y" { /* a block is a loop that happens once */ (yyval.opval) = newWHILEOP(0, 1, (LOOP*)(OP*)NULL, @@ -428,8 +472,8 @@ case 2: ;} break; - case 51: -#line 419 "perly.y" + case 53: +#line 460 "perly.y" { package((ps[(3) - (5)].val.opval)); if ((ps[(2) - (5)].val.opval)) { @@ -438,8 +482,8 @@ case 2: ;} break; - case 52: -#line 426 "perly.y" + case 54: +#line 467 "perly.y" { /* a block is a loop that happens once */ (yyval.opval) = newWHILEOP(0, 1, (LOOP*)(OP*)NULL, @@ -449,23 +493,23 @@ case 2: ;} break; - case 53: -#line 434 "perly.y" + case 55: +#line 475 "perly.y" { (yyval.opval) = (ps[(1) - (2)].val.opval); ;} break; - case 54: -#line 438 "perly.y" + case 56: +#line 479 "perly.y" { (yyval.opval) = (OP*)NULL; parser->copline = NOLINE; ;} break; - case 55: -#line 446 "perly.y" + case 57: +#line 487 "perly.y" { OP *list; if ((ps[(2) - (2)].val.opval)) { OP *term = (ps[(2) - (2)].val.opval); @@ -482,72 +526,72 @@ case 2: ;} break; - case 56: -#line 463 "perly.y" + case 58: +#line 504 "perly.y" { (yyval.opval) = NULL; ;} break; - case 57: -#line 465 "perly.y" + case 59: +#line 506 "perly.y" { (yyval.opval) = op_unscope((ps[(2) - (3)].val.opval)); ;} break; - case 58: -#line 470 "perly.y" + case 60: +#line 511 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 59: -#line 472 "perly.y" + case 61: +#line 513 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 60: -#line 474 "perly.y" + case 62: +#line 515 "perly.y" { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval)); ;} break; - case 61: -#line 476 "perly.y" + case 63: +#line 517 "perly.y" { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval)); ;} break; - case 62: -#line 478 "perly.y" + case 64: +#line 519 "perly.y" { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[(3) - (3)].val.opval)), (ps[(1) - (3)].val.opval)); ;} break; - case 63: -#line 480 "perly.y" + case 65: +#line 521 "perly.y" { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval)); ;} break; - case 64: -#line 482 "perly.y" + case 66: +#line 523 "perly.y" { (yyval.opval) = newFOROP(0, (OP*)NULL, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval), (OP*)NULL); parser->copline = (line_t)(ps[(2) - (3)].val.ival); ;} break; - case 65: -#line 485 "perly.y" + case 67: +#line 526 "perly.y" { (yyval.opval) = newWHENOP((ps[(3) - (3)].val.opval), op_scope((ps[(1) - (3)].val.opval))); ;} break; - case 66: -#line 490 "perly.y" + case 68: +#line 531 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 67: -#line 492 "perly.y" + case 69: +#line 533 "perly.y" { ((ps[(2) - (2)].val.opval))->op_flags |= OPf_PARENS; (yyval.opval) = op_scope((ps[(2) - (2)].val.opval)); ;} break; - case 68: -#line 497 "perly.y" + case 70: +#line 538 "perly.y" { parser->copline = (line_t)(ps[(1) - (6)].val.ival); (yyval.opval) = newCONDOP(0, newSTATEOP(OPf_SPECIAL,NULL,(ps[(3) - (6)].val.opval)), @@ -556,204 +600,364 @@ case 2: ;} break; - case 69: -#line 507 "perly.y" + case 71: +#line 548 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 70: -#line 509 "perly.y" + case 72: +#line 550 "perly.y" { (yyval.opval) = op_scope((ps[(2) - (2)].val.opval)); ;} break; - case 71: -#line 514 "perly.y" + case 73: +#line 555 "perly.y" { (yyval.ival) = (PL_min_intro_pending && PL_max_intro_pending >= PL_min_intro_pending); intro_my(); ;} break; - case 72: -#line 520 "perly.y" + case 74: +#line 561 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 74: -#line 526 "perly.y" + case 76: +#line 567 "perly.y" { YYSTYPE tmplval; (void)scan_num("1", &tmplval); (yyval.opval) = tmplval.opval; ;} break; - case 76: -#line 534 "perly.y" + case 78: +#line 575 "perly.y" { (yyval.opval) = invert(scalar((ps[(1) - (1)].val.opval))); ;} break; - case 77: -#line 539 "perly.y" - { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;} - break; - - case 78: -#line 543 "perly.y" + case 79: +#line 580 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;} break; - case 79: -#line 547 "perly.y" + case 80: +#line 584 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;} break; - case 80: -#line 550 "perly.y" + case 81: +#line 587 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 81: -#line 551 "perly.y" + case 82: +#line 588 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 82: -#line 555 "perly.y" + case 83: +#line 592 "perly.y" { (yyval.ival) = start_subparse(FALSE, 0); SAVEFREESV(PL_compcv); ;} break; - case 83: -#line 561 "perly.y" + case 84: +#line 598 "perly.y" { (yyval.ival) = start_subparse(FALSE, CVf_ANON); SAVEFREESV(PL_compcv); ;} break; - case 84: -#line 566 "perly.y" + case 85: +#line 603 "perly.y" { (yyval.ival) = start_subparse(TRUE, 0); SAVEFREESV(PL_compcv); ;} break; - case 87: -#line 577 "perly.y" - { (yyval.opval) = (OP*)NULL; ;} - break; - - case 89: -#line 583 "perly.y" + case 88: +#line 614 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; case 90: -#line 585 "perly.y" - { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} +#line 620 "perly.y" + { (yyval.opval) = (OP*)NULL; ;} break; case 91: -#line 587 "perly.y" - { (yyval.opval) = (OP*)NULL; ;} +#line 622 "perly.y" + { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} break; case 92: -#line 592 "perly.y" - { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} +#line 624 "perly.y" + { (yyval.opval) = (OP*)NULL; ;} break; case 93: -#line 594 "perly.y" - { (yyval.opval) = (OP*)NULL; ;} +#line 629 "perly.y" + { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} break; case 94: -#line 598 "perly.y" +#line 631 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; case 95: -#line 600 "perly.y" - { - if (!FEATURE_SIGNATURES_IS_ENABLED) - Perl_croak(aTHX_ "Experimental " - "subroutine signatures not enabled"); - Perl_ck_warner_d(aTHX_ - packWARN(WARN_EXPERIMENTAL__SIGNATURES), - "The signatures feature is experimental"); - (yyval.opval) = parse_subsignature(); - ;} +#line 642 "perly.y" + { parser->in_my = 0; (yyval.opval) = (OP*)NULL; ;} break; case 96: -#line 610 "perly.y" - { - (yyval.opval) = op_append_list(OP_LINESEQ, (ps[(2) - (3)].val.opval), - newSTATEOP(0, NULL, sawparens(newNULLLIST()))); - parser->expect = XBLOCK; - ;} +#line 644 "perly.y" + { parser->in_my = 0; (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; case 97: -#line 619 "perly.y" +#line 649 "perly.y" + { (yyval.ival) = '@'; ;} + break; + + case 98: +#line 651 "perly.y" + { (yyval.ival) = '%'; ;} + break; + + case 99: +#line 655 "perly.y" + { + I32 sigil = (ps[(1) - (3)].val.ival); + OP *var = (ps[(2) - (3)].val.opval); + OP *defexpr = (ps[(3) - (3)].val.opval); + + if (parser->sig_slurpy) + yyerror("Multiple slurpy parameters not allowed"); + parser->sig_slurpy = (char)sigil; + + if (defexpr) + yyerror("A slurpy parameter may not have " + "a default value"); + + (yyval.opval) = var ? newSTATEOP(0, NULL, var) : (OP*)NULL; + ;} + break; + + case 100: +#line 674 "perly.y" + { (yyval.opval) = (OP*)NULL; ;} + break; + + case 101: +#line 676 "perly.y" + { (yyval.opval) = newOP(OP_NULL, 0); ;} + break; + + case 102: +#line 678 "perly.y" + { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} + break; + + case 103: +#line 684 "perly.y" + { + OP *var = (ps[(2) - (3)].val.opval); + OP *defexpr = (ps[(3) - (3)].val.opval); + + if (parser->sig_slurpy) + yyerror("Slurpy parameter not last"); + + parser->sig_elems++; + + if (defexpr) { + parser->sig_optelems++; + + if ( defexpr->op_type == OP_NULL + && !(defexpr->op_flags & OPf_KIDS)) + { + /* handle '$=' special case */ + if (var) + yyerror("Optional parameter " + "lacks default expression"); + op_free(defexpr); + } + else { + /* a normal '=default' expression */ + OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM, + defexpr, + LINKLIST(defexpr)); + /* re-purpose op_targ to hold @_ index */ + defop->op_targ = + (PADOFFSET)(parser->sig_elems - 1); + + if (var) { + var->op_flags |= OPf_STACKED; + (void)op_sibling_splice(var, + NULL, 0, defop); + scalar(defop); + } + else + var = newUNOP(OP_NULL, 0, defop); + + LINKLIST(var); + /* NB: normally the first child of a + * logop is executed before the logop, + * and it pushes a boolean result + * ready for the logop. For ARGDEFELEM, + * the op itself does the boolean + * calculation, so set the first op to + * it instead. + */ + var->op_next = defop; + defexpr->op_next = var; + } + } + else { + if (parser->sig_optelems) + yyerror("Mandatory parameter " + "follows optional parameter"); + } + + (yyval.opval) = var ? newSTATEOP(0, NULL, var) : (OP*)NULL; + ;} + break; + + case 104: +#line 749 "perly.y" + { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[(1) - (1)].val.opval); ;} + break; + + case 105: +#line 751 "perly.y" + { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[(1) - (1)].val.opval); ;} + break; + + case 106: +#line 757 "perly.y" + { (yyval.opval) = (ps[(1) - (2)].val.opval); ;} + break; + + case 107: +#line 759 "perly.y" { - if (parser->copline > (line_t)(ps[(3) - (5)].val.ival)) - parser->copline = (line_t)(ps[(3) - (5)].val.ival); - (yyval.opval) = block_end((ps[(1) - (5)].val.ival), - op_append_list(OP_LINESEQ, (ps[(2) - (5)].val.opval), (ps[(4) - (5)].val.opval))); + (yyval.opval) = op_append_list(OP_LINESEQ, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 98: -#line 628 "perly.y" + case 108: +#line 763 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 99: -#line 629 "perly.y" + case 109: +#line 768 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 100: -#line 634 "perly.y" + case 110: +#line 770 "perly.y" + { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} + break; + + case 111: +#line 774 "perly.y" + { + ENTER; + SAVEIV(parser->sig_elems); + SAVEIV(parser->sig_optelems); + SAVEI8(parser->sig_slurpy); + parser->sig_elems = 0; + parser->sig_optelems = 0; + parser->sig_slurpy = 0; + parser->in_my = KEY_sigvar; + ;} + break; + + case 112: +#line 786 "perly.y" + { + OP *sigops = (ps[(3) - (4)].val.opval); + UNOP_AUX_item *aux; + OP *check; + + if (!parser->error_count) { + assert(FEATURE_SIGNATURES_IS_ENABLED); + } + + /* We shouldn't get here otherwise */ + Perl_ck_warner_d(aTHX_ + packWARN(WARN_EXPERIMENTAL__SIGNATURES), + "The signatures feature is experimental"); + + aux = (UNOP_AUX_item*)PerlMemShared_malloc( + sizeof(UNOP_AUX_item) * 3); + aux[0].iv = parser->sig_elems; + aux[1].iv = parser->sig_optelems; + aux[2].iv = parser->sig_slurpy; + check = newUNOP_AUX(OP_ARGCHECK, 0, NULL, aux); + sigops = op_prepend_elem(OP_LINESEQ, check, sigops); + sigops = op_prepend_elem(OP_LINESEQ, + newSTATEOP(0, NULL, NULL), + sigops); + /* a nextstate at the end handles context + * correctly for an empty sub body */ + (yyval.opval) = op_append_elem(OP_LINESEQ, + sigops, + newSTATEOP(0, NULL, NULL)); + + parser->in_my = 0; + parser->expect = XATTRBLOCK; + LEAVE; + ;} + break; + + case 114: +#line 826 "perly.y" + { (yyval.opval) = (OP*)NULL; ;} + break; + + case 115: +#line 831 "perly.y" { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 101: -#line 636 "perly.y" + case 116: +#line 833 "perly.y" { (yyval.opval) = newLOGOP((ps[(2) - (3)].val.ival), 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 102: -#line 638 "perly.y" + case 117: +#line 835 "perly.y" { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 104: -#line 644 "perly.y" + case 119: +#line 841 "perly.y" { (yyval.opval) = (ps[(1) - (2)].val.opval); ;} break; - case 105: -#line 646 "perly.y" - { + case 120: +#line 843 "perly.y" + { OP* term = (ps[(3) - (3)].val.opval); (yyval.opval) = op_append_elem(OP_LIST, (ps[(1) - (3)].val.opval), term); ;} break; - case 107: -#line 655 "perly.y" + case 122: +#line 852 "perly.y" { (yyval.opval) = op_convert_list((ps[(1) - (3)].val.ival), OPf_STACKED, op_prepend_elem(OP_LIST, newGVREF((ps[(1) - (3)].val.ival),(ps[(2) - (3)].val.opval)), (ps[(3) - (3)].val.opval)) ); ;} break; - case 108: -#line 659 "perly.y" + case 123: +#line 856 "perly.y" { (yyval.opval) = op_convert_list((ps[(1) - (5)].val.ival), OPf_STACKED, op_prepend_elem(OP_LIST, newGVREF((ps[(1) - (5)].val.ival),(ps[(3) - (5)].val.opval)), (ps[(4) - (5)].val.opval)) ); ;} break; - case 109: -#line 663 "perly.y" + case 124: +#line 860 "perly.y" { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, op_prepend_elem(OP_LIST, scalar((ps[(1) - (6)].val.opval)), (ps[(5) - (6)].val.opval)), @@ -761,16 +965,16 @@ case 2: ;} break; - case 110: -#line 669 "perly.y" + case 125: +#line 866 "perly.y" { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, scalar((ps[(1) - (3)].val.opval)), newMETHOP(OP_METHOD, 0, (ps[(3) - (3)].val.opval)))); ;} break; - case 111: -#line 674 "perly.y" + case 126: +#line 871 "perly.y" { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, op_prepend_elem(OP_LIST, (ps[(2) - (3)].val.opval), (ps[(3) - (3)].val.opval)), @@ -778,8 +982,8 @@ case 2: ;} break; - case 112: -#line 680 "perly.y" + case 127: +#line 877 "perly.y" { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, op_prepend_elem(OP_LIST, (ps[(2) - (5)].val.opval), (ps[(4) - (5)].val.opval)), @@ -787,225 +991,225 @@ case 2: ;} break; - case 113: -#line 686 "perly.y" + case 128: +#line 883 "perly.y" { (yyval.opval) = op_convert_list((ps[(1) - (2)].val.ival), 0, (ps[(2) - (2)].val.opval)); ;} break; - case 114: -#line 688 "perly.y" + case 129: +#line 885 "perly.y" { (yyval.opval) = op_convert_list((ps[(1) - (4)].val.ival), 0, (ps[(3) - (4)].val.opval)); ;} break; - case 115: -#line 690 "perly.y" + case 130: +#line 887 "perly.y" { SvREFCNT_inc_simple_void(PL_compcv); (yyval.opval) = newANONATTRSUB((ps[(2) - (3)].val.ival), 0, (OP*)NULL, (ps[(3) - (3)].val.opval)); ;} break; - case 116: -#line 693 "perly.y" + case 131: +#line 890 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, op_prepend_elem(OP_LIST, (ps[(4) - (5)].val.opval), (ps[(5) - (5)].val.opval)), (ps[(1) - (5)].val.opval))); ;} break; - case 119: -#line 708 "perly.y" + case 134: +#line 905 "perly.y" { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[(1) - (5)].val.opval), scalar((ps[(3) - (5)].val.opval))); ;} break; - case 120: -#line 710 "perly.y" + case 135: +#line 907 "perly.y" { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[(1) - (4)].val.opval)), scalar((ps[(3) - (4)].val.opval))); ;} break; - case 121: -#line 713 "perly.y" + case 136: +#line 910 "perly.y" { (yyval.opval) = newBINOP(OP_AELEM, 0, ref(newAVREF((ps[(1) - (5)].val.opval)),OP_RV2AV), scalar((ps[(4) - (5)].val.opval))); ;} break; - case 122: -#line 718 "perly.y" + case 137: +#line 915 "perly.y" { (yyval.opval) = newBINOP(OP_AELEM, 0, ref(newAVREF((ps[(1) - (4)].val.opval)),OP_RV2AV), scalar((ps[(3) - (4)].val.opval))); ;} break; - case 123: -#line 723 "perly.y" + case 138: +#line 920 "perly.y" { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[(1) - (5)].val.opval)), jmaybe((ps[(3) - (5)].val.opval))); ;} break; - case 124: -#line 726 "perly.y" + case 139: +#line 923 "perly.y" { (yyval.opval) = newBINOP(OP_HELEM, 0, ref(newHVREF((ps[(1) - (6)].val.opval)),OP_RV2HV), jmaybe((ps[(4) - (6)].val.opval))); ;} break; - case 125: -#line 730 "perly.y" + case 140: +#line 927 "perly.y" { (yyval.opval) = newBINOP(OP_HELEM, 0, ref(newHVREF((ps[(1) - (5)].val.opval)),OP_RV2HV), jmaybe((ps[(3) - (5)].val.opval))); ;} break; - case 126: -#line 734 "perly.y" + case 141: +#line 931 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, newCVREF(0, scalar((ps[(1) - (4)].val.opval)))); ;} break; - case 127: -#line 737 "perly.y" + case 142: +#line 934 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, (ps[(4) - (5)].val.opval), newCVREF(0, scalar((ps[(1) - (5)].val.opval))))); ;} break; - case 128: -#line 742 "perly.y" + case 143: +#line 939 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, (ps[(3) - (4)].val.opval), newCVREF(0, scalar((ps[(1) - (4)].val.opval))))); ;} break; - case 129: -#line 746 "perly.y" + case 144: +#line 943 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, newCVREF(0, scalar((ps[(1) - (3)].val.opval)))); ;} break; - case 130: -#line 749 "perly.y" + case 145: +#line 946 "perly.y" { (yyval.opval) = newSLICEOP(0, (ps[(5) - (6)].val.opval), (ps[(2) - (6)].val.opval)); ;} break; - case 131: -#line 751 "perly.y" + case 146: +#line 948 "perly.y" { (yyval.opval) = newSLICEOP(0, (ps[(3) - (4)].val.opval), (ps[(1) - (4)].val.opval)); ;} break; - case 132: -#line 753 "perly.y" + case 147: +#line 950 "perly.y" { (yyval.opval) = newSLICEOP(0, (ps[(4) - (5)].val.opval), (OP*)NULL); ;} break; - case 133: -#line 758 "perly.y" + case 148: +#line 955 "perly.y" { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[(1) - (3)].val.opval), (ps[(2) - (3)].val.ival), (ps[(3) - (3)].val.opval)); ;} break; - case 134: -#line 760 "perly.y" + case 149: +#line 957 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 135: -#line 762 "perly.y" + case 150: +#line 959 "perly.y" { if ((ps[(2) - (3)].val.ival) != OP_REPEAT) scalar((ps[(1) - (3)].val.opval)); (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, (ps[(1) - (3)].val.opval), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 136: -#line 767 "perly.y" + case 151: +#line 964 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 137: -#line 769 "perly.y" + case 152: +#line 966 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 138: -#line 771 "perly.y" + case 153: +#line 968 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 139: -#line 773 "perly.y" + case 154: +#line 970 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 140: -#line 775 "perly.y" + case 155: +#line 972 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 141: -#line 777 "perly.y" + case 156: +#line 974 "perly.y" { (yyval.opval) = newBINOP((ps[(2) - (3)].val.ival), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 142: -#line 779 "perly.y" + case 157: +#line 976 "perly.y" { (yyval.opval) = newRANGE((ps[(2) - (3)].val.ival), scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval))); ;} break; - case 143: -#line 781 "perly.y" + case 158: +#line 978 "perly.y" { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 144: -#line 783 "perly.y" + case 159: +#line 980 "perly.y" { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 145: -#line 785 "perly.y" + case 160: +#line 982 "perly.y" { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 146: -#line 787 "perly.y" + case 161: +#line 984 "perly.y" { (yyval.opval) = bind_match((ps[(2) - (3)].val.ival), (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval)); ;} break; - case 147: -#line 792 "perly.y" + case 162: +#line 989 "perly.y" { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[(2) - (2)].val.opval))); ;} break; - case 148: -#line 794 "perly.y" + case 163: +#line 991 "perly.y" { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} break; - case 149: -#line 797 "perly.y" + case 164: +#line 994 "perly.y" { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[(2) - (2)].val.opval))); ;} break; - case 150: -#line 799 "perly.y" - { (yyval.opval) = newUNOP(OP_COMPLEMENT, 0, scalar((ps[(2) - (2)].val.opval))); ;} + case 165: +#line 996 "perly.y" + { (yyval.opval) = newUNOP((ps[(1) - (2)].val.ival), 0, scalar((ps[(2) - (2)].val.opval))); ;} break; - case 151: -#line 801 "perly.y" + case 166: +#line 998 "perly.y" { (yyval.opval) = newUNOP(OP_POSTINC, 0, op_lvalue(scalar((ps[(1) - (2)].val.opval)), OP_POSTINC)); ;} break; - case 152: -#line 804 "perly.y" + case 167: +#line 1001 "perly.y" { (yyval.opval) = newUNOP(OP_POSTDEC, 0, op_lvalue(scalar((ps[(1) - (2)].val.opval)), OP_POSTDEC));;} break; - case 153: -#line 807 "perly.y" + case 168: +#line 1004 "perly.y" { (yyval.opval) = op_convert_list(OP_JOIN, 0, op_append_elem( OP_LIST, @@ -1018,121 +1222,139 @@ case 2: ;} break; - case 154: -#line 818 "perly.y" + case 169: +#line 1015 "perly.y" { (yyval.opval) = newUNOP(OP_PREINC, 0, op_lvalue(scalar((ps[(2) - (2)].val.opval)), OP_PREINC)); ;} break; - case 155: -#line 821 "perly.y" + case 170: +#line 1018 "perly.y" { (yyval.opval) = newUNOP(OP_PREDEC, 0, op_lvalue(scalar((ps[(2) - (2)].val.opval)), OP_PREDEC)); ;} break; - case 156: -#line 828 "perly.y" + case 171: +#line 1025 "perly.y" { (yyval.opval) = newANONLIST((ps[(2) - (3)].val.opval)); ;} break; - case 157: -#line 830 "perly.y" + case 172: +#line 1027 "perly.y" { (yyval.opval) = newANONLIST((OP*)NULL);;} break; - case 158: -#line 832 "perly.y" + case 173: +#line 1029 "perly.y" { (yyval.opval) = newANONHASH((ps[(2) - (4)].val.opval)); ;} break; - case 159: -#line 834 "perly.y" + case 174: +#line 1031 "perly.y" { (yyval.opval) = newANONHASH((OP*)NULL); ;} break; - case 160: -#line 836 "perly.y" + case 175: +#line 1033 "perly.y" { SvREFCNT_inc_simple_void(PL_compcv); (yyval.opval) = newANONATTRSUB((ps[(2) - (5)].val.ival), (ps[(3) - (5)].val.opval), (ps[(4) - (5)].val.opval), (ps[(5) - (5)].val.opval)); ;} break; - case 161: -#line 843 "perly.y" + case 176: +#line 1036 "perly.y" + { + OP *body; + if (parser->copline > (line_t)(ps[(6) - (8)].val.ival)) + parser->copline = (line_t)(ps[(6) - (8)].val.ival); + body = block_end((ps[(3) - (8)].val.ival), + op_append_list(OP_LINESEQ, (ps[(4) - (8)].val.opval), (ps[(7) - (8)].val.opval))); + SvREFCNT_inc_simple_void(PL_compcv); + (yyval.opval) = newANONATTRSUB((ps[(2) - (8)].val.ival), NULL, (ps[(5) - (8)].val.opval), body); + ;} + break; + + case 177: +#line 1050 "perly.y" { (yyval.opval) = dofile((ps[(2) - (2)].val.opval), (ps[(1) - (2)].val.ival));;} break; - case 162: -#line 845 "perly.y" + case 178: +#line 1052 "perly.y" { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[(2) - (2)].val.opval)));;} break; - case 167: -#line 853 "perly.y" + case 183: +#line 1060 "perly.y" { (yyval.opval) = newCONDOP(0, (ps[(1) - (5)].val.opval), (ps[(3) - (5)].val.opval), (ps[(5) - (5)].val.opval)); ;} break; - case 168: -#line 855 "perly.y" - { (yyval.opval) = newUNOP(OP_REFGEN, 0, op_lvalue((ps[(2) - (2)].val.opval),OP_REFGEN)); ;} + case 184: +#line 1062 "perly.y" + { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[(2) - (2)].val.opval)); ;} break; - case 169: -#line 857 "perly.y" + case 185: +#line 1064 "perly.y" + { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[(3) - (3)].val.opval),1)); ;} + break; + + case 186: +#line 1066 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 170: -#line 859 "perly.y" - { (yyval.opval) = localize((ps[(2) - (2)].val.opval),(ps[(1) - (2)].val.ival)); ;} + case 187: +#line 1068 "perly.y" + { (yyval.opval) = localize((ps[(2) - (2)].val.opval),0); ;} break; - case 171: -#line 861 "perly.y" + case 188: +#line 1070 "perly.y" { (yyval.opval) = sawparens((ps[(2) - (3)].val.opval)); ;} break; - case 172: -#line 863 "perly.y" + case 189: +#line 1072 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 173: -#line 865 "perly.y" + case 190: +#line 1074 "perly.y" { (yyval.opval) = sawparens(newNULLLIST()); ;} break; - case 174: -#line 867 "perly.y" + case 191: +#line 1076 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 175: -#line 869 "perly.y" + case 192: +#line 1078 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 176: -#line 871 "perly.y" + case 193: +#line 1080 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 177: -#line 873 "perly.y" + case 194: +#line 1082 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 178: -#line 875 "perly.y" + case 195: +#line 1084 "perly.y" { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[(1) - (1)].val.opval), OP_AV2ARYLEN));;} break; - case 179: -#line 877 "perly.y" + case 196: +#line 1086 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 180: -#line 879 "perly.y" + case 197: +#line 1088 "perly.y" { (yyval.opval) = op_prepend_elem(OP_ASLICE, newOP(OP_PUSHMARK, 0), newLISTOP(OP_ASLICE, 0, @@ -1144,8 +1366,8 @@ case 2: ;} break; - case 181: -#line 889 "perly.y" + case 198: +#line 1098 "perly.y" { (yyval.opval) = op_prepend_elem(OP_KVASLICE, newOP(OP_PUSHMARK, 0), newLISTOP(OP_KVASLICE, 0, @@ -1157,8 +1379,8 @@ case 2: ;} break; - case 182: -#line 899 "perly.y" + case 199: +#line 1108 "perly.y" { (yyval.opval) = op_prepend_elem(OP_HSLICE, newOP(OP_PUSHMARK, 0), newLISTOP(OP_HSLICE, 0, @@ -1170,8 +1392,8 @@ case 2: ;} break; - case 183: -#line 909 "perly.y" + case 200: +#line 1118 "perly.y" { (yyval.opval) = op_prepend_elem(OP_KVHSLICE, newOP(OP_PUSHMARK, 0), newLISTOP(OP_KVHSLICE, 0, @@ -1183,154 +1405,154 @@ case 2: ;} break; - case 184: -#line 919 "perly.y" + case 201: +#line 1128 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 185: -#line 921 "perly.y" + case 202: +#line 1130 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[(1) - (1)].val.opval))); ;} break; - case 186: -#line 923 "perly.y" + case 203: +#line 1132 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[(1) - (3)].val.opval))); ;} break; - case 187: -#line 926 "perly.y" + case 204: +#line 1135 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, (ps[(3) - (4)].val.opval), scalar((ps[(1) - (4)].val.opval)))); ;} break; - case 188: -#line 931 "perly.y" + case 205: +#line 1140 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, (ps[(3) - (3)].val.opval), scalar((ps[(2) - (3)].val.opval)))); ;} break; - case 189: -#line 935 "perly.y" + case 206: +#line 1144 "perly.y" { (yyval.opval) = newSVREF((ps[(1) - (4)].val.opval)); ;} break; - case 190: -#line 937 "perly.y" + case 207: +#line 1146 "perly.y" { (yyval.opval) = newAVREF((ps[(1) - (4)].val.opval)); ;} break; - case 191: -#line 939 "perly.y" + case 208: +#line 1148 "perly.y" { (yyval.opval) = newHVREF((ps[(1) - (4)].val.opval)); ;} break; - case 192: -#line 941 "perly.y" + case 209: +#line 1150 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar(newCVREF((ps[(3) - (4)].val.ival),(ps[(1) - (4)].val.opval)))); ;} break; - case 193: -#line 944 "perly.y" + case 210: +#line 1153 "perly.y" { (yyval.opval) = newGVREF(0,(ps[(1) - (4)].val.opval)); ;} break; - case 194: -#line 946 "perly.y" + case 211: +#line 1155 "perly.y" { (yyval.opval) = newOP((ps[(1) - (1)].val.ival), OPf_SPECIAL); PL_hints |= HINT_BLOCK_SCOPE; ;} break; - case 195: -#line 949 "perly.y" + case 212: +#line 1158 "perly.y" { (yyval.opval) = newLOOPEX((ps[(1) - (2)].val.ival),(ps[(2) - (2)].val.opval)); ;} break; - case 196: -#line 951 "perly.y" + case 213: +#line 1160 "perly.y" { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[(2) - (2)].val.opval))); ;} break; - case 197: -#line 953 "perly.y" + case 214: +#line 1162 "perly.y" { (yyval.opval) = newOP((ps[(1) - (1)].val.ival), 0); ;} break; - case 198: -#line 955 "perly.y" + case 215: +#line 1164 "perly.y" { (yyval.opval) = newUNOP((ps[(1) - (2)].val.ival), 0, (ps[(2) - (2)].val.opval)); ;} break; - case 199: -#line 957 "perly.y" + case 216: +#line 1166 "perly.y" { (yyval.opval) = newUNOP((ps[(1) - (2)].val.ival), 0, (ps[(2) - (2)].val.opval)); ;} break; - case 200: -#line 959 "perly.y" + case 217: +#line 1168 "perly.y" { (yyval.opval) = newOP(OP_REQUIRE, (ps[(1) - (1)].val.ival) ? OPf_SPECIAL : 0); ;} break; - case 201: -#line 961 "perly.y" + case 218: +#line 1170 "perly.y" { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[(1) - (2)].val.ival) ? OPf_SPECIAL : 0, (ps[(2) - (2)].val.opval)); ;} break; - case 202: -#line 963 "perly.y" + case 219: +#line 1172 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[(1) - (1)].val.opval))); ;} break; - case 203: -#line 965 "perly.y" + case 220: +#line 1174 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, op_append_elem(OP_LIST, (ps[(2) - (2)].val.opval), scalar((ps[(1) - (2)].val.opval)))); ;} break; - case 204: -#line 968 "perly.y" + case 221: +#line 1177 "perly.y" { (yyval.opval) = newOP((ps[(1) - (1)].val.ival), 0); ;} break; - case 205: -#line 970 "perly.y" + case 222: +#line 1179 "perly.y" { (yyval.opval) = newOP((ps[(1) - (3)].val.ival), 0);;} break; - case 206: -#line 972 "perly.y" + case 223: +#line 1181 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 207: -#line 974 "perly.y" + case 224: +#line 1183 "perly.y" { (yyval.opval) = (ps[(1) - (3)].val.opval); ;} break; - case 208: -#line 976 "perly.y" + case 225: +#line 1185 "perly.y" { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[(1) - (1)].val.opval))); ;} break; - case 209: -#line 978 "perly.y" + case 226: +#line 1187 "perly.y" { (yyval.opval) = ((ps[(1) - (3)].val.ival) == OP_NOT) ? newUNOP((ps[(1) - (3)].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0))) : newOP((ps[(1) - (3)].val.ival), OPf_SPECIAL); ;} break; - case 210: -#line 982 "perly.y" + case 227: +#line 1191 "perly.y" { (yyval.opval) = newUNOP((ps[(1) - (4)].val.ival), 0, (ps[(3) - (4)].val.opval)); ;} break; - case 211: -#line 984 "perly.y" + case 228: +#line 1193 "perly.y" { if ( (ps[(1) - (1)].val.opval)->op_type != OP_TRANS && (ps[(1) - (1)].val.opval)->op_type != OP_TRANSR @@ -1343,150 +1565,165 @@ case 2: ;} break; - case 212: -#line 995 "perly.y" - { (yyval.opval) = pmruntime((ps[(1) - (5)].val.opval), (ps[(4) - (5)].val.opval), 1, (ps[(2) - (5)].val.ival)); ;} + case 229: +#line 1204 "perly.y" + { (yyval.opval) = pmruntime((ps[(1) - (6)].val.opval), (ps[(4) - (6)].val.opval), (ps[(5) - (6)].val.opval), 1, (ps[(2) - (6)].val.ival)); ;} break; - case 215: -#line 999 "perly.y" + case 232: +#line 1208 "perly.y" { (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0), newSVOP(OP_CONST, 0, newSVpvs("Unimplemented"))); ;} break; - case 217: -#line 1008 "perly.y" + case 234: +#line 1217 "perly.y" { (yyval.opval) = my_attrs((ps[(2) - (3)].val.opval),(ps[(3) - (3)].val.opval)); ;} break; - case 218: -#line 1010 "perly.y" - { (yyval.opval) = localize((ps[(2) - (2)].val.opval),(ps[(1) - (2)].val.ival)); ;} + case 235: +#line 1219 "perly.y" + { (yyval.opval) = localize((ps[(2) - (2)].val.opval),1); ;} break; - case 219: -#line 1015 "perly.y" + case 236: +#line 1221 "perly.y" + { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[(3) - (4)].val.opval),(ps[(4) - (4)].val.opval))); ;} + break; + + case 237: +#line 1226 "perly.y" { (yyval.opval) = sawparens((ps[(2) - (3)].val.opval)); ;} break; - case 220: -#line 1017 "perly.y" + case 238: +#line 1228 "perly.y" { (yyval.opval) = sawparens(newNULLLIST()); ;} break; - case 221: -#line 1020 "perly.y" + case 239: +#line 1231 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 222: -#line 1022 "perly.y" + case 240: +#line 1233 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 223: -#line 1024 "perly.y" + case 241: +#line 1235 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 224: -#line 1029 "perly.y" + case 242: +#line 1240 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 225: -#line 1031 "perly.y" + case 243: +#line 1242 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 226: -#line 1035 "perly.y" + case 244: +#line 1246 "perly.y" { (yyval.opval) = (OP*)NULL; ;} break; - case 227: -#line 1037 "perly.y" + case 245: +#line 1248 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; - case 228: -#line 1043 "perly.y" + case 246: +#line 1252 "perly.y" + { (yyval.opval) = (OP*)NULL; ;} + break; + + case 247: +#line 1254 "perly.y" + { (yyval.opval) = (ps[(2) - (2)].val.opval); ;} + break; + + case 248: +#line 1260 "perly.y" { parser->in_my = 0; (yyval.opval) = my((ps[(1) - (1)].val.opval)); ;} break; - case 234: -#line 1056 "perly.y" + case 256: +#line 1277 "perly.y" { (yyval.opval) = newCVREF((ps[(1) - (2)].val.ival),(ps[(2) - (2)].val.opval)); ;} break; - case 235: -#line 1060 "perly.y" + case 257: +#line 1281 "perly.y" { (yyval.opval) = newSVREF((ps[(2) - (2)].val.opval)); ;} break; - case 236: -#line 1064 "perly.y" + case 258: +#line 1285 "perly.y" { (yyval.opval) = newAVREF((ps[(2) - (2)].val.opval)); if ((yyval.opval)) (yyval.opval)->op_private |= (ps[(1) - (2)].val.ival); ;} break; - case 237: -#line 1070 "perly.y" + case 259: +#line 1291 "perly.y" { (yyval.opval) = newHVREF((ps[(2) - (2)].val.opval)); if ((yyval.opval)) (yyval.opval)->op_private |= (ps[(1) - (2)].val.ival); ;} break; - case 238: -#line 1076 "perly.y" + case 260: +#line 1297 "perly.y" { (yyval.opval) = newAVREF((ps[(2) - (2)].val.opval)); ;} break; - case 239: -#line 1078 "perly.y" + case 261: +#line 1299 "perly.y" { (yyval.opval) = newAVREF((ps[(1) - (4)].val.opval)); ;} break; - case 240: -#line 1082 "perly.y" + case 262: +#line 1303 "perly.y" { (yyval.opval) = newGVREF(0,(ps[(2) - (2)].val.opval)); ;} break; - case 242: -#line 1087 "perly.y" + case 264: +#line 1308 "perly.y" { (yyval.opval) = newAVREF((ps[(1) - (3)].val.opval)); ;} break; - case 244: -#line 1092 "perly.y" + case 266: +#line 1313 "perly.y" { (yyval.opval) = newHVREF((ps[(1) - (3)].val.opval)); ;} break; - case 246: -#line 1097 "perly.y" + case 268: +#line 1318 "perly.y" { (yyval.opval) = newGVREF(0,(ps[(1) - (3)].val.opval)); ;} break; - case 247: -#line 1102 "perly.y" + case 269: +#line 1323 "perly.y" { (yyval.opval) = scalar((ps[(1) - (1)].val.opval)); ;} break; - case 248: -#line 1104 "perly.y" + case 270: +#line 1325 "perly.y" { (yyval.opval) = scalar((ps[(1) - (1)].val.opval)); ;} break; - case 249: -#line 1106 "perly.y" + case 271: +#line 1327 "perly.y" { (yyval.opval) = op_scope((ps[(1) - (1)].val.opval)); ;} break; - case 250: -#line 1109 "perly.y" + case 272: +#line 1330 "perly.y" { (yyval.opval) = (ps[(1) - (1)].val.opval); ;} break; @@ -1497,6 +1734,6 @@ case 2: /* Generated from: - * aa8cc2f0979e92f76ac0fbc21000e975a6a443beed009e907eddb57f3d8dbe6a perly.y - * d1d4df7b8e30ac9dede664af9179e6e5e7ddc7f2ad9c4eff9e2e5b32c9e16a6e regen_perly.pl + * b1f32b9f6f7c53d22517de00b5b5bfe4dd9d657c8573b9ea9eab7a43e852850a perly.y + * 3e1dff60f26df8933d7aed0c0e87177a0f022c14800c0707eb62a7db4196ac98 regen_perly.pl * ex: set ro: */