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 { if (parser->copline > (line_t)(ps[-6].val.ival))
155 parser->copline = (line_t)(ps[-6].val.ival);
156 (yyval.opval) = block_end((ps[-5].val.ival), (ps[-2].val.opval));
163 { (yyval.ival) = block_start(TRUE);
164 parser->parsed_sub = 0; }
170 { if (parser->copline > (line_t)(ps[-3].val.ival))
171 parser->copline = (line_t)(ps[-3].val.ival);
172 (yyval.opval) = block_end((ps[-2].val.ival), (ps[-1].val.opval));
179 { (yyval.ival) = block_start(FALSE);
180 parser->parsed_sub = 0; }
186 { (yyval.opval) = NULL; }
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) = NULL; }
208 { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-1].val.opval), (ps[0].val.opval));
209 PL_pad_reset_pending = TRUE;
210 if ((ps[-1].val.opval) && (ps[0].val.opval))
211 PL_hints |= HINT_BLOCK_SCOPE;
219 (yyval.opval) = (ps[0].val.opval) ? newSTATEOP(0, NULL, (ps[0].val.opval)) : NULL;
226 { (yyval.opval) = (ps[0].val.opval); }
233 SV *label = cSVOPx_sv((ps[-1].val.opval));
234 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
235 savepv(SvPVX_const(label)), (ps[0].val.opval));
236 op_free((ps[-1].val.opval));
244 SV *label = cSVOPx_sv((ps[-1].val.opval));
245 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
246 savepv(SvPVX_const(label)), (ps[0].val.opval));
247 op_free((ps[-1].val.opval));
254 { (yyval.opval) = (ps[0].val.opval); }
261 CV *fmtcv = PL_compcv;
262 newFORM((ps[-2].val.ival), (ps[-1].val.opval), (ps[0].val.opval));
263 (yyval.opval) = NULL;
264 if (CvOUTSIDE(fmtcv) && !CvEVAL(CvOUTSIDE(fmtcv))) {
265 pad_add_weakref(fmtcv);
267 parser->parsed_sub = 1;
275 init_named_cv(PL_compcv, (ps[-1].val.opval));
277 parser->in_my_stash = NULL;
285 SvREFCNT_inc_simple_void(PL_compcv);
286 (ps[-5].val.opval)->op_type == OP_CONST
287 ? newATTRSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
288 : newMYSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
290 (yyval.opval) = NULL;
292 parser->parsed_sub = 1;
300 init_named_cv(PL_compcv, (ps[-1].val.opval));
302 parser->in_my_stash = NULL;
310 SvREFCNT_inc_simple_void(PL_compcv);
311 (ps[-4].val.opval)->op_type == OP_CONST
312 ? newATTRSUB((ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
313 : newMYSUB( (ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
315 (yyval.opval) = NULL;
317 parser->parsed_sub = 1;
325 package((ps[-1].val.opval));
326 if ((ps[-2].val.opval))
327 package_version((ps[-2].val.opval));
328 (yyval.opval) = NULL;
335 { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ }
342 SvREFCNT_inc_simple_void(PL_compcv);
343 utilize((ps[-6].val.ival), (ps[-5].val.ival), (ps[-3].val.opval), (ps[-2].val.opval), (ps[-1].val.opval));
344 parser->parsed_sub = 1;
345 (yyval.opval) = NULL;
353 (yyval.opval) = block_end((ps[-4].val.ival),
354 newCONDOP(0, (ps[-3].val.opval), op_scope((ps[-1].val.opval)), (ps[0].val.opval)));
355 parser->copline = (line_t)(ps[-6].val.ival);
363 (yyval.opval) = block_end((ps[-4].val.ival),
364 newCONDOP(0, (ps[-3].val.opval), (ps[0].val.opval), op_scope((ps[-1].val.opval))));
365 parser->copline = (line_t)(ps[-6].val.ival);
373 (yyval.opval) = block_end((ps[-3].val.ival), newGIVENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)), 0));
374 parser->copline = (line_t)(ps[-5].val.ival);
381 { (yyval.opval) = block_end((ps[-3].val.ival), newWHENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)))); }
387 { (yyval.opval) = newWHENOP(0, op_scope((ps[0].val.opval))); }
394 (yyval.opval) = block_end((ps[-5].val.ival),
395 newWHILEOP(0, 1, NULL,
396 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
397 parser->copline = (line_t)(ps[-7].val.ival);
405 (yyval.opval) = block_end((ps[-5].val.ival),
406 newWHILEOP(0, 1, NULL,
407 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
408 parser->copline = (line_t)(ps[-7].val.ival);
415 { parser->expect = XTERM; }
421 { parser->expect = XTERM; }
428 OP *initop = (ps[-9].val.opval);
429 OP *forop = newWHILEOP(0, 1, NULL,
430 scalar((ps[-6].val.opval)), (ps[0].val.opval), (ps[-2].val.opval), (ps[-3].val.ival));
432 forop = op_prepend_elem(OP_LINESEQ, initop,
433 op_append_elem(OP_LINESEQ,
434 newOP(OP_UNSTACK, OPf_SPECIAL),
437 PL_hints |= HINT_BLOCK_SCOPE;
438 (yyval.opval) = block_end((ps[-10].val.ival), forop);
439 parser->copline = (line_t)(ps[-12].val.ival);
447 (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)));
448 parser->copline = (line_t)(ps[-8].val.ival);
456 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(0,
457 op_lvalue((ps[-6].val.opval), OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
458 parser->copline = (line_t)(ps[-7].val.ival);
465 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
472 (yyval.opval) = block_end(
476 newUNOP(OP_REFGEN, 0,
479 (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
481 parser->copline = (line_t)(ps[-9].val.ival);
489 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(
490 0, op_lvalue(newUNOP(OP_REFGEN, 0,
492 OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
493 parser->copline = (line_t)(ps[-8].val.ival);
501 (yyval.opval) = block_end((ps[-4].val.ival),
502 newFOROP(0, NULL, (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
503 parser->copline = (line_t)(ps[-6].val.ival);
511 /* a block is a loop that happens once */
512 (yyval.opval) = newWHILEOP(0, 1, NULL,
513 NULL, (ps[-1].val.opval), (ps[0].val.opval), 0);
521 package((ps[-2].val.opval));
522 if ((ps[-3].val.opval)) {
523 package_version((ps[-3].val.opval));
532 /* a block is a loop that happens once */
533 (yyval.opval) = newWHILEOP(0, 1, NULL,
534 NULL, block_end((ps[-3].val.ival), (ps[-1].val.opval)), NULL, 0);
535 if (parser->copline > (line_t)(ps[-4].val.ival))
536 parser->copline = (line_t)(ps[-4].val.ival);
544 (yyval.opval) = (ps[-1].val.opval);
552 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
553 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
561 (yyval.opval) = NULL;
562 parser->copline = NOLINE;
570 if ((ps[0].val.opval)) {
571 OP *term = (ps[0].val.opval);
572 list = op_append_elem(OP_LIST, (ps[-1].val.opval), term);
575 list = (ps[-1].val.opval);
577 if (parser->copline == NOLINE)
578 parser->copline = CopLINE(PL_curcop)-1;
579 else parser->copline--;
580 (yyval.opval) = newSTATEOP(0, NULL,
581 op_convert_list(OP_FORMLINE, 0, list));
588 { (yyval.opval) = NULL; }
594 { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
600 { (yyval.opval) = NULL; }
606 { (yyval.opval) = (ps[0].val.opval); }
612 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
618 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
624 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
630 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
636 { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
637 parser->copline = (line_t)(ps[-1].val.ival); }
643 { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
649 { (yyval.opval) = NULL; }
656 ((ps[0].val.opval))->op_flags |= OPf_PARENS;
657 (yyval.opval) = op_scope((ps[0].val.opval));
664 { parser->copline = (line_t)(ps[-5].val.ival);
665 (yyval.opval) = newCONDOP(0,
666 newSTATEOP(OPf_SPECIAL,NULL,(ps[-3].val.opval)),
667 op_scope((ps[-1].val.opval)), (ps[0].val.opval));
668 PL_hints |= HINT_BLOCK_SCOPE;
675 { (yyval.opval) = NULL; }
681 { (yyval.opval) = op_scope((ps[0].val.opval)); }
687 { (yyval.ival) = (PL_min_intro_pending &&
688 PL_max_intro_pending >= PL_min_intro_pending);
695 { (yyval.opval) = NULL; }
702 (void)scan_num("1", &tmplval);
703 (yyval.opval) = tmplval.opval; }
709 { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
715 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
721 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
727 { (yyval.opval) = (ps[0].val.opval); }
733 { (yyval.opval) = NULL; }
739 { (yyval.ival) = start_subparse(FALSE, 0);
740 SAVEFREESV(PL_compcv); }
746 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
747 SAVEFREESV(PL_compcv); }
753 { (yyval.ival) = start_subparse(TRUE, 0);
754 SAVEFREESV(PL_compcv); }
760 { (yyval.opval) = NULL; }
766 { (yyval.opval) = NULL; }
772 { (yyval.opval) = (ps[0].val.opval); }
778 { (yyval.opval) = NULL; }
784 { (yyval.opval) = (ps[0].val.opval); }
790 { (yyval.opval) = NULL; }
796 { parser->in_my = 0; (yyval.opval) = NULL; }
802 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
808 { (yyval.ival) = '@'; }
814 { (yyval.ival) = '%'; }
821 I32 sigil = (ps[-2].val.ival);
822 OP *var = (ps[-1].val.opval);
823 OP *defexpr = (ps[0].val.opval);
825 if (parser->sig_slurpy)
826 yyerror("Multiple slurpy parameters not allowed");
827 parser->sig_slurpy = (char)sigil;
830 yyerror("A slurpy parameter may not have "
833 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
840 { (yyval.opval) = NULL; }
846 { (yyval.opval) = newOP(OP_NULL, 0); }
852 { (yyval.opval) = (ps[0].val.opval); }
859 OP *var = (ps[-1].val.opval);
860 OP *defexpr = (ps[0].val.opval);
862 if (parser->sig_slurpy)
863 yyerror("Slurpy parameter not last");
868 parser->sig_optelems++;
870 if ( defexpr->op_type == OP_NULL
871 && !(defexpr->op_flags & OPf_KIDS))
873 /* handle '$=' special case */
875 yyerror("Optional parameter "
876 "lacks default expression");
880 /* a normal '=default' expression */
881 OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
884 /* re-purpose op_targ to hold @_ index */
886 (PADOFFSET)(parser->sig_elems - 1);
889 var->op_flags |= OPf_STACKED;
890 (void)op_sibling_splice(var,
895 var = newUNOP(OP_NULL, 0, defop);
898 /* NB: normally the first child of a
899 * logop is executed before the logop,
900 * and it pushes a boolean result
901 * ready for the logop. For ARGDEFELEM,
902 * the op itself does the boolean
903 * calculation, so set the first op to
906 var->op_next = defop;
907 defexpr->op_next = var;
911 if (parser->sig_optelems)
912 yyerror("Mandatory parameter "
913 "follows optional parameter");
916 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
923 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
929 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
935 { (yyval.opval) = (ps[-1].val.opval); }
942 (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
949 { (yyval.opval) = (ps[0].val.opval); }
955 { (yyval.opval) = NULL; }
961 { (yyval.opval) = (ps[0].val.opval); }
967 { (yyval.opval) = NULL; }
973 { (yyval.opval) = (ps[0].val.opval); }
979 { (yyval.opval) = (ps[-1].val.opval); }
987 SAVEIV(parser->sig_elems);
988 SAVEIV(parser->sig_optelems);
989 SAVEI8(parser->sig_slurpy);
990 parser->sig_elems = 0;
991 parser->sig_optelems = 0;
992 parser->sig_slurpy = 0;
993 parser->in_my = KEY_sigvar;
1001 OP *sigops = (ps[0].val.opval);
1005 if (!FEATURE_SIGNATURES_IS_ENABLED)
1006 Perl_croak(aTHX_ "Experimental "
1007 "subroutine signatures not enabled");
1009 /* We shouldn't get here otherwise */
1010 Perl_ck_warner_d(aTHX_
1011 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
1012 "The signatures feature is experimental");
1014 aux = (UNOP_AUX_item*)PerlMemShared_malloc(
1015 sizeof(UNOP_AUX_item) * 3);
1016 aux[0].iv = parser->sig_elems;
1017 aux[1].iv = parser->sig_optelems;
1018 aux[2].iv = parser->sig_slurpy;
1019 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL, aux);
1020 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
1021 sigops = op_prepend_elem(OP_LINESEQ,
1022 newSTATEOP(0, NULL, NULL),
1024 /* a nextstate at the end handles context
1025 * correctly for an empty sub body */
1026 (yyval.opval) = op_append_elem(OP_LINESEQ,
1028 newSTATEOP(0, NULL, NULL));
1031 /* tell the toker that attrributes can follow
1032 * this sig, but only so that the toker
1033 * can skip through any (illegal) trailing
1034 * attribute text then give a useful error
1035 * message about "attributes before sig",
1036 * rather than falling over ina mess at
1037 * unrecognised syntax.
1039 parser->expect = XATTRBLOCK;
1040 parser->sig_seen = TRUE;
1048 { (yyval.opval) = (ps[0].val.opval); }
1054 { (yyval.opval) = NULL; }
1061 if (parser->copline > (line_t)(ps[-2].val.ival))
1062 parser->copline = (line_t)(ps[-2].val.ival);
1063 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1070 { (yyval.opval) = (ps[0].val.opval); }
1076 { (yyval.opval) = NULL; }
1083 if (parser->copline > (line_t)(ps[-2].val.ival))
1084 parser->copline = (line_t)(ps[-2].val.ival);
1085 (yyval.opval) = block_end((ps[-4].val.ival),
1086 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1093 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1099 { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1105 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1111 { (yyval.opval) = (ps[-1].val.opval); }
1118 OP* term = (ps[0].val.opval);
1119 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1126 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1127 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1134 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1135 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1142 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1143 op_append_elem(OP_LIST,
1144 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1145 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1152 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1153 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1154 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1161 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1162 op_append_elem(OP_LIST,
1163 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1164 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1171 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1172 op_append_elem(OP_LIST,
1173 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1174 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1181 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1187 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1193 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1199 { SvREFCNT_inc_simple_void(PL_compcv);
1200 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1206 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1207 op_append_elem(OP_LIST,
1208 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1215 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1221 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1228 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1229 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1230 scalar((ps[-1].val.opval)));
1237 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1238 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1239 scalar((ps[-1].val.opval)));
1246 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1253 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1254 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1255 jmaybe((ps[-2].val.opval))); }
1261 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1262 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1263 jmaybe((ps[-2].val.opval))); }
1269 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1270 newCVREF(0, scalar((ps[-3].val.opval))));
1271 if (parser->expect == XBLOCK)
1272 parser->expect = XOPERATOR;
1279 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1280 op_append_elem(OP_LIST, (ps[-1].val.opval),
1281 newCVREF(0, scalar((ps[-4].val.opval)))));
1282 if (parser->expect == XBLOCK)
1283 parser->expect = XOPERATOR;
1290 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1291 op_append_elem(OP_LIST, (ps[-1].val.opval),
1292 newCVREF(0, scalar((ps[-3].val.opval)))));
1293 if (parser->expect == XBLOCK)
1294 parser->expect = XOPERATOR;
1301 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1302 newCVREF(0, scalar((ps[-2].val.opval))));
1303 if (parser->expect == XBLOCK)
1304 parser->expect = XOPERATOR;
1311 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1316 #line 1001 "perly.y"
1317 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1322 #line 1003 "perly.y"
1323 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1328 #line 1008 "perly.y"
1329 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1334 #line 1010 "perly.y"
1335 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1340 #line 1012 "perly.y"
1341 { if ((ps[-1].val.ival) != OP_REPEAT)
1342 scalar((ps[-2].val.opval));
1343 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1349 #line 1017 "perly.y"
1350 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1355 #line 1019 "perly.y"
1356 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1361 #line 1021 "perly.y"
1362 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1367 #line 1023 "perly.y"
1368 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1373 #line 1025 "perly.y"
1374 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1379 #line 1027 "perly.y"
1380 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1385 #line 1029 "perly.y"
1386 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1391 #line 1031 "perly.y"
1392 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1397 #line 1033 "perly.y"
1398 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1403 #line 1035 "perly.y"
1404 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1409 #line 1037 "perly.y"
1410 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1415 #line 1042 "perly.y"
1416 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1421 #line 1044 "perly.y"
1422 { (yyval.opval) = (ps[0].val.opval); }
1427 #line 1047 "perly.y"
1428 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1433 #line 1049 "perly.y"
1434 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1439 #line 1051 "perly.y"
1440 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1441 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1446 #line 1054 "perly.y"
1447 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1448 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1453 #line 1057 "perly.y"
1454 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1468 #line 1068 "perly.y"
1469 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1470 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1475 #line 1071 "perly.y"
1476 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1477 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1482 #line 1078 "perly.y"
1483 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1488 #line 1080 "perly.y"
1489 { (yyval.opval) = newANONLIST(NULL);}
1494 #line 1082 "perly.y"
1495 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1500 #line 1084 "perly.y"
1501 { (yyval.opval) = newANONHASH(NULL); }
1506 #line 1086 "perly.y"
1507 { SvREFCNT_inc_simple_void(PL_compcv);
1508 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1513 #line 1089 "perly.y"
1514 { SvREFCNT_inc_simple_void(PL_compcv);
1515 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1520 #line 1095 "perly.y"
1521 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1526 #line 1097 "perly.y"
1527 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1532 #line 1105 "perly.y"
1533 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1538 #line 1107 "perly.y"
1539 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1544 #line 1109 "perly.y"
1545 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1550 #line 1111 "perly.y"
1551 { (yyval.opval) = (ps[0].val.opval); }
1556 #line 1113 "perly.y"
1557 { (yyval.opval) = localize((ps[0].val.opval),0); }
1562 #line 1115 "perly.y"
1563 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1568 #line 1117 "perly.y"
1569 { (yyval.opval) = (ps[0].val.opval); }
1574 #line 1119 "perly.y"
1575 { (yyval.opval) = sawparens(newNULLLIST()); }
1580 #line 1121 "perly.y"
1581 { (yyval.opval) = (ps[0].val.opval); }
1586 #line 1123 "perly.y"
1587 { (yyval.opval) = (ps[0].val.opval); }
1592 #line 1125 "perly.y"
1593 { (yyval.opval) = (ps[0].val.opval); }
1598 #line 1127 "perly.y"
1599 { (yyval.opval) = (ps[0].val.opval); }
1604 #line 1129 "perly.y"
1605 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1610 #line 1131 "perly.y"
1611 { (yyval.opval) = (ps[0].val.opval); }
1616 #line 1133 "perly.y"
1617 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1618 newOP(OP_PUSHMARK, 0),
1619 newLISTOP(OP_ASLICE, 0,
1620 list((ps[-1].val.opval)),
1621 ref((ps[-3].val.opval), OP_ASLICE)));
1622 if ((yyval.opval) && (ps[-3].val.opval))
1623 (yyval.opval)->op_private |=
1624 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1630 #line 1143 "perly.y"
1631 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1632 newOP(OP_PUSHMARK, 0),
1633 newLISTOP(OP_KVASLICE, 0,
1634 list((ps[-1].val.opval)),
1635 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1636 if ((yyval.opval) && (ps[-3].val.opval))
1637 (yyval.opval)->op_private |=
1638 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1644 #line 1153 "perly.y"
1645 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1646 newOP(OP_PUSHMARK, 0),
1647 newLISTOP(OP_HSLICE, 0,
1648 list((ps[-2].val.opval)),
1649 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1650 if ((yyval.opval) && (ps[-4].val.opval))
1651 (yyval.opval)->op_private |=
1652 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1658 #line 1163 "perly.y"
1659 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1660 newOP(OP_PUSHMARK, 0),
1661 newLISTOP(OP_KVHSLICE, 0,
1662 list((ps[-2].val.opval)),
1663 ref((ps[-4].val.opval), OP_KVHSLICE)));
1664 if ((yyval.opval) && (ps[-4].val.opval))
1665 (yyval.opval)->op_private |=
1666 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1672 #line 1173 "perly.y"
1673 { (yyval.opval) = (ps[0].val.opval); }
1678 #line 1175 "perly.y"
1679 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1684 #line 1177 "perly.y"
1685 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1691 #line 1180 "perly.y"
1693 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1694 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1700 #line 1185 "perly.y"
1701 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1702 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1708 #line 1189 "perly.y"
1709 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1714 #line 1191 "perly.y"
1715 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1720 #line 1193 "perly.y"
1721 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1726 #line 1195 "perly.y"
1727 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1728 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1733 #line 1198 "perly.y"
1734 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1739 #line 1200 "perly.y"
1740 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1741 PL_hints |= HINT_BLOCK_SCOPE; }
1746 #line 1203 "perly.y"
1747 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1752 #line 1205 "perly.y"
1753 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1758 #line 1207 "perly.y"
1759 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1764 #line 1209 "perly.y"
1765 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1770 #line 1211 "perly.y"
1771 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1776 #line 1213 "perly.y"
1777 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1782 #line 1215 "perly.y"
1783 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1788 #line 1217 "perly.y"
1789 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1794 #line 1219 "perly.y"
1795 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1796 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1801 #line 1222 "perly.y"
1802 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1807 #line 1224 "perly.y"
1808 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1813 #line 1226 "perly.y"
1814 { (yyval.opval) = (ps[0].val.opval); }
1819 #line 1228 "perly.y"
1820 { (yyval.opval) = (ps[-2].val.opval); }
1825 #line 1230 "perly.y"
1826 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1831 #line 1232 "perly.y"
1832 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1833 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1834 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1839 #line 1236 "perly.y"
1840 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1845 #line 1238 "perly.y"
1847 if ( (ps[0].val.opval)->op_type != OP_TRANS
1848 && (ps[0].val.opval)->op_type != OP_TRANSR
1849 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1851 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1852 SAVEFREESV(PL_compcv);
1860 #line 1249 "perly.y"
1861 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1866 #line 1257 "perly.y"
1867 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1872 #line 1259 "perly.y"
1873 { (yyval.opval) = localize((ps[0].val.opval),1); }
1878 #line 1261 "perly.y"
1879 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1884 #line 1266 "perly.y"
1885 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1890 #line 1268 "perly.y"
1891 { (yyval.opval) = sawparens(newNULLLIST()); }
1896 #line 1271 "perly.y"
1897 { (yyval.opval) = (ps[0].val.opval); }
1902 #line 1273 "perly.y"
1903 { (yyval.opval) = (ps[0].val.opval); }
1908 #line 1275 "perly.y"
1909 { (yyval.opval) = (ps[0].val.opval); }
1914 #line 1280 "perly.y"
1915 { (yyval.opval) = NULL; }
1920 #line 1282 "perly.y"
1921 { (yyval.opval) = (ps[0].val.opval); }
1926 #line 1286 "perly.y"
1927 { (yyval.opval) = NULL; }
1932 #line 1288 "perly.y"
1933 { (yyval.opval) = (ps[0].val.opval); }
1938 #line 1292 "perly.y"
1939 { (yyval.opval) = NULL; }
1944 #line 1294 "perly.y"
1945 { (yyval.opval) = (ps[0].val.opval); }
1950 #line 1300 "perly.y"
1951 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
1956 #line 1317 "perly.y"
1957 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
1962 #line 1321 "perly.y"
1963 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
1968 #line 1325 "perly.y"
1969 { (yyval.opval) = newAVREF((ps[0].val.opval));
1970 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1976 #line 1331 "perly.y"
1977 { (yyval.opval) = newHVREF((ps[0].val.opval));
1978 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1984 #line 1337 "perly.y"
1985 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
1990 #line 1339 "perly.y"
1991 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1996 #line 1343 "perly.y"
1997 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
2002 #line 1348 "perly.y"
2003 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2008 #line 1353 "perly.y"
2009 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2014 #line 1358 "perly.y"
2015 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2020 #line 1363 "perly.y"
2021 { (yyval.opval) = scalar((ps[0].val.opval)); }
2026 #line 1365 "perly.y"
2027 { (yyval.opval) = scalar((ps[0].val.opval)); }
2032 #line 1367 "perly.y"
2033 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2038 #line 1370 "perly.y"
2039 { (yyval.opval) = (ps[0].val.opval); }
2050 * 4d7581de6482210c9b2f3302b589173c8d8c0a88724cc58b659ca9dcd2a35761 perly.y
2051 * 0947213b55d0ed11693554bea04987e886cf285f5c14cf9075fa1e7acc3f4061 regen_perly.pl