1 /* -*- buffer-read-only: t -*-
2 !!!!!!! DO NOT EDIT THIS FILE !!!!!!!
3 This file is built by regen_perly.pl from perly.y.
4 Any changes made here will be lost!
10 parser->expect = XSTATE;
19 newPROG(block_end((ps[-1].val.ival),(ps[0].val.opval)));
20 PL_compiling.cop_seq = 0;
29 parser->expect = XTERM;
38 PL_eval_root = (ps[0].val.opval);
47 parser->expect = XBLOCK;
56 PL_pad_reset_pending = TRUE;
57 PL_eval_root = (ps[0].val.opval);
60 parser->yychar = yytoken = YYEOF;
68 parser->expect = XSTATE;
77 PL_pad_reset_pending = TRUE;
78 PL_eval_root = (ps[0].val.opval);
81 parser->yychar = yytoken = YYEOF;
89 parser->expect = XSTATE;
98 PL_pad_reset_pending = TRUE;
99 PL_eval_root = (ps[0].val.opval);
102 parser->yychar = yytoken = YYEOF;
110 parser->expect = XSTATE;
119 PL_eval_root = (ps[0].val.opval);
128 parser->expect = XSTATE;
137 PL_eval_root = (ps[0].val.opval);
145 { if (parser->copline > (line_t)(ps[-3].val.ival))
146 parser->copline = (line_t)(ps[-3].val.ival);
147 (yyval.opval) = block_end((ps[-2].val.ival), (ps[-1].val.opval));
154 { (yyval.opval) = NULL; }
160 { if (parser->copline > (line_t)(ps[-6].val.ival))
161 parser->copline = (line_t)(ps[-6].val.ival);
162 (yyval.opval) = block_end((ps[-5].val.ival), (ps[-2].val.opval));
169 { (yyval.ival) = block_start(TRUE);
170 parser->parsed_sub = 0; }
176 { if (parser->copline > (line_t)(ps[-3].val.ival))
177 parser->copline = (line_t)(ps[-3].val.ival);
178 (yyval.opval) = block_end((ps[-2].val.ival), (ps[-1].val.opval));
185 { (yyval.ival) = block_start(FALSE);
186 parser->parsed_sub = 0; }
192 { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-1].val.opval), (ps[0].val.opval));
193 PL_pad_reset_pending = TRUE;
194 if ((ps[-1].val.opval) && (ps[0].val.opval))
195 PL_hints |= HINT_BLOCK_SCOPE;
202 { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-1].val.opval), (ps[0].val.opval));
203 PL_pad_reset_pending = TRUE;
204 if ((ps[-1].val.opval) && (ps[0].val.opval))
205 PL_hints |= HINT_BLOCK_SCOPE;
213 (yyval.opval) = (ps[0].val.opval) ? newSTATEOP(0, NULL, (ps[0].val.opval)) : NULL;
220 { (yyval.opval) = (ps[0].val.opval); }
227 SV *label = cSVOPx_sv((ps[-1].val.opval));
228 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
229 savepv(SvPVX_const(label)), (ps[0].val.opval));
230 op_free((ps[-1].val.opval));
238 SV *label = cSVOPx_sv((ps[-1].val.opval));
239 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
240 savepv(SvPVX_const(label)), (ps[0].val.opval));
241 op_free((ps[-1].val.opval));
248 { (yyval.opval) = (ps[0].val.opval); }
255 CV *fmtcv = PL_compcv;
256 newFORM((ps[-2].val.ival), (ps[-1].val.opval), (ps[0].val.opval));
257 (yyval.opval) = NULL;
258 if (CvOUTSIDE(fmtcv) && !CvEVAL(CvOUTSIDE(fmtcv))) {
259 pad_add_weakref(fmtcv);
261 parser->parsed_sub = 1;
269 init_named_cv(PL_compcv, (ps[-1].val.opval));
271 parser->in_my_stash = NULL;
279 SvREFCNT_inc_simple_void(PL_compcv);
280 (ps[-5].val.opval)->op_type == OP_CONST
281 ? newATTRSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
282 : newMYSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
284 (yyval.opval) = NULL;
286 parser->parsed_sub = 1;
294 init_named_cv(PL_compcv, (ps[-1].val.opval));
296 parser->in_my_stash = NULL;
304 SvREFCNT_inc_simple_void(PL_compcv);
305 (ps[-4].val.opval)->op_type == OP_CONST
306 ? newATTRSUB((ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
307 : newMYSUB( (ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
309 (yyval.opval) = NULL;
311 parser->parsed_sub = 1;
319 package((ps[-1].val.opval));
320 if ((ps[-2].val.opval))
321 package_version((ps[-2].val.opval));
322 (yyval.opval) = NULL;
329 { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ }
336 SvREFCNT_inc_simple_void(PL_compcv);
337 utilize((ps[-6].val.ival), (ps[-5].val.ival), (ps[-3].val.opval), (ps[-2].val.opval), (ps[-1].val.opval));
338 parser->parsed_sub = 1;
339 (yyval.opval) = NULL;
347 (yyval.opval) = block_end((ps[-4].val.ival),
348 newCONDOP(0, (ps[-3].val.opval), op_scope((ps[-1].val.opval)), (ps[0].val.opval)));
349 parser->copline = (line_t)(ps[-6].val.ival);
357 (yyval.opval) = block_end((ps[-4].val.ival),
358 newCONDOP(0, (ps[-3].val.opval), (ps[0].val.opval), op_scope((ps[-1].val.opval))));
359 parser->copline = (line_t)(ps[-6].val.ival);
367 (yyval.opval) = block_end((ps[-3].val.ival), newGIVENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)), 0));
368 parser->copline = (line_t)(ps[-5].val.ival);
375 { (yyval.opval) = block_end((ps[-3].val.ival), newWHENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)))); }
381 { (yyval.opval) = newWHENOP(0, op_scope((ps[0].val.opval))); }
388 (yyval.opval) = block_end((ps[-5].val.ival),
389 newWHILEOP(0, 1, NULL,
390 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
391 parser->copline = (line_t)(ps[-7].val.ival);
399 (yyval.opval) = block_end((ps[-5].val.ival),
400 newWHILEOP(0, 1, NULL,
401 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
402 parser->copline = (line_t)(ps[-7].val.ival);
409 { parser->expect = XTERM; }
415 { parser->expect = XTERM; }
422 OP *initop = (ps[-9].val.opval);
423 OP *forop = newWHILEOP(0, 1, NULL,
424 scalar((ps[-6].val.opval)), (ps[0].val.opval), (ps[-2].val.opval), (ps[-3].val.ival));
426 forop = op_prepend_elem(OP_LINESEQ, initop,
427 op_append_elem(OP_LINESEQ,
428 newOP(OP_UNSTACK, OPf_SPECIAL),
431 PL_hints |= HINT_BLOCK_SCOPE;
432 (yyval.opval) = block_end((ps[-10].val.ival), forop);
433 parser->copline = (line_t)(ps[-12].val.ival);
441 (yyval.opval) = block_end((ps[-6].val.ival), newFOROP(0, (ps[-5].val.opval), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
442 parser->copline = (line_t)(ps[-8].val.ival);
450 (yyval.opval) = block_end((ps[-8].val.ival), newFOROP(0, (ps[-6].val.opval), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
451 parser->copline = (line_t)(ps[-10].val.ival);
459 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(0,
460 op_lvalue((ps[-6].val.opval), OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
461 parser->copline = (line_t)(ps[-7].val.ival);
468 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
475 (yyval.opval) = block_end(
479 newUNOP(OP_REFGEN, 0,
482 (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
484 parser->copline = (line_t)(ps[-9].val.ival);
492 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(
493 0, op_lvalue(newUNOP(OP_REFGEN, 0,
495 OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
496 parser->copline = (line_t)(ps[-8].val.ival);
504 (yyval.opval) = block_end((ps[-4].val.ival),
505 newFOROP(0, NULL, (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
506 parser->copline = (line_t)(ps[-6].val.ival);
513 { parser->in_my = 1; }
519 { parser->in_my = 0; intro_my(); }
526 (yyval.opval) = newTRYCATCHOP(0,
527 (ps[-9].val.opval), (ps[-4].val.opval), block_end((ps[-5].val.ival), op_scope((ps[-1].val.opval))));
528 if((ps[0].val.opval))
529 (yyval.opval) = op_wrap_finally((yyval.opval), (ps[0].val.opval));
530 parser->copline = (line_t)(ps[-10].val.ival);
538 /* a block is a loop that happens once */
539 (yyval.opval) = newWHILEOP(0, 1, NULL,
540 NULL, (ps[-1].val.opval), (ps[0].val.opval), 0);
548 package((ps[-2].val.opval));
549 if ((ps[-3].val.opval)) {
550 package_version((ps[-3].val.opval));
559 /* a block is a loop that happens once */
560 (yyval.opval) = newWHILEOP(0, 1, NULL,
561 NULL, block_end((ps[-3].val.ival), (ps[-1].val.opval)), NULL, 0);
562 if (parser->copline > (line_t)(ps[-4].val.ival))
563 parser->copline = (line_t)(ps[-4].val.ival);
571 (yyval.opval) = (ps[-1].val.opval);
579 (yyval.opval) = newDEFEROP(0, op_scope((ps[0].val.opval)));
587 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
588 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
596 (yyval.opval) = NULL;
597 parser->copline = NOLINE;
605 if ((ps[0].val.opval)) {
606 OP *term = (ps[0].val.opval);
607 list = op_append_elem(OP_LIST, (ps[-1].val.opval), term);
610 list = (ps[-1].val.opval);
612 if (parser->copline == NOLINE)
613 parser->copline = CopLINE(PL_curcop)-1;
614 else parser->copline--;
615 (yyval.opval) = newSTATEOP(0, NULL,
616 op_convert_list(OP_FORMLINE, 0, list));
623 { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
629 { (yyval.opval) = NULL; }
635 { (yyval.opval) = (ps[0].val.opval); }
641 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
647 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
653 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
659 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
665 { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
666 parser->copline = (line_t)(ps[-1].val.ival); }
672 { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
679 ((ps[0].val.opval))->op_flags |= OPf_PARENS;
680 (yyval.opval) = op_scope((ps[0].val.opval));
687 { parser->copline = (line_t)(ps[-5].val.ival);
688 (yyval.opval) = newCONDOP(0,
689 newSTATEOP(OPf_SPECIAL,NULL,(ps[-3].val.opval)),
690 op_scope((ps[-1].val.opval)), (ps[0].val.opval));
691 PL_hints |= HINT_BLOCK_SCOPE;
698 { (yyval.opval) = op_scope((ps[0].val.opval)); }
704 { (yyval.opval) = NULL; }
710 { (yyval.opval) = op_scope((ps[0].val.opval)); }
716 { (yyval.ival) = (PL_min_intro_pending &&
717 PL_max_intro_pending >= PL_min_intro_pending);
725 (void)scan_num("1", &tmplval);
726 (yyval.opval) = tmplval.opval; }
732 { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
738 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
744 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
750 { (yyval.opval) = (ps[0].val.opval); }
756 { (yyval.ival) = start_subparse(FALSE, 0);
757 SAVEFREESV(PL_compcv); }
763 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
764 SAVEFREESV(PL_compcv); }
770 { (yyval.ival) = start_subparse(TRUE, 0);
771 SAVEFREESV(PL_compcv); }
777 { (yyval.opval) = (ps[0].val.opval); }
783 { (yyval.opval) = NULL; }
789 { (yyval.opval) = (ps[0].val.opval); }
795 { (yyval.opval) = NULL; }
801 { parser->in_my = 0; (yyval.opval) = NULL; }
807 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
813 { (yyval.ival) = '@'; }
819 { (yyval.ival) = '%'; }
826 I32 sigil = (ps[-2].val.ival);
827 OP *var = (ps[-1].val.opval);
828 OP *defexpr = (ps[0].val.opval);
830 if (parser->sig_slurpy)
831 yyerror("Multiple slurpy parameters not allowed");
832 parser->sig_slurpy = (char)sigil;
835 yyerror("A slurpy parameter may not have "
838 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
845 { (yyval.opval) = newOP(OP_NULL, 0); }
851 { (yyval.opval) = (ps[0].val.opval); }
858 OP *var = (ps[-1].val.opval);
859 OP *defexpr = (ps[0].val.opval);
861 if (parser->sig_slurpy)
862 yyerror("Slurpy parameter not last");
867 parser->sig_optelems++;
869 if ( defexpr->op_type == OP_NULL
870 && !(defexpr->op_flags & OPf_KIDS))
872 /* handle '$=' special case */
874 yyerror("Optional parameter "
875 "lacks default expression");
879 /* a normal '=default' expression */
880 OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
883 /* re-purpose op_targ to hold @_ index */
885 (PADOFFSET)(parser->sig_elems - 1);
888 var->op_flags |= OPf_STACKED;
889 (void)op_sibling_splice(var,
894 var = newUNOP(OP_NULL, 0, defop);
897 /* NB: normally the first child of a
898 * logop is executed before the logop,
899 * and it pushes a boolean result
900 * ready for the logop. For ARGDEFELEM,
901 * the op itself does the boolean
902 * calculation, so set the first op to
905 var->op_next = defop;
906 defexpr->op_next = var;
910 if (parser->sig_optelems)
911 yyerror("Mandatory parameter "
912 "follows optional parameter");
915 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
922 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
928 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
934 { (yyval.opval) = (ps[-1].val.opval); }
941 (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
948 { (yyval.opval) = (ps[0].val.opval); }
954 { (yyval.opval) = (ps[-1].val.opval); }
962 SAVEIV(parser->sig_elems);
963 SAVEIV(parser->sig_optelems);
964 SAVEI8(parser->sig_slurpy);
965 parser->sig_elems = 0;
966 parser->sig_optelems = 0;
967 parser->sig_slurpy = 0;
968 parser->in_my = KEY_sigvar;
976 OP *sigops = (ps[0].val.opval);
977 struct op_argcheck_aux *aux;
980 if (!FEATURE_SIGNATURES_IS_ENABLED)
981 Perl_croak(aTHX_ "Experimental "
982 "subroutine signatures not enabled");
984 /* We shouldn't get here otherwise */
985 Perl_ck_warner_d(aTHX_
986 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
987 "The signatures feature is experimental");
989 aux = (struct op_argcheck_aux*)
990 PerlMemShared_malloc(
991 sizeof(struct op_argcheck_aux));
992 aux->params = parser->sig_elems;
993 aux->opt_params = parser->sig_optelems;
994 aux->slurpy = parser->sig_slurpy;
995 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL,
996 (UNOP_AUX_item *)aux);
997 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
998 sigops = op_prepend_elem(OP_LINESEQ,
999 newSTATEOP(0, NULL, NULL),
1001 /* a nextstate at the end handles context
1002 * correctly for an empty sub body */
1003 sigops = op_append_elem(OP_LINESEQ,
1005 newSTATEOP(0, NULL, NULL));
1006 /* wrap the list of arg ops in a NULL aux op.
1007 This serves two purposes. First, it makes
1008 the arg list a separate subtree from the
1009 body of the sub, and secondly the null op
1010 may in future be upgraded to an OP_SIGNATURE
1011 when implemented. For now leave it as
1013 (yyval.opval) = newUNOP_AUX(OP_ARGCHECK, 0, sigops, NULL);
1014 op_null((yyval.opval));
1016 CvSIGNATURE_on(PL_compcv);
1019 /* tell the toker that attrributes can follow
1020 * this sig, but only so that the toker
1021 * can skip through any (illegal) trailing
1022 * attribute text then give a useful error
1023 * message about "attributes before sig",
1024 * rather than falling over ina mess at
1025 * unrecognised syntax.
1027 parser->expect = XATTRBLOCK;
1028 parser->sig_seen = TRUE;
1036 { (yyval.opval) = NULL; }
1043 if (parser->copline > (line_t)(ps[-2].val.ival))
1044 parser->copline = (line_t)(ps[-2].val.ival);
1045 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1052 { (yyval.opval) = NULL; }
1059 if (parser->copline > (line_t)(ps[-2].val.ival))
1060 parser->copline = (line_t)(ps[-2].val.ival);
1061 (yyval.opval) = block_end((ps[-4].val.ival),
1062 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1069 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1075 { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1081 { (yyval.opval) = (ps[-1].val.opval); }
1088 OP* term = (ps[0].val.opval);
1089 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1096 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1097 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1104 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1105 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1112 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1113 op_append_elem(OP_LIST,
1114 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1115 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1122 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1123 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1124 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1131 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1132 op_append_elem(OP_LIST,
1133 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1134 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1141 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1142 op_append_elem(OP_LIST,
1143 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1144 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1151 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1157 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1163 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1169 { SvREFCNT_inc_simple_void(PL_compcv);
1170 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1175 #line 1000 "perly.y"
1176 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1177 op_append_elem(OP_LIST,
1178 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1184 #line 1015 "perly.y"
1185 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1190 #line 1017 "perly.y"
1191 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1197 #line 1020 "perly.y"
1198 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1199 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1200 scalar((ps[-1].val.opval)));
1206 #line 1025 "perly.y"
1207 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1208 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1209 scalar((ps[-1].val.opval)));
1215 #line 1030 "perly.y"
1216 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1222 #line 1033 "perly.y"
1223 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1224 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1225 jmaybe((ps[-2].val.opval))); }
1230 #line 1037 "perly.y"
1231 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1232 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1233 jmaybe((ps[-2].val.opval))); }
1238 #line 1041 "perly.y"
1239 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1240 newCVREF(0, scalar((ps[-3].val.opval))));
1241 if (parser->expect == XBLOCK)
1242 parser->expect = XOPERATOR;
1248 #line 1047 "perly.y"
1249 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1250 op_append_elem(OP_LIST, (ps[-1].val.opval),
1251 newCVREF(0, scalar((ps[-4].val.opval)))));
1252 if (parser->expect == XBLOCK)
1253 parser->expect = XOPERATOR;
1259 #line 1055 "perly.y"
1260 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1261 op_append_elem(OP_LIST, (ps[-1].val.opval),
1262 newCVREF(0, scalar((ps[-3].val.opval)))));
1263 if (parser->expect == XBLOCK)
1264 parser->expect = XOPERATOR;
1270 #line 1062 "perly.y"
1271 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1272 newCVREF(0, scalar((ps[-2].val.opval))));
1273 if (parser->expect == XBLOCK)
1274 parser->expect = XOPERATOR;
1280 #line 1068 "perly.y"
1281 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1286 #line 1070 "perly.y"
1287 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1292 #line 1072 "perly.y"
1293 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1298 #line 1077 "perly.y"
1299 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1304 #line 1079 "perly.y"
1305 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1310 #line 1081 "perly.y"
1311 { if ((ps[-1].val.ival) != OP_REPEAT)
1312 scalar((ps[-2].val.opval));
1313 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1319 #line 1086 "perly.y"
1320 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1325 #line 1088 "perly.y"
1326 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1331 #line 1090 "perly.y"
1332 { (yyval.opval) = (ps[0].val.opval); }
1337 #line 1092 "perly.y"
1338 { (yyval.opval) = (ps[0].val.opval); }
1343 #line 1094 "perly.y"
1344 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1349 #line 1096 "perly.y"
1350 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1355 #line 1098 "perly.y"
1356 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1361 #line 1100 "perly.y"
1362 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1367 #line 1102 "perly.y"
1368 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1373 #line 1104 "perly.y"
1374 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1379 #line 1106 "perly.y"
1380 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1385 #line 1110 "perly.y"
1386 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1391 #line 1112 "perly.y"
1392 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1397 #line 1114 "perly.y"
1398 { yyerror("syntax error"); YYERROR; }
1403 #line 1116 "perly.y"
1404 { yyerror("syntax error"); YYERROR; }
1409 #line 1120 "perly.y"
1410 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1415 #line 1122 "perly.y"
1416 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1421 #line 1126 "perly.y"
1422 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1427 #line 1128 "perly.y"
1428 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1433 #line 1130 "perly.y"
1434 { yyerror("syntax error"); YYERROR; }
1439 #line 1132 "perly.y"
1440 { yyerror("syntax error"); YYERROR; }
1445 #line 1136 "perly.y"
1446 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1451 #line 1138 "perly.y"
1452 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1457 #line 1143 "perly.y"
1458 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1463 #line 1145 "perly.y"
1464 { (yyval.opval) = (ps[0].val.opval); }
1469 #line 1148 "perly.y"
1470 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1475 #line 1150 "perly.y"
1476 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1481 #line 1152 "perly.y"
1482 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1483 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1488 #line 1155 "perly.y"
1489 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1490 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1495 #line 1158 "perly.y"
1496 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1510 #line 1169 "perly.y"
1511 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1512 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1517 #line 1172 "perly.y"
1518 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1519 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1524 #line 1179 "perly.y"
1525 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1530 #line 1181 "perly.y"
1531 { (yyval.opval) = newANONLIST(NULL);}
1536 #line 1183 "perly.y"
1537 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1542 #line 1185 "perly.y"
1543 { (yyval.opval) = newANONHASH(NULL); }
1548 #line 1187 "perly.y"
1549 { SvREFCNT_inc_simple_void(PL_compcv);
1550 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1555 #line 1190 "perly.y"
1556 { SvREFCNT_inc_simple_void(PL_compcv);
1557 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1562 #line 1196 "perly.y"
1563 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1568 #line 1198 "perly.y"
1569 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1574 #line 1206 "perly.y"
1575 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1580 #line 1208 "perly.y"
1581 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1586 #line 1210 "perly.y"
1587 { (yyval.opval) = (ps[0].val.opval); }
1592 #line 1212 "perly.y"
1593 { (yyval.opval) = localize((ps[0].val.opval),0); }
1598 #line 1214 "perly.y"
1599 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1604 #line 1216 "perly.y"
1605 { (yyval.opval) = (ps[0].val.opval); }
1610 #line 1218 "perly.y"
1611 { (yyval.opval) = sawparens(newNULLLIST()); }
1616 #line 1220 "perly.y"
1617 { (yyval.opval) = (ps[0].val.opval); }
1622 #line 1222 "perly.y"
1623 { (yyval.opval) = (ps[0].val.opval); }
1628 #line 1224 "perly.y"
1629 { (yyval.opval) = (ps[0].val.opval); }
1634 #line 1226 "perly.y"
1635 { (yyval.opval) = (ps[0].val.opval); }
1640 #line 1228 "perly.y"
1641 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1646 #line 1230 "perly.y"
1647 { (yyval.opval) = (ps[0].val.opval); }
1652 #line 1232 "perly.y"
1653 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1654 newOP(OP_PUSHMARK, 0),
1655 newLISTOP(OP_ASLICE, 0,
1656 list((ps[-1].val.opval)),
1657 ref((ps[-3].val.opval), OP_ASLICE)));
1658 if ((yyval.opval) && (ps[-3].val.opval))
1659 (yyval.opval)->op_private |=
1660 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1666 #line 1242 "perly.y"
1667 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1668 newOP(OP_PUSHMARK, 0),
1669 newLISTOP(OP_KVASLICE, 0,
1670 list((ps[-1].val.opval)),
1671 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1672 if ((yyval.opval) && (ps[-3].val.opval))
1673 (yyval.opval)->op_private |=
1674 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1680 #line 1252 "perly.y"
1681 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1682 newOP(OP_PUSHMARK, 0),
1683 newLISTOP(OP_HSLICE, 0,
1684 list((ps[-2].val.opval)),
1685 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1686 if ((yyval.opval) && (ps[-4].val.opval))
1687 (yyval.opval)->op_private |=
1688 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1694 #line 1262 "perly.y"
1695 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1696 newOP(OP_PUSHMARK, 0),
1697 newLISTOP(OP_KVHSLICE, 0,
1698 list((ps[-2].val.opval)),
1699 ref((ps[-4].val.opval), OP_KVHSLICE)));
1700 if ((yyval.opval) && (ps[-4].val.opval))
1701 (yyval.opval)->op_private |=
1702 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1708 #line 1272 "perly.y"
1709 { (yyval.opval) = (ps[0].val.opval); }
1714 #line 1274 "perly.y"
1715 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1720 #line 1276 "perly.y"
1721 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1727 #line 1279 "perly.y"
1729 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1730 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1736 #line 1284 "perly.y"
1737 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1738 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1744 #line 1288 "perly.y"
1745 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1750 #line 1290 "perly.y"
1751 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1756 #line 1292 "perly.y"
1757 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1762 #line 1294 "perly.y"
1763 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1764 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1769 #line 1297 "perly.y"
1770 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1775 #line 1299 "perly.y"
1776 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1777 PL_hints |= HINT_BLOCK_SCOPE; }
1782 #line 1302 "perly.y"
1783 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1788 #line 1304 "perly.y"
1789 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1794 #line 1306 "perly.y"
1795 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1800 #line 1308 "perly.y"
1801 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1806 #line 1310 "perly.y"
1807 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1812 #line 1312 "perly.y"
1813 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1818 #line 1314 "perly.y"
1819 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1824 #line 1316 "perly.y"
1825 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1830 #line 1318 "perly.y"
1831 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1832 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1837 #line 1321 "perly.y"
1838 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1843 #line 1323 "perly.y"
1844 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1849 #line 1325 "perly.y"
1850 { (yyval.opval) = (ps[0].val.opval); }
1855 #line 1327 "perly.y"
1856 { (yyval.opval) = (ps[-2].val.opval); }
1861 #line 1329 "perly.y"
1862 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1867 #line 1331 "perly.y"
1868 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1869 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1870 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1875 #line 1335 "perly.y"
1876 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1881 #line 1337 "perly.y"
1883 if ( (ps[0].val.opval)->op_type != OP_TRANS
1884 && (ps[0].val.opval)->op_type != OP_TRANSR
1885 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1887 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1888 SAVEFREESV(PL_compcv);
1896 #line 1348 "perly.y"
1897 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1902 #line 1357 "perly.y"
1903 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1908 #line 1359 "perly.y"
1909 { (yyval.opval) = localize((ps[0].val.opval),1); }
1914 #line 1361 "perly.y"
1915 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1920 #line 1363 "perly.y"
1921 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1926 #line 1368 "perly.y"
1927 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1932 #line 1370 "perly.y"
1933 { (yyval.opval) = sawparens(newNULLLIST()); }
1938 #line 1373 "perly.y"
1939 { (yyval.opval) = (ps[0].val.opval); }
1944 #line 1375 "perly.y"
1945 { (yyval.opval) = (ps[0].val.opval); }
1950 #line 1377 "perly.y"
1951 { (yyval.opval) = (ps[0].val.opval); }
1956 #line 1393 "perly.y"
1957 { (yyval.opval) = (ps[0].val.opval); }
1962 #line 1399 "perly.y"
1963 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
1968 #line 1404 "perly.y"
1969 { (yyval.opval) = (ps[-1].val.opval); }
1974 #line 1406 "perly.y"
1976 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), (ps[0].val.opval));
1982 #line 1413 "perly.y"
1983 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
1988 #line 1430 "perly.y"
1989 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
1994 #line 1434 "perly.y"
1995 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
2000 #line 1438 "perly.y"
2001 { (yyval.opval) = newAVREF((ps[0].val.opval));
2002 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2008 #line 1444 "perly.y"
2009 { (yyval.opval) = newHVREF((ps[0].val.opval));
2010 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2016 #line 1450 "perly.y"
2017 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
2022 #line 1452 "perly.y"
2023 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
2028 #line 1456 "perly.y"
2029 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
2034 #line 1461 "perly.y"
2035 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2040 #line 1466 "perly.y"
2041 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2046 #line 1471 "perly.y"
2047 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2052 #line 1476 "perly.y"
2053 { (yyval.opval) = scalar((ps[0].val.opval)); }
2058 #line 1478 "perly.y"
2059 { (yyval.opval) = scalar((ps[0].val.opval)); }
2064 #line 1480 "perly.y"
2065 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2070 #line 1483 "perly.y"
2071 { (yyval.opval) = (ps[0].val.opval); }
2081 * 2dfefce380093b4e965ea327b172cdeabe9d706bf879f0fea6e9388ee185bd32 perly.y
2082 * acf1cbfd2545faeaaa58b1cf0cf9d7f98b5be0752eb7a54528ef904a9e2e1ca7 regen_perly.pl