3 { (yyval.ival) = (ps[(2) - (2)].val.ival); ;}
9 PL_eval_root = (ps[(2) - (2)].val.opval);
12 parser->yychar = YYEOF;
18 { (yyval.ival) = (ps[(1) - (2)].val.ival); newPROG(block_end((ps[(1) - (2)].val.ival),(ps[(2) - (2)].val.opval))); ;}
23 { if (PL_parser->copline > (line_t)IVAL((ps[(1) - (4)].val.i_tkval)))
24 PL_parser->copline = (line_t)IVAL((ps[(1) - (4)].val.i_tkval));
25 (yyval.opval) = block_end((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval));
26 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'{');
27 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),'}');
33 { (yyval.ival) = block_start(TRUE); ;}
38 { (yyval.ival) = (I32) Perl_allocmy(aTHX_ STR_WITH_LEN("$_"), 0); ;}
44 PL_parser->expect = XSTATE; (yyval.ival) = block_start(TRUE);
50 { if (PL_parser->copline > (line_t)IVAL((ps[(1) - (4)].val.i_tkval)))
51 PL_parser->copline = (line_t)IVAL((ps[(1) - (4)].val.i_tkval));
52 (yyval.opval) = block_end((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval));
53 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'{');
54 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),'}');
60 { (yyval.ival) = block_start(FALSE); ;}
65 { (yyval.opval) = (OP*)NULL; ;}
71 (yyval.opval) = IF_MAD(
72 append_list(OP_LINESEQ,
73 (LISTOP*)(ps[(1) - (2)].val.opval), (LISTOP*)(ps[(2) - (2)].val.opval)),
74 (ps[(1) - (2)].val.opval));
80 { (yyval.opval) = append_list(OP_LINESEQ,
81 (LISTOP*)(ps[(1) - (2)].val.opval), (LISTOP*)(ps[(2) - (2)].val.opval));
82 PL_pad_reset_pending = TRUE;
83 if ((ps[(1) - (2)].val.opval) && (ps[(2) - (2)].val.opval))
84 PL_hints |= HINT_BLOCK_SCOPE;
90 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
96 PL_pad_reset_pending = TRUE;
97 (yyval.opval) = (ps[(1) - (1)].val.opval);
103 { (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (2)].val.p_tkval)), (ps[(2) - (2)].val.opval));
104 TOKEN_GETMAD((ps[(1) - (2)].val.p_tkval),((LISTOP*)(yyval.opval))->op_first,'L'); ;}
109 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
114 { (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (2)].val.p_tkval)), (ps[(2) - (2)].val.opval)); ;}
120 if (PVAL((ps[(1) - (2)].val.p_tkval))) {
121 (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (2)].val.p_tkval)), newOP(OP_NULL, 0));
122 TOKEN_GETMAD((ps[(1) - (2)].val.p_tkval),(yyval.opval),'L');
123 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),((LISTOP*)(yyval.opval))->op_first,';');
126 (yyval.opval) = IF_MAD(
129 PL_parser->copline = NOLINE;
130 TOKEN_FREE((ps[(1) - (2)].val.p_tkval));
131 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),';');
133 PL_parser->expect = XSTATE;
140 (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (3)].val.p_tkval)), (ps[(2) - (3)].val.opval));
141 PL_parser->expect = XSTATE;
143 /* sideff might already have a nexstate */
144 OP* op = ((LISTOP*)(yyval.opval))->op_first;
146 while (op->op_sibling &&
147 op->op_sibling->op_type == OP_NEXTSTATE)
149 token_getmad((ps[(1) - (3)].val.p_tkval),op,'L');
150 token_getmad((ps[(3) - (3)].val.i_tkval),op,';');
158 { (yyval.opval) = newSTATEOP(0, NULL,
159 newWHILEOP(0, 1, (LOOP*)(OP*)NULL,
160 NOLINE, (OP*)NULL, (ps[(1) - (1)].val.opval),
166 { (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (2)].val.p_tkval)), (ps[(2) - (2)].val.opval)); ;}
171 { (yyval.opval) = (OP*)NULL; ;}
176 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
181 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval));
182 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'i');
188 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval));
189 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'i');
195 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[(3) - (3)].val.opval)), (ps[(1) - (3)].val.opval));
196 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'w');
202 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval));
203 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'w');
209 { (yyval.opval) = newFOROP(0, NULL, (line_t)IVAL((ps[(2) - (3)].val.i_tkval)),
210 (OP*)NULL, (ps[(3) - (3)].val.opval), (ps[(1) - (3)].val.opval), (OP*)NULL);
211 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),((LISTOP*)(yyval.opval))->op_first->op_sibling,'w');
217 { (yyval.opval) = newWHENOP((ps[(3) - (3)].val.opval), scope((ps[(1) - (3)].val.opval))); ;}
222 { (yyval.opval) = (OP*)NULL; ;}
227 { ((ps[(2) - (2)].val.opval))->op_flags |= OPf_PARENS; (yyval.opval) = scope((ps[(2) - (2)].val.opval));
228 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
234 { PL_parser->copline = (line_t)IVAL((ps[(1) - (6)].val.i_tkval));
235 (yyval.opval) = newCONDOP(0, newSTATEOP(OPf_SPECIAL,NULL,(ps[(3) - (6)].val.opval)), scope((ps[(5) - (6)].val.opval)), (ps[(6) - (6)].val.opval));
236 PL_hints |= HINT_BLOCK_SCOPE;
237 TOKEN_GETMAD((ps[(1) - (6)].val.i_tkval),(yyval.opval),'I');
238 TOKEN_GETMAD((ps[(2) - (6)].val.i_tkval),(yyval.opval),'(');
239 TOKEN_GETMAD((ps[(4) - (6)].val.i_tkval),(yyval.opval),')');
245 { PL_parser->copline = (line_t)IVAL((ps[(1) - (7)].val.i_tkval));
246 (yyval.opval) = block_end((ps[(3) - (7)].val.ival),
247 newCONDOP(0, (ps[(4) - (7)].val.opval), scope((ps[(6) - (7)].val.opval)), (ps[(7) - (7)].val.opval)));
248 TOKEN_GETMAD((ps[(1) - (7)].val.i_tkval),(yyval.opval),'I');
249 TOKEN_GETMAD((ps[(2) - (7)].val.i_tkval),(yyval.opval),'(');
250 TOKEN_GETMAD((ps[(5) - (7)].val.i_tkval),(yyval.opval),')');
256 { PL_parser->copline = (line_t)IVAL((ps[(1) - (7)].val.i_tkval));
257 (yyval.opval) = block_end((ps[(3) - (7)].val.ival),
258 newCONDOP(0, (ps[(4) - (7)].val.opval), scope((ps[(6) - (7)].val.opval)), (ps[(7) - (7)].val.opval)));
259 TOKEN_GETMAD((ps[(1) - (7)].val.i_tkval),(yyval.opval),'I');
260 TOKEN_GETMAD((ps[(2) - (7)].val.i_tkval),(yyval.opval),'(');
261 TOKEN_GETMAD((ps[(5) - (7)].val.i_tkval),(yyval.opval),')');
267 { (yyval.opval) = block_end((ps[(3) - (6)].val.ival),
268 newWHENOP((ps[(4) - (6)].val.opval), scope((ps[(6) - (6)].val.opval)))); ;}
273 { (yyval.opval) = newWHENOP(0, scope((ps[(2) - (2)].val.opval))); ;}
278 { (yyval.opval) = (OP*)NULL; ;}
283 { (yyval.opval) = scope((ps[(2) - (2)].val.opval));
284 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
291 PL_parser->copline = (line_t)IVAL((ps[(2) - (9)].val.i_tkval));
292 (yyval.opval) = block_end((ps[(4) - (9)].val.ival),
293 newSTATEOP(0, PVAL((ps[(1) - (9)].val.p_tkval)),
294 innerop = newWHILEOP(0, 1, (LOOP*)(OP*)NULL,
295 IVAL((ps[(2) - (9)].val.i_tkval)), (ps[(5) - (9)].val.opval), (ps[(8) - (9)].val.opval), (ps[(9) - (9)].val.opval), (ps[(7) - (9)].val.ival))));
296 TOKEN_GETMAD((ps[(1) - (9)].val.p_tkval),innerop,'L');
297 TOKEN_GETMAD((ps[(2) - (9)].val.i_tkval),innerop,'W');
298 TOKEN_GETMAD((ps[(3) - (9)].val.i_tkval),innerop,'(');
299 TOKEN_GETMAD((ps[(6) - (9)].val.i_tkval),innerop,')');
306 PL_parser->copline = (line_t)IVAL((ps[(2) - (9)].val.i_tkval));
307 (yyval.opval) = block_end((ps[(4) - (9)].val.ival),
308 newSTATEOP(0, PVAL((ps[(1) - (9)].val.p_tkval)),
309 innerop = newWHILEOP(0, 1, (LOOP*)(OP*)NULL,
310 IVAL((ps[(2) - (9)].val.i_tkval)), (ps[(5) - (9)].val.opval), (ps[(8) - (9)].val.opval), (ps[(9) - (9)].val.opval), (ps[(7) - (9)].val.ival))));
311 TOKEN_GETMAD((ps[(1) - (9)].val.p_tkval),innerop,'L');
312 TOKEN_GETMAD((ps[(2) - (9)].val.i_tkval),innerop,'W');
313 TOKEN_GETMAD((ps[(3) - (9)].val.i_tkval),innerop,'(');
314 TOKEN_GETMAD((ps[(6) - (9)].val.i_tkval),innerop,')');
321 (yyval.opval) = block_end((ps[(4) - (10)].val.ival),
322 innerop = newFOROP(0, PVAL((ps[(1) - (10)].val.p_tkval)), (line_t)IVAL((ps[(2) - (10)].val.i_tkval)),
323 (ps[(5) - (10)].val.opval), (ps[(7) - (10)].val.opval), (ps[(9) - (10)].val.opval), (ps[(10) - (10)].val.opval)));
324 TOKEN_GETMAD((ps[(1) - (10)].val.p_tkval),((LISTOP*)innerop)->op_first,'L');
325 TOKEN_GETMAD((ps[(2) - (10)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'W');
326 TOKEN_GETMAD((ps[(3) - (10)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'d');
327 TOKEN_GETMAD((ps[(6) - (10)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'(');
328 TOKEN_GETMAD((ps[(8) - (10)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,')');
335 (yyval.opval) = block_end((ps[(5) - (9)].val.ival),
336 innerop = newFOROP(0, PVAL((ps[(1) - (9)].val.p_tkval)), (line_t)IVAL((ps[(2) - (9)].val.i_tkval)),
337 mod((ps[(3) - (9)].val.opval), OP_ENTERLOOP), (ps[(6) - (9)].val.opval), (ps[(8) - (9)].val.opval), (ps[(9) - (9)].val.opval)));
338 TOKEN_GETMAD((ps[(1) - (9)].val.p_tkval),((LISTOP*)innerop)->op_first,'L');
339 TOKEN_GETMAD((ps[(2) - (9)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'W');
340 TOKEN_GETMAD((ps[(4) - (9)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'(');
341 TOKEN_GETMAD((ps[(7) - (9)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,')');
348 (yyval.opval) = block_end((ps[(4) - (8)].val.ival),
349 innerop = newFOROP(0, PVAL((ps[(1) - (8)].val.p_tkval)), (line_t)IVAL((ps[(2) - (8)].val.i_tkval)),
350 (OP*)NULL, (ps[(5) - (8)].val.opval), (ps[(7) - (8)].val.opval), (ps[(8) - (8)].val.opval)));
351 TOKEN_GETMAD((ps[(1) - (8)].val.p_tkval),((LISTOP*)innerop)->op_first,'L');
352 TOKEN_GETMAD((ps[(2) - (8)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'W');
353 TOKEN_GETMAD((ps[(3) - (8)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,'(');
354 TOKEN_GETMAD((ps[(6) - (8)].val.i_tkval),((LISTOP*)innerop)->op_first->op_sibling,')');
361 PL_parser->copline = (line_t)IVAL((ps[(2) - (12)].val.i_tkval));
362 forop = newSTATEOP(0, PVAL((ps[(1) - (12)].val.p_tkval)),
363 newWHILEOP(0, 1, (LOOP*)(OP*)NULL,
364 IVAL((ps[(2) - (12)].val.i_tkval)), scalar((ps[(7) - (12)].val.opval)),
365 (ps[(12) - (12)].val.opval), (ps[(10) - (12)].val.opval), (ps[(9) - (12)].val.ival)));
367 forop = newUNOP(OP_NULL, 0, append_elem(OP_LINESEQ,
369 CopLABEL_alloc(((ps[(1) - (12)].val.p_tkval))->tk_lval.pval),
370 ((ps[(5) - (12)].val.opval) ? (ps[(5) - (12)].val.opval) : newOP(OP_NULL, 0)) ),
373 token_getmad((ps[(2) - (12)].val.i_tkval),forop,'3');
374 token_getmad((ps[(3) - (12)].val.i_tkval),forop,'(');
375 token_getmad((ps[(6) - (12)].val.i_tkval),forop,'1');
376 token_getmad((ps[(8) - (12)].val.i_tkval),forop,'2');
377 token_getmad((ps[(11) - (12)].val.i_tkval),forop,')');
378 token_getmad((ps[(1) - (12)].val.p_tkval),forop,'L');
380 if ((ps[(5) - (12)].val.opval)) {
381 forop = append_elem(OP_LINESEQ,
382 newSTATEOP(0, CopLABEL_alloc((ps[(1) - (12)].val.p_tkval)), (ps[(5) - (12)].val.opval)),
388 (yyval.opval) = block_end((ps[(4) - (12)].val.ival), forop); ;}
393 { (yyval.opval) = newSTATEOP(0, PVAL((ps[(1) - (3)].val.p_tkval)),
394 newWHILEOP(0, 1, (LOOP*)(OP*)NULL,
395 NOLINE, (OP*)NULL, (ps[(2) - (3)].val.opval), (ps[(3) - (3)].val.opval), 0));
396 TOKEN_GETMAD((ps[(1) - (3)].val.p_tkval),((LISTOP*)(yyval.opval))->op_first,'L'); ;}
401 { PL_parser->copline = (line_t) IVAL((ps[(2) - (8)].val.i_tkval));
402 (yyval.opval) = block_end((ps[(4) - (8)].val.ival),
403 newSTATEOP(0, PVAL((ps[(1) - (8)].val.p_tkval)),
404 newGIVENOP((ps[(6) - (8)].val.opval), scope((ps[(8) - (8)].val.opval)),
405 (PADOFFSET) (ps[(5) - (8)].val.ival)) )); ;}
410 { (yyval.ival) = (PL_min_intro_pending &&
411 PL_max_intro_pending >= PL_min_intro_pending);
417 { (yyval.opval) = (OP*)NULL; ;}
423 (void)scan_num("1", &tmplval);
424 (yyval.opval) = tmplval.opval; ;}
429 { (yyval.opval) = invert(scalar((ps[(1) - (1)].val.opval))); ;}
434 { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;}
439 { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;}
444 { (yyval.opval) = (ps[(1) - (1)].val.opval); intro_my(); ;}
453 (yyval.p_tkval) = newTOKEN(OP_NULL, tmplval, 0);
455 (yyval.p_tkval) = NULL;
462 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
467 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
472 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
477 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
482 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
487 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
492 { (yyval.opval) = newOP(OP_NULL,0);
493 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'p');
500 CV *fmtcv = PL_compcv;
501 SvREFCNT_inc_simple_void(PL_compcv);
503 (yyval.opval) = newFORM((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval), (ps[(4) - (4)].val.opval));
504 prepend_madprops((ps[(1) - (4)].val.i_tkval)->tk_mad, (yyval.opval), 'F');
505 (ps[(1) - (4)].val.i_tkval)->tk_mad = 0;
506 token_free((ps[(1) - (4)].val.i_tkval));
508 newFORM((ps[(2) - (4)].val.ival), (ps[(3) - (4)].val.opval), (ps[(4) - (4)].val.opval));
509 (yyval.opval) = (OP*)NULL;
511 if (CvOUTSIDE(fmtcv) && !CvUNIQUE(CvOUTSIDE(fmtcv))) {
512 SvREFCNT_inc_simple_void(fmtcv);
513 pad_add_anon((SV*)fmtcv, OP_NULL);
520 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
525 { (yyval.opval) = (OP*)NULL; ;}
530 { SvREFCNT_inc_simple_void(PL_compcv);
532 (yyval.opval) = newMYSUB((ps[(2) - (6)].val.ival), (ps[(3) - (6)].val.opval), (ps[(4) - (6)].val.opval), (ps[(5) - (6)].val.opval), (ps[(6) - (6)].val.opval));
533 token_getmad((ps[(1) - (6)].val.i_tkval),(yyval.opval),'d');
535 newMYSUB((ps[(2) - (6)].val.ival), (ps[(3) - (6)].val.opval), (ps[(4) - (6)].val.opval), (ps[(5) - (6)].val.opval), (ps[(6) - (6)].val.opval));
536 (yyval.opval) = (OP*)NULL;
543 { SvREFCNT_inc_simple_void(PL_compcv);
546 OP* o = newSVOP(OP_ANONCODE, 0,
547 (SV*)newATTRSUB((ps[(2) - (6)].val.ival), (ps[(3) - (6)].val.opval), (ps[(4) - (6)].val.opval), (ps[(5) - (6)].val.opval), (ps[(6) - (6)].val.opval)));
548 (yyval.opval) = newOP(OP_NULL,0);
549 op_getmad(o,(yyval.opval),'&');
550 op_getmad((ps[(3) - (6)].val.opval),(yyval.opval),'n');
551 op_getmad((ps[(4) - (6)].val.opval),(yyval.opval),'s');
552 op_getmad((ps[(5) - (6)].val.opval),(yyval.opval),'a');
553 token_getmad((ps[(1) - (6)].val.i_tkval),(yyval.opval),'d');
554 append_madprops((ps[(6) - (6)].val.opval)->op_madprop, (yyval.opval), 0);
555 (ps[(6) - (6)].val.opval)->op_madprop = 0;
558 newATTRSUB((ps[(2) - (6)].val.ival), (ps[(3) - (6)].val.opval), (ps[(4) - (6)].val.opval), (ps[(5) - (6)].val.opval), (ps[(6) - (6)].val.opval));
559 (yyval.opval) = (OP*)NULL;
566 { (yyval.ival) = start_subparse(FALSE, 0);
567 SAVEFREESV(PL_compcv); ;}
572 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
573 SAVEFREESV(PL_compcv); ;}
578 { (yyval.ival) = start_subparse(TRUE, 0);
579 SAVEFREESV(PL_compcv); ;}
584 { const char *const name = SvPV_nolen_const(((SVOP*)(ps[(1) - (1)].val.opval))->op_sv);
585 if (strEQ(name, "BEGIN") || strEQ(name, "END")
586 || strEQ(name, "INIT") || strEQ(name, "CHECK")
587 || strEQ(name, "UNITCHECK"))
588 CvSPECIAL_on(PL_compcv);
589 (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
594 { (yyval.opval) = (OP*)NULL; ;}
599 { (yyval.opval) = (OP*)NULL; ;}
604 { (yyval.opval) = (ps[(2) - (2)].val.opval);
605 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),':');
611 { (yyval.opval) = IF_MAD(
615 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),':');
621 { (yyval.opval) = (ps[(2) - (2)].val.opval);
622 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),':');
628 { (yyval.opval) = IF_MAD(
632 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),':');
638 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
643 { (yyval.opval) = IF_MAD(
647 PL_parser->expect = XSTATE;
648 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),';');
656 (yyval.opval) = package((ps[(3) - (4)].val.opval));
657 token_getmad((ps[(1) - (4)].val.i_tkval),(yyval.opval),'o');
658 if ((ps[(2) - (4)].val.opval))
659 package_version((ps[(2) - (4)].val.opval));
660 token_getmad((ps[(4) - (4)].val.i_tkval),(yyval.opval),';');
662 package((ps[(3) - (4)].val.opval));
663 if ((ps[(2) - (4)].val.opval))
664 package_version((ps[(2) - (4)].val.opval));
665 (yyval.opval) = (OP*)NULL;
673 int save_3_latefree = (ps[(3) - (5)].val.opval)->op_latefree;
674 (ps[(3) - (5)].val.opval)->op_latefree = 1;
675 package((ps[(3) - (5)].val.opval));
676 (ps[(3) - (5)].val.opval)->op_latefree = save_3_latefree;
677 if ((ps[(2) - (5)].val.opval)) {
678 int save_2_latefree = (ps[(2) - (5)].val.opval)->op_latefree;
679 (ps[(2) - (5)].val.opval)->op_latefree = 1;
680 package_version((ps[(2) - (5)].val.opval));
681 (ps[(2) - (5)].val.opval)->op_latefree = save_2_latefree;
688 { if (PL_parser->copline > (line_t)IVAL((ps[(4) - (8)].val.i_tkval)))
689 PL_parser->copline = (line_t)IVAL((ps[(4) - (8)].val.i_tkval));
690 (yyval.opval) = block_end((ps[(5) - (8)].val.ival), (ps[(7) - (8)].val.opval));
691 TOKEN_GETMAD((ps[(4) - (8)].val.i_tkval),(yyval.opval),'{');
692 TOKEN_GETMAD((ps[(8) - (8)].val.i_tkval),(yyval.opval),'}');
693 op_free((ps[(3) - (8)].val.opval));
694 if ((ps[(2) - (8)].val.opval))
695 op_free((ps[(2) - (8)].val.opval));
701 { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ ;}
706 { SvREFCNT_inc_simple_void(PL_compcv);
708 (yyval.opval) = utilize(IVAL((ps[(1) - (7)].val.i_tkval)), (ps[(2) - (7)].val.ival), (ps[(4) - (7)].val.opval), (ps[(5) - (7)].val.opval), (ps[(6) - (7)].val.opval));
709 token_getmad((ps[(1) - (7)].val.i_tkval),(yyval.opval),'o');
710 token_getmad((ps[(7) - (7)].val.i_tkval),(yyval.opval),';');
711 if (PL_parser->rsfp_filters &&
712 AvFILLp(PL_parser->rsfp_filters) >= 0)
713 append_madprops(newMADPROP('!', MAD_NULL, NULL, 0), (yyval.opval), 0);
715 utilize(IVAL((ps[(1) - (7)].val.i_tkval)), (ps[(2) - (7)].val.ival), (ps[(4) - (7)].val.opval), (ps[(5) - (7)].val.opval), (ps[(6) - (7)].val.opval));
716 (yyval.opval) = (OP*)NULL;
723 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
724 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
730 { (yyval.opval) = newLOGOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
731 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
737 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
738 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
746 OP* op = newNULLLIST();
747 token_getmad((ps[(2) - (2)].val.i_tkval),op,',');
748 (yyval.opval) = append_elem(OP_LIST, (ps[(1) - (2)].val.opval), op);
750 (yyval.opval) = (ps[(1) - (2)].val.opval);
758 OP* term = (ps[(3) - (3)].val.opval);
760 term = newUNOP(OP_NULL, 0, term);
761 token_getmad((ps[(2) - (3)].val.i_tkval),term,',');
763 (yyval.opval) = append_elem(OP_LIST, (ps[(1) - (3)].val.opval), term);
769 { (yyval.opval) = convert(IVAL((ps[(1) - (3)].val.i_tkval)), OPf_STACKED,
770 prepend_elem(OP_LIST, newGVREF(IVAL((ps[(1) - (3)].val.i_tkval)),(ps[(2) - (3)].val.opval)), (ps[(3) - (3)].val.opval)) );
771 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'o');
777 { (yyval.opval) = convert(IVAL((ps[(1) - (5)].val.i_tkval)), OPf_STACKED,
778 prepend_elem(OP_LIST, newGVREF(IVAL((ps[(1) - (5)].val.i_tkval)),(ps[(3) - (5)].val.opval)), (ps[(4) - (5)].val.opval)) );
779 TOKEN_GETMAD((ps[(1) - (5)].val.i_tkval),(yyval.opval),'o');
780 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'(');
781 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),')');
787 { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
789 prepend_elem(OP_LIST, scalar((ps[(1) - (6)].val.opval)), (ps[(5) - (6)].val.opval)),
790 newUNOP(OP_METHOD, 0, (ps[(3) - (6)].val.opval))));
791 TOKEN_GETMAD((ps[(2) - (6)].val.i_tkval),(yyval.opval),'A');
792 TOKEN_GETMAD((ps[(4) - (6)].val.i_tkval),(yyval.opval),'(');
793 TOKEN_GETMAD((ps[(6) - (6)].val.i_tkval),(yyval.opval),')');
799 { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
800 append_elem(OP_LIST, scalar((ps[(1) - (3)].val.opval)),
801 newUNOP(OP_METHOD, 0, (ps[(3) - (3)].val.opval))));
802 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'A');
808 { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
810 prepend_elem(OP_LIST, (ps[(2) - (3)].val.opval), (ps[(3) - (3)].val.opval)),
811 newUNOP(OP_METHOD, 0, (ps[(1) - (3)].val.opval))));
817 { (yyval.opval) = convert(OP_ENTERSUB, OPf_STACKED,
819 prepend_elem(OP_LIST, (ps[(2) - (5)].val.opval), (ps[(4) - (5)].val.opval)),
820 newUNOP(OP_METHOD, 0, (ps[(1) - (5)].val.opval))));
821 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'(');
822 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),')');
828 { (yyval.opval) = convert(IVAL((ps[(1) - (2)].val.i_tkval)), 0, (ps[(2) - (2)].val.opval));
829 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
835 { (yyval.opval) = convert(IVAL((ps[(1) - (4)].val.i_tkval)), 0, (ps[(3) - (4)].val.opval));
836 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'o');
837 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'(');
838 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
844 { SvREFCNT_inc_simple_void(PL_compcv);
845 (yyval.opval) = newANONATTRSUB((ps[(2) - (3)].val.ival), 0, (OP*)NULL, (ps[(3) - (3)].val.opval)); ;}
850 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
852 prepend_elem(OP_LIST, (ps[(4) - (5)].val.opval), (ps[(5) - (5)].val.opval)), (ps[(1) - (5)].val.opval)));
858 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[(1) - (5)].val.opval), scalar((ps[(3) - (5)].val.opval)));
859 PL_parser->expect = XOPERATOR;
860 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'{');
861 TOKEN_GETMAD((ps[(4) - (5)].val.i_tkval),(yyval.opval),';');
862 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),'}');
868 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[(1) - (4)].val.opval)), scalar((ps[(3) - (4)].val.opval)));
869 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'[');
870 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),']');
876 { (yyval.opval) = newBINOP(OP_AELEM, 0,
877 ref(newAVREF((ps[(1) - (5)].val.opval)),OP_RV2AV),
878 scalar((ps[(4) - (5)].val.opval)));
879 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'a');
880 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'[');
881 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),']');
887 { (yyval.opval) = newBINOP(OP_AELEM, 0,
888 ref(newAVREF((ps[(1) - (4)].val.opval)),OP_RV2AV),
889 scalar((ps[(3) - (4)].val.opval)));
890 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'[');
891 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),']');
897 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[(1) - (5)].val.opval)), jmaybe((ps[(3) - (5)].val.opval)));
898 PL_parser->expect = XOPERATOR;
899 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'{');
900 TOKEN_GETMAD((ps[(4) - (5)].val.i_tkval),(yyval.opval),';');
901 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),'}');
907 { (yyval.opval) = newBINOP(OP_HELEM, 0,
908 ref(newHVREF((ps[(1) - (6)].val.opval)),OP_RV2HV),
909 jmaybe((ps[(4) - (6)].val.opval)));
910 PL_parser->expect = XOPERATOR;
911 TOKEN_GETMAD((ps[(2) - (6)].val.i_tkval),(yyval.opval),'a');
912 TOKEN_GETMAD((ps[(3) - (6)].val.i_tkval),(yyval.opval),'{');
913 TOKEN_GETMAD((ps[(5) - (6)].val.i_tkval),(yyval.opval),';');
914 TOKEN_GETMAD((ps[(6) - (6)].val.i_tkval),(yyval.opval),'}');
920 { (yyval.opval) = newBINOP(OP_HELEM, 0,
921 ref(newHVREF((ps[(1) - (5)].val.opval)),OP_RV2HV),
922 jmaybe((ps[(3) - (5)].val.opval)));
923 PL_parser->expect = XOPERATOR;
924 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'{');
925 TOKEN_GETMAD((ps[(4) - (5)].val.i_tkval),(yyval.opval),';');
926 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),'}');
932 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
933 newCVREF(0, scalar((ps[(1) - (4)].val.opval))));
934 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'a');
935 TOKEN_GETMAD((ps[(3) - (4)].val.i_tkval),(yyval.opval),'(');
936 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
942 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
943 append_elem(OP_LIST, (ps[(4) - (5)].val.opval),
944 newCVREF(0, scalar((ps[(1) - (5)].val.opval)))));
945 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'a');
946 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'(');
947 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),')');
953 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
954 append_elem(OP_LIST, (ps[(3) - (4)].val.opval),
955 newCVREF(0, scalar((ps[(1) - (4)].val.opval)))));
956 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'(');
957 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
963 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
964 newCVREF(0, scalar((ps[(1) - (3)].val.opval))));
965 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'(');
966 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
972 { (yyval.opval) = newSLICEOP(0, (ps[(5) - (6)].val.opval), (ps[(2) - (6)].val.opval));
973 TOKEN_GETMAD((ps[(1) - (6)].val.i_tkval),(yyval.opval),'(');
974 TOKEN_GETMAD((ps[(3) - (6)].val.i_tkval),(yyval.opval),')');
975 TOKEN_GETMAD((ps[(4) - (6)].val.i_tkval),(yyval.opval),'[');
976 TOKEN_GETMAD((ps[(6) - (6)].val.i_tkval),(yyval.opval),']');
982 { (yyval.opval) = newSLICEOP(0, (ps[(3) - (4)].val.opval), (ps[(1) - (4)].val.opval));
983 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'[');
984 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),']');
990 { (yyval.opval) = newSLICEOP(0, (ps[(4) - (5)].val.opval), (OP*)NULL);
991 TOKEN_GETMAD((ps[(1) - (5)].val.i_tkval),(yyval.opval),'(');
992 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),')');
993 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'[');
994 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),']');
1000 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[(1) - (3)].val.opval), IVAL((ps[(2) - (3)].val.i_tkval)), (ps[(3) - (3)].val.opval));
1001 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1007 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1008 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1014 { if (IVAL((ps[(2) - (3)].val.i_tkval)) != OP_REPEAT)
1015 scalar((ps[(1) - (3)].val.opval));
1016 (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, (ps[(1) - (3)].val.opval), scalar((ps[(3) - (3)].val.opval)));
1017 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1023 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1024 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1030 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1031 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1037 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1038 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1044 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1045 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1051 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1052 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1058 { (yyval.opval) = newBINOP(IVAL((ps[(2) - (3)].val.i_tkval)), 0, scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1059 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1066 (yyval.opval) = newRANGE(IVAL((ps[(2) - (3)].val.i_tkval)), scalar((ps[(1) - (3)].val.opval)), scalar((ps[(3) - (3)].val.opval)));
1069 op = (UNOP*)(yyval.opval);
1070 op = (UNOP*)op->op_first; /* get to flop */
1071 op = (UNOP*)op->op_first; /* get to flip */
1072 op = (UNOP*)op->op_first; /* get to range */
1073 token_getmad((ps[(2) - (3)].val.i_tkval),(OP*)op,'o');
1080 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
1081 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1086 #line 1003 "perly.y"
1087 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
1088 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1093 #line 1007 "perly.y"
1094 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
1095 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'o');
1100 #line 1011 "perly.y"
1101 { (yyval.opval) = bind_match(IVAL((ps[(2) - (3)].val.i_tkval)), (ps[(1) - (3)].val.opval), (ps[(3) - (3)].val.opval));
1102 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),
1103 ((yyval.opval)->op_type == OP_NOT
1104 ? ((UNOP*)(yyval.opval))->op_first : (yyval.opval)),
1110 #line 1021 "perly.y"
1111 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[(2) - (2)].val.opval)));
1112 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1117 #line 1025 "perly.y"
1118 { (yyval.opval) = IF_MAD(
1119 newUNOP(OP_NULL, 0, (ps[(2) - (2)].val.opval)),
1120 (ps[(2) - (2)].val.opval)
1122 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'+');
1127 #line 1032 "perly.y"
1128 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[(2) - (2)].val.opval)));
1129 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1134 #line 1036 "perly.y"
1135 { (yyval.opval) = newUNOP(OP_COMPLEMENT, 0, scalar((ps[(2) - (2)].val.opval)));
1136 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1141 #line 1040 "perly.y"
1142 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1143 mod(scalar((ps[(1) - (2)].val.opval)), OP_POSTINC));
1144 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),'o');
1149 #line 1045 "perly.y"
1150 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1151 mod(scalar((ps[(1) - (2)].val.opval)), OP_POSTDEC));
1152 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),'o');
1157 #line 1050 "perly.y"
1158 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1159 mod(scalar((ps[(2) - (2)].val.opval)), OP_PREINC));
1160 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1165 #line 1055 "perly.y"
1166 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1167 mod(scalar((ps[(2) - (2)].val.opval)), OP_PREDEC));
1168 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1173 #line 1064 "perly.y"
1174 { (yyval.opval) = newANONLIST((ps[(2) - (3)].val.opval));
1175 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'[');
1176 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),']');
1181 #line 1069 "perly.y"
1182 { (yyval.opval) = newANONLIST((OP*)NULL);
1183 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'[');
1184 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),']');
1189 #line 1074 "perly.y"
1190 { (yyval.opval) = newANONHASH((ps[(2) - (4)].val.opval));
1191 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'{');
1192 TOKEN_GETMAD((ps[(3) - (4)].val.i_tkval),(yyval.opval),';');
1193 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),'}');
1198 #line 1080 "perly.y"
1199 { (yyval.opval) = newANONHASH((OP*)NULL);
1200 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'{');
1201 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),';');
1202 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),'}');
1207 #line 1086 "perly.y"
1208 { SvREFCNT_inc_simple_void(PL_compcv);
1209 (yyval.opval) = newANONATTRSUB((ps[(2) - (5)].val.ival), (ps[(3) - (5)].val.opval), (ps[(4) - (5)].val.opval), (ps[(5) - (5)].val.opval));
1210 TOKEN_GETMAD((ps[(1) - (5)].val.i_tkval),(yyval.opval),'o');
1211 OP_GETMAD((ps[(3) - (5)].val.opval),(yyval.opval),'s');
1212 OP_GETMAD((ps[(4) - (5)].val.opval),(yyval.opval),'a');
1217 #line 1097 "perly.y"
1218 { (yyval.opval) = dofile((ps[(2) - (2)].val.opval), IVAL((ps[(1) - (2)].val.i_tkval)));
1219 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1224 #line 1101 "perly.y"
1225 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, scope((ps[(2) - (2)].val.opval)));
1226 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'D');
1231 #line 1105 "perly.y"
1232 { (yyval.opval) = newUNOP(OP_ENTERSUB,
1233 OPf_SPECIAL|OPf_STACKED,
1234 prepend_elem(OP_LIST,
1236 (OPpENTERSUB_AMPER<<8),
1237 scalar((ps[(2) - (4)].val.opval))
1238 )),(OP*)NULL)); dep();
1239 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'o');
1240 TOKEN_GETMAD((ps[(3) - (4)].val.i_tkval),(yyval.opval),'(');
1241 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
1246 #line 1117 "perly.y"
1247 { (yyval.opval) = newUNOP(OP_ENTERSUB,
1248 OPf_SPECIAL|OPf_STACKED,
1249 append_elem(OP_LIST,
1250 (ps[(4) - (5)].val.opval),
1252 (OPpENTERSUB_AMPER<<8),
1253 scalar((ps[(2) - (5)].val.opval))
1255 TOKEN_GETMAD((ps[(1) - (5)].val.i_tkval),(yyval.opval),'o');
1256 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'(');
1257 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),')');
1262 #line 1130 "perly.y"
1263 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
1264 prepend_elem(OP_LIST,
1265 scalar(newCVREF(0,scalar((ps[(2) - (4)].val.opval)))), (OP*)NULL)); dep();
1266 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'o');
1267 TOKEN_GETMAD((ps[(3) - (4)].val.i_tkval),(yyval.opval),'(');
1268 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
1273 #line 1138 "perly.y"
1274 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_SPECIAL|OPf_STACKED,
1275 prepend_elem(OP_LIST,
1276 (ps[(4) - (5)].val.opval),
1277 scalar(newCVREF(0,scalar((ps[(2) - (5)].val.opval)))))); dep();
1278 TOKEN_GETMAD((ps[(1) - (5)].val.i_tkval),(yyval.opval),'o');
1279 TOKEN_GETMAD((ps[(3) - (5)].val.i_tkval),(yyval.opval),'(');
1280 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),')');
1285 #line 1154 "perly.y"
1286 { (yyval.opval) = newCONDOP(0, (ps[(1) - (5)].val.opval), (ps[(3) - (5)].val.opval), (ps[(5) - (5)].val.opval));
1287 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'?');
1288 TOKEN_GETMAD((ps[(4) - (5)].val.i_tkval),(yyval.opval),':');
1293 #line 1159 "perly.y"
1294 { (yyval.opval) = newUNOP(OP_REFGEN, 0, mod((ps[(2) - (2)].val.opval),OP_REFGEN));
1295 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1300 #line 1163 "perly.y"
1301 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1305 #line 1165 "perly.y"
1306 { (yyval.opval) = localize((ps[(2) - (2)].val.opval),IVAL((ps[(1) - (2)].val.i_tkval)));
1307 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'k');
1312 #line 1169 "perly.y"
1313 { (yyval.opval) = sawparens(IF_MAD(newUNOP(OP_NULL,0,(ps[(2) - (3)].val.opval)), (ps[(2) - (3)].val.opval)));
1314 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'(');
1315 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
1320 #line 1174 "perly.y"
1321 { (yyval.opval) = IF_MAD(newUNOP(OP_NULL,0,(ps[(1) - (1)].val.opval)), (ps[(1) - (1)].val.opval)); ;}
1325 #line 1176 "perly.y"
1326 { (yyval.opval) = sawparens(newNULLLIST());
1327 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'(');
1328 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),')');
1333 #line 1181 "perly.y"
1334 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1338 #line 1183 "perly.y"
1339 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1343 #line 1185 "perly.y"
1344 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1348 #line 1187 "perly.y"
1349 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1353 #line 1189 "perly.y"
1354 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[(1) - (1)].val.opval), OP_AV2ARYLEN));;}
1358 #line 1191 "perly.y"
1359 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1363 #line 1193 "perly.y"
1364 { (yyval.opval) = prepend_elem(OP_ASLICE,
1365 newOP(OP_PUSHMARK, 0),
1366 newLISTOP(OP_ASLICE, 0,
1367 list((ps[(3) - (4)].val.opval)),
1368 ref((ps[(1) - (4)].val.opval), OP_ASLICE)));
1369 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'[');
1370 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),']');
1375 #line 1202 "perly.y"
1376 { (yyval.opval) = prepend_elem(OP_HSLICE,
1377 newOP(OP_PUSHMARK, 0),
1378 newLISTOP(OP_HSLICE, 0,
1379 list((ps[(3) - (5)].val.opval)),
1380 ref(oopsHV((ps[(1) - (5)].val.opval)), OP_HSLICE)));
1381 PL_parser->expect = XOPERATOR;
1382 TOKEN_GETMAD((ps[(2) - (5)].val.i_tkval),(yyval.opval),'{');
1383 TOKEN_GETMAD((ps[(4) - (5)].val.i_tkval),(yyval.opval),';');
1384 TOKEN_GETMAD((ps[(5) - (5)].val.i_tkval),(yyval.opval),'}');
1389 #line 1213 "perly.y"
1390 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1394 #line 1215 "perly.y"
1395 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[(1) - (1)].val.opval))); ;}
1399 #line 1217 "perly.y"
1400 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[(1) - (3)].val.opval)));
1401 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'(');
1402 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
1407 #line 1222 "perly.y"
1409 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1410 append_elem(OP_LIST, (ps[(3) - (4)].val.opval), scalar((ps[(1) - (4)].val.opval))));
1412 OP* op = (yyval.opval);
1413 if (op->op_type == OP_CONST) { /* defeat const fold */
1414 op = (OP*)op->op_madprop->mad_val;
1416 token_getmad((ps[(2) - (4)].val.i_tkval),op,'(');
1417 token_getmad((ps[(4) - (4)].val.i_tkval),op,')');
1423 #line 1235 "perly.y"
1424 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1425 append_elem(OP_LIST, (ps[(3) - (3)].val.opval), scalar((ps[(2) - (3)].val.opval))));
1426 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'o');
1431 #line 1240 "perly.y"
1432 { (yyval.opval) = newOP(IVAL((ps[(1) - (1)].val.i_tkval)), OPf_SPECIAL);
1433 PL_hints |= HINT_BLOCK_SCOPE;
1434 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'o');
1439 #line 1245 "perly.y"
1440 { (yyval.opval) = newLOOPEX(IVAL((ps[(1) - (2)].val.i_tkval)),(ps[(2) - (2)].val.opval));
1441 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1446 #line 1249 "perly.y"
1447 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[(2) - (2)].val.opval)));
1448 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1453 #line 1253 "perly.y"
1454 { (yyval.opval) = newOP(IVAL((ps[(1) - (1)].val.i_tkval)), 0);
1455 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'o');
1460 #line 1257 "perly.y"
1461 { (yyval.opval) = newUNOP(IVAL((ps[(1) - (2)].val.i_tkval)), 0, (ps[(2) - (2)].val.opval));
1462 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1467 #line 1261 "perly.y"
1468 { (yyval.opval) = newUNOP(IVAL((ps[(1) - (2)].val.i_tkval)), 0, (ps[(2) - (2)].val.opval));
1469 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1474 #line 1265 "perly.y"
1475 { (yyval.opval) = newOP(OP_REQUIRE, (ps[(1) - (1)].val.i_tkval) ? OPf_SPECIAL : 0);
1476 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'o');
1481 #line 1269 "perly.y"
1482 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[(1) - (2)].val.i_tkval) ? OPf_SPECIAL : 0, (ps[(2) - (2)].val.opval));
1483 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'o');
1488 #line 1273 "perly.y"
1489 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[(1) - (1)].val.opval))); ;}
1493 #line 1275 "perly.y"
1494 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1495 append_elem(OP_LIST, (ps[(2) - (2)].val.opval), scalar((ps[(1) - (2)].val.opval)))); ;}
1499 #line 1278 "perly.y"
1500 { (yyval.opval) = newOP(IVAL((ps[(1) - (1)].val.i_tkval)), 0);
1501 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'o');
1506 #line 1282 "perly.y"
1507 { (yyval.opval) = newOP(IVAL((ps[(1) - (3)].val.i_tkval)), 0);
1508 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'o');
1509 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'(');
1510 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
1515 #line 1288 "perly.y"
1516 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1517 scalar((ps[(1) - (1)].val.opval))); ;}
1521 #line 1291 "perly.y"
1522 { (yyval.opval) = (IVAL((ps[(1) - (3)].val.i_tkval)) == OP_NOT)
1523 ? newUNOP(IVAL((ps[(1) - (3)].val.i_tkval)), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1524 : newOP(IVAL((ps[(1) - (3)].val.i_tkval)), OPf_SPECIAL);
1526 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'o');
1527 TOKEN_GETMAD((ps[(2) - (3)].val.i_tkval),(yyval.opval),'(');
1528 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
1533 #line 1300 "perly.y"
1534 { (yyval.opval) = newUNOP(IVAL((ps[(1) - (4)].val.i_tkval)), 0, (ps[(3) - (4)].val.opval));
1535 TOKEN_GETMAD((ps[(1) - (4)].val.i_tkval),(yyval.opval),'o');
1536 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'(');
1537 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
1542 #line 1306 "perly.y"
1543 { (yyval.opval) = pmruntime((ps[(1) - (4)].val.opval), (ps[(3) - (4)].val.opval), 1);
1544 TOKEN_GETMAD((ps[(2) - (4)].val.i_tkval),(yyval.opval),'(');
1545 TOKEN_GETMAD((ps[(4) - (4)].val.i_tkval),(yyval.opval),')');
1550 #line 1313 "perly.y"
1552 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
1553 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
1554 TOKEN_GETMAD((ps[(1) - (1)].val.i_tkval),(yyval.opval),'X');
1559 #line 1323 "perly.y"
1560 { (yyval.opval) = my_attrs((ps[(2) - (3)].val.opval),(ps[(3) - (3)].val.opval));
1562 token_getmad((ps[(1) - (3)].val.i_tkval),(yyval.opval),'d');
1563 append_madprops((ps[(3) - (3)].val.opval)->op_madprop, (yyval.opval), 'a');
1564 (ps[(3) - (3)].val.opval)->op_madprop = 0;
1570 #line 1331 "perly.y"
1571 { (yyval.opval) = localize((ps[(2) - (2)].val.opval),IVAL((ps[(1) - (2)].val.i_tkval)));
1572 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'d');
1577 #line 1338 "perly.y"
1578 { (yyval.opval) = sawparens((ps[(2) - (3)].val.opval));
1579 TOKEN_GETMAD((ps[(1) - (3)].val.i_tkval),(yyval.opval),'(');
1580 TOKEN_GETMAD((ps[(3) - (3)].val.i_tkval),(yyval.opval),')');
1585 #line 1343 "perly.y"
1586 { (yyval.opval) = sawparens(newNULLLIST());
1587 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'(');
1588 TOKEN_GETMAD((ps[(2) - (2)].val.i_tkval),(yyval.opval),')');
1593 #line 1348 "perly.y"
1594 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1598 #line 1350 "perly.y"
1599 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1603 #line 1352 "perly.y"
1604 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1608 #line 1357 "perly.y"
1609 { (yyval.opval) = (OP*)NULL; ;}
1613 #line 1359 "perly.y"
1614 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1618 #line 1363 "perly.y"
1619 { (yyval.opval) = (OP*)NULL; ;}
1623 #line 1365 "perly.y"
1624 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1628 #line 1369 "perly.y"
1629 { (yyval.i_tkval) = (ps[(1) - (1)].val.i_tkval); ;}
1633 #line 1371 "perly.y"
1634 { munge_qwlist_to_paren_list((ps[(1) - (1)].val.opval)); ;}
1638 #line 1373 "perly.y"
1639 { (yyval.i_tkval) = (ps[(3) - (3)].val.i_tkval); ;}
1643 #line 1379 "perly.y"
1644 { PL_parser->in_my = 0; (yyval.opval) = my((ps[(1) - (1)].val.opval)); ;}
1648 #line 1383 "perly.y"
1649 { (yyval.opval) = newCVREF(IVAL((ps[(1) - (2)].val.i_tkval)),(ps[(2) - (2)].val.opval));
1650 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'&');
1655 #line 1389 "perly.y"
1656 { (yyval.opval) = newSVREF((ps[(2) - (2)].val.opval));
1657 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'$');
1662 #line 1395 "perly.y"
1663 { (yyval.opval) = newAVREF((ps[(2) - (2)].val.opval));
1664 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'@');
1669 #line 1401 "perly.y"
1670 { (yyval.opval) = newHVREF((ps[(2) - (2)].val.opval));
1671 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'%');
1676 #line 1407 "perly.y"
1677 { (yyval.opval) = newAVREF((ps[(2) - (2)].val.opval));
1678 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'l');
1683 #line 1413 "perly.y"
1684 { (yyval.opval) = newGVREF(0,(ps[(2) - (2)].val.opval));
1685 TOKEN_GETMAD((ps[(1) - (2)].val.i_tkval),(yyval.opval),'*');
1690 #line 1420 "perly.y"
1691 { (yyval.opval) = scalar((ps[(1) - (1)].val.opval)); ;}
1695 #line 1422 "perly.y"
1696 { (yyval.opval) = scalar((ps[(1) - (1)].val.opval)); ;}
1700 #line 1424 "perly.y"
1701 { (yyval.opval) = scope((ps[(1) - (1)].val.opval)); ;}
1705 #line 1427 "perly.y"
1706 { (yyval.opval) = (ps[(1) - (1)].val.opval); ;}
1710 /* Line 1267 of yacc.c. */