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);
127 { if (parser->copline > (line_t)(ps[-3].val.ival))
128 parser->copline = (line_t)(ps[-3].val.ival);
129 (yyval.opval) = block_end((ps[-2].val.ival), (ps[-1].val.opval));
136 { if (parser->copline > (line_t)(ps[-6].val.ival))
137 parser->copline = (line_t)(ps[-6].val.ival);
138 (yyval.opval) = block_end((ps[-5].val.ival), (ps[-2].val.opval));
145 { (yyval.ival) = block_start(TRUE);
146 parser->parsed_sub = 0; }
152 { if (parser->copline > (line_t)(ps[-3].val.ival))
153 parser->copline = (line_t)(ps[-3].val.ival);
154 (yyval.opval) = block_end((ps[-2].val.ival), (ps[-1].val.opval));
161 { (yyval.ival) = block_start(FALSE);
162 parser->parsed_sub = 0; }
168 { (yyval.opval) = NULL; }
174 { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-1].val.opval), (ps[0].val.opval));
175 PL_pad_reset_pending = TRUE;
176 if ((ps[-1].val.opval) && (ps[0].val.opval))
177 PL_hints |= HINT_BLOCK_SCOPE;
184 { (yyval.opval) = NULL; }
190 { (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-1].val.opval), (ps[0].val.opval));
191 PL_pad_reset_pending = TRUE;
192 if ((ps[-1].val.opval) && (ps[0].val.opval))
193 PL_hints |= HINT_BLOCK_SCOPE;
201 (yyval.opval) = (ps[0].val.opval) ? newSTATEOP(0, NULL, (ps[0].val.opval)) : NULL;
208 { (yyval.opval) = (ps[0].val.opval); }
215 SV *label = cSVOPx_sv((ps[-1].val.opval));
216 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
217 savepv(SvPVX_const(label)), (ps[0].val.opval));
218 op_free((ps[-1].val.opval));
226 SV *label = cSVOPx_sv((ps[-1].val.opval));
227 (yyval.opval) = newSTATEOP(SvFLAGS(label) & SVf_UTF8,
228 savepv(SvPVX_const(label)), (ps[0].val.opval));
229 op_free((ps[-1].val.opval));
236 { (yyval.opval) = (ps[0].val.opval); }
243 CV *fmtcv = PL_compcv;
244 newFORM((ps[-2].val.ival), (ps[-1].val.opval), (ps[0].val.opval));
245 (yyval.opval) = NULL;
246 if (CvOUTSIDE(fmtcv) && !CvEVAL(CvOUTSIDE(fmtcv))) {
247 pad_add_weakref(fmtcv);
249 parser->parsed_sub = 1;
257 init_named_cv(PL_compcv, (ps[-1].val.opval));
259 parser->in_my_stash = NULL;
267 SvREFCNT_inc_simple_void(PL_compcv);
268 (ps[-5].val.opval)->op_type == OP_CONST
269 ? newATTRSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
270 : newMYSUB((ps[-4].val.ival), (ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
272 (yyval.opval) = NULL;
274 parser->parsed_sub = 1;
282 init_named_cv(PL_compcv, (ps[-1].val.opval));
284 parser->in_my_stash = NULL;
292 SvREFCNT_inc_simple_void(PL_compcv);
293 (ps[-4].val.opval)->op_type == OP_CONST
294 ? newATTRSUB((ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
295 : newMYSUB( (ps[-3].val.ival), (ps[-4].val.opval), NULL, (ps[-1].val.opval), (ps[0].val.opval))
297 (yyval.opval) = NULL;
299 parser->parsed_sub = 1;
307 package((ps[-1].val.opval));
308 if ((ps[-2].val.opval))
309 package_version((ps[-2].val.opval));
310 (yyval.opval) = NULL;
317 { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ }
324 SvREFCNT_inc_simple_void(PL_compcv);
325 utilize((ps[-6].val.ival), (ps[-5].val.ival), (ps[-3].val.opval), (ps[-2].val.opval), (ps[-1].val.opval));
326 parser->parsed_sub = 1;
327 (yyval.opval) = NULL;
335 (yyval.opval) = block_end((ps[-4].val.ival),
336 newCONDOP(0, (ps[-3].val.opval), op_scope((ps[-1].val.opval)), (ps[0].val.opval)));
337 parser->copline = (line_t)(ps[-6].val.ival);
345 (yyval.opval) = block_end((ps[-4].val.ival),
346 newCONDOP(0, (ps[-3].val.opval), (ps[0].val.opval), op_scope((ps[-1].val.opval))));
347 parser->copline = (line_t)(ps[-6].val.ival);
355 (yyval.opval) = block_end((ps[-3].val.ival), newGIVENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)), 0));
356 parser->copline = (line_t)(ps[-5].val.ival);
363 { (yyval.opval) = block_end((ps[-3].val.ival), newWHENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)))); }
369 { (yyval.opval) = newWHENOP(0, op_scope((ps[0].val.opval))); }
376 (yyval.opval) = block_end((ps[-5].val.ival),
377 newWHILEOP(0, 1, NULL,
378 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
379 parser->copline = (line_t)(ps[-7].val.ival);
387 (yyval.opval) = block_end((ps[-5].val.ival),
388 newWHILEOP(0, 1, NULL,
389 (ps[-4].val.opval), (ps[-1].val.opval), (ps[0].val.opval), (ps[-2].val.ival)));
390 parser->copline = (line_t)(ps[-7].val.ival);
397 { parser->expect = XTERM; }
403 { parser->expect = XTERM; }
410 OP *initop = (ps[-9].val.opval);
411 OP *forop = newWHILEOP(0, 1, NULL,
412 scalar((ps[-6].val.opval)), (ps[0].val.opval), (ps[-2].val.opval), (ps[-3].val.ival));
414 forop = op_prepend_elem(OP_LINESEQ, initop,
415 op_append_elem(OP_LINESEQ,
416 newOP(OP_UNSTACK, OPf_SPECIAL),
419 PL_hints |= HINT_BLOCK_SCOPE;
420 (yyval.opval) = block_end((ps[-10].val.ival), forop);
421 parser->copline = (line_t)(ps[-12].val.ival);
429 (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)));
430 parser->copline = (line_t)(ps[-8].val.ival);
438 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(0,
439 op_lvalue((ps[-6].val.opval), OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
440 parser->copline = (line_t)(ps[-7].val.ival);
447 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
454 (yyval.opval) = block_end(
458 newUNOP(OP_REFGEN, 0,
461 (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
463 parser->copline = (line_t)(ps[-9].val.ival);
471 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(
472 0, op_lvalue(newUNOP(OP_REFGEN, 0,
474 OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
475 parser->copline = (line_t)(ps[-8].val.ival);
483 (yyval.opval) = block_end((ps[-4].val.ival),
484 newFOROP(0, NULL, (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
485 parser->copline = (line_t)(ps[-6].val.ival);
493 /* a block is a loop that happens once */
494 (yyval.opval) = newWHILEOP(0, 1, NULL,
495 NULL, (ps[-1].val.opval), (ps[0].val.opval), 0);
503 package((ps[-2].val.opval));
504 if ((ps[-3].val.opval)) {
505 package_version((ps[-3].val.opval));
514 /* a block is a loop that happens once */
515 (yyval.opval) = newWHILEOP(0, 1, NULL,
516 NULL, block_end((ps[-3].val.ival), (ps[-1].val.opval)), NULL, 0);
517 if (parser->copline > (line_t)(ps[-4].val.ival))
518 parser->copline = (line_t)(ps[-4].val.ival);
526 (yyval.opval) = (ps[-1].val.opval);
534 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
535 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
543 (yyval.opval) = NULL;
544 parser->copline = NOLINE;
552 if ((ps[0].val.opval)) {
553 OP *term = (ps[0].val.opval);
554 list = op_append_elem(OP_LIST, (ps[-1].val.opval), term);
557 list = (ps[-1].val.opval);
559 if (parser->copline == NOLINE)
560 parser->copline = CopLINE(PL_curcop)-1;
561 else parser->copline--;
562 (yyval.opval) = newSTATEOP(0, NULL,
563 op_convert_list(OP_FORMLINE, 0, list));
570 { (yyval.opval) = NULL; }
576 { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
582 { (yyval.opval) = NULL; }
588 { (yyval.opval) = (ps[0].val.opval); }
594 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
600 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
606 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
612 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
618 { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
619 parser->copline = (line_t)(ps[-1].val.ival); }
625 { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
631 { (yyval.opval) = NULL; }
638 ((ps[0].val.opval))->op_flags |= OPf_PARENS;
639 (yyval.opval) = op_scope((ps[0].val.opval));
646 { parser->copline = (line_t)(ps[-5].val.ival);
647 (yyval.opval) = newCONDOP(0,
648 newSTATEOP(OPf_SPECIAL,NULL,(ps[-3].val.opval)),
649 op_scope((ps[-1].val.opval)), (ps[0].val.opval));
650 PL_hints |= HINT_BLOCK_SCOPE;
657 { (yyval.opval) = NULL; }
663 { (yyval.opval) = op_scope((ps[0].val.opval)); }
669 { (yyval.ival) = (PL_min_intro_pending &&
670 PL_max_intro_pending >= PL_min_intro_pending);
677 { (yyval.opval) = NULL; }
684 (void)scan_num("1", &tmplval);
685 (yyval.opval) = tmplval.opval; }
691 { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
697 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
703 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
709 { (yyval.opval) = (ps[0].val.opval); }
715 { (yyval.opval) = NULL; }
721 { (yyval.ival) = start_subparse(FALSE, 0);
722 SAVEFREESV(PL_compcv); }
728 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
729 SAVEFREESV(PL_compcv); }
735 { (yyval.ival) = start_subparse(TRUE, 0);
736 SAVEFREESV(PL_compcv); }
742 { (yyval.opval) = NULL; }
748 { (yyval.opval) = NULL; }
754 { (yyval.opval) = (ps[0].val.opval); }
760 { (yyval.opval) = NULL; }
766 { (yyval.opval) = (ps[0].val.opval); }
772 { (yyval.opval) = NULL; }
778 { parser->in_my = 0; (yyval.opval) = NULL; }
784 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
790 { (yyval.ival) = '@'; }
796 { (yyval.ival) = '%'; }
803 I32 sigil = (ps[-2].val.ival);
804 OP *var = (ps[-1].val.opval);
805 OP *defexpr = (ps[0].val.opval);
807 if (parser->sig_slurpy)
808 yyerror("Multiple slurpy parameters not allowed");
809 parser->sig_slurpy = (char)sigil;
812 yyerror("A slurpy parameter may not have "
815 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
822 { (yyval.opval) = NULL; }
828 { (yyval.opval) = newOP(OP_NULL, 0); }
834 { (yyval.opval) = (ps[0].val.opval); }
841 OP *var = (ps[-1].val.opval);
842 OP *defexpr = (ps[0].val.opval);
844 if (parser->sig_slurpy)
845 yyerror("Slurpy parameter not last");
850 parser->sig_optelems++;
852 if ( defexpr->op_type == OP_NULL
853 && !(defexpr->op_flags & OPf_KIDS))
855 /* handle '$=' special case */
857 yyerror("Optional parameter "
858 "lacks default expression");
862 /* a normal '=default' expression */
863 OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
866 /* re-purpose op_targ to hold @_ index */
868 (PADOFFSET)(parser->sig_elems - 1);
871 var->op_flags |= OPf_STACKED;
872 (void)op_sibling_splice(var,
877 var = newUNOP(OP_NULL, 0, defop);
880 /* NB: normally the first child of a
881 * logop is executed before the logop,
882 * and it pushes a boolean result
883 * ready for the logop. For ARGDEFELEM,
884 * the op itself does the boolean
885 * calculation, so set the first op to
888 var->op_next = defop;
889 defexpr->op_next = var;
893 if (parser->sig_optelems)
894 yyerror("Mandatory parameter "
895 "follows optional parameter");
898 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
905 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
911 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
917 { (yyval.opval) = (ps[-1].val.opval); }
924 (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
931 { (yyval.opval) = (ps[0].val.opval); }
937 { (yyval.opval) = NULL; }
943 { (yyval.opval) = (ps[0].val.opval); }
949 { (yyval.opval) = NULL; }
955 { (yyval.opval) = (ps[0].val.opval); }
963 SAVEIV(parser->sig_elems);
964 SAVEIV(parser->sig_optelems);
965 SAVEI8(parser->sig_slurpy);
966 parser->sig_elems = 0;
967 parser->sig_optelems = 0;
968 parser->sig_slurpy = 0;
969 parser->in_my = KEY_sigvar;
977 OP *sigops = (ps[-1].val.opval);
981 if (!FEATURE_SIGNATURES_IS_ENABLED)
982 Perl_croak(aTHX_ "Experimental "
983 "subroutine signatures not enabled");
985 /* We shouldn't get here otherwise */
986 Perl_ck_warner_d(aTHX_
987 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
988 "The signatures feature is experimental");
990 aux = (UNOP_AUX_item*)PerlMemShared_malloc(
991 sizeof(UNOP_AUX_item) * 3);
992 aux[0].iv = parser->sig_elems;
993 aux[1].iv = parser->sig_optelems;
994 aux[2].iv = parser->sig_slurpy;
995 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL, aux);
996 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
997 sigops = op_prepend_elem(OP_LINESEQ,
998 newSTATEOP(0, NULL, NULL),
1000 /* a nextstate at the end handles context
1001 * correctly for an empty sub body */
1002 (yyval.opval) = op_append_elem(OP_LINESEQ,
1004 newSTATEOP(0, NULL, NULL));
1007 /* tell the toker that attrributes can follow
1008 * this sig, but only so that the toker
1009 * can skip through any (illegal) trailing
1010 * attribute text then give a useful error
1011 * message about "attributes before sig",
1012 * rather than falling over ina mess at
1013 * unrecognised syntax.
1015 parser->expect = XATTRBLOCK;
1016 parser->sig_seen = TRUE;
1024 { (yyval.opval) = (ps[0].val.opval); }
1030 { (yyval.opval) = NULL; }
1037 if (parser->copline > (line_t)(ps[-2].val.ival))
1038 parser->copline = (line_t)(ps[-2].val.ival);
1039 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1046 { (yyval.opval) = (ps[0].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) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1087 { (yyval.opval) = (ps[-1].val.opval); }
1094 OP* term = (ps[0].val.opval);
1095 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1102 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1103 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1110 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1111 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1118 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1119 op_append_elem(OP_LIST,
1120 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1121 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1128 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1129 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1130 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1137 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1138 op_append_elem(OP_LIST,
1139 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1140 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1147 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1148 op_append_elem(OP_LIST,
1149 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1150 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1157 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1163 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1169 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1175 { SvREFCNT_inc_simple_void(PL_compcv);
1176 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1182 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1183 op_append_elem(OP_LIST,
1184 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1191 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1197 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1204 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1205 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1206 scalar((ps[-1].val.opval)));
1213 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1214 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1215 scalar((ps[-1].val.opval)));
1222 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1229 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1230 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1231 jmaybe((ps[-2].val.opval))); }
1237 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1238 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1239 jmaybe((ps[-2].val.opval))); }
1245 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1246 newCVREF(0, scalar((ps[-3].val.opval))));
1247 if (parser->expect == XBLOCK)
1248 parser->expect = XOPERATOR;
1255 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1256 op_append_elem(OP_LIST, (ps[-1].val.opval),
1257 newCVREF(0, scalar((ps[-4].val.opval)))));
1258 if (parser->expect == XBLOCK)
1259 parser->expect = XOPERATOR;
1266 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1267 op_append_elem(OP_LIST, (ps[-1].val.opval),
1268 newCVREF(0, scalar((ps[-3].val.opval)))));
1269 if (parser->expect == XBLOCK)
1270 parser->expect = XOPERATOR;
1277 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1278 newCVREF(0, scalar((ps[-2].val.opval))));
1279 if (parser->expect == XBLOCK)
1280 parser->expect = XOPERATOR;
1287 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1293 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1299 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1305 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1311 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1316 #line 1000 "perly.y"
1317 { if ((ps[-1].val.ival) != OP_REPEAT)
1318 scalar((ps[-2].val.opval));
1319 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1325 #line 1005 "perly.y"
1326 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1331 #line 1007 "perly.y"
1332 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1337 #line 1009 "perly.y"
1338 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1343 #line 1011 "perly.y"
1344 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1349 #line 1013 "perly.y"
1350 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1355 #line 1015 "perly.y"
1356 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1361 #line 1017 "perly.y"
1362 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1367 #line 1019 "perly.y"
1368 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1373 #line 1021 "perly.y"
1374 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1379 #line 1023 "perly.y"
1380 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1385 #line 1025 "perly.y"
1386 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1391 #line 1030 "perly.y"
1392 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1397 #line 1032 "perly.y"
1398 { (yyval.opval) = (ps[0].val.opval); }
1403 #line 1035 "perly.y"
1404 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1409 #line 1037 "perly.y"
1410 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1415 #line 1039 "perly.y"
1416 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1417 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1422 #line 1042 "perly.y"
1423 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1424 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1429 #line 1045 "perly.y"
1430 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1444 #line 1056 "perly.y"
1445 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1446 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1451 #line 1059 "perly.y"
1452 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1453 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1458 #line 1066 "perly.y"
1459 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1464 #line 1068 "perly.y"
1465 { (yyval.opval) = newANONLIST(NULL);}
1470 #line 1070 "perly.y"
1471 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1476 #line 1072 "perly.y"
1477 { (yyval.opval) = newANONHASH(NULL); }
1482 #line 1074 "perly.y"
1483 { SvREFCNT_inc_simple_void(PL_compcv);
1484 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1489 #line 1077 "perly.y"
1490 { SvREFCNT_inc_simple_void(PL_compcv);
1491 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1496 #line 1083 "perly.y"
1497 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1502 #line 1085 "perly.y"
1503 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1508 #line 1093 "perly.y"
1509 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1514 #line 1095 "perly.y"
1515 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1520 #line 1097 "perly.y"
1521 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1526 #line 1099 "perly.y"
1527 { (yyval.opval) = (ps[0].val.opval); }
1532 #line 1101 "perly.y"
1533 { (yyval.opval) = localize((ps[0].val.opval),0); }
1538 #line 1103 "perly.y"
1539 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1544 #line 1105 "perly.y"
1545 { (yyval.opval) = (ps[0].val.opval); }
1550 #line 1107 "perly.y"
1551 { (yyval.opval) = sawparens(newNULLLIST()); }
1556 #line 1109 "perly.y"
1557 { (yyval.opval) = (ps[0].val.opval); }
1562 #line 1111 "perly.y"
1563 { (yyval.opval) = (ps[0].val.opval); }
1568 #line 1113 "perly.y"
1569 { (yyval.opval) = (ps[0].val.opval); }
1574 #line 1115 "perly.y"
1575 { (yyval.opval) = (ps[0].val.opval); }
1580 #line 1117 "perly.y"
1581 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1586 #line 1119 "perly.y"
1587 { (yyval.opval) = (ps[0].val.opval); }
1592 #line 1121 "perly.y"
1593 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1594 newOP(OP_PUSHMARK, 0),
1595 newLISTOP(OP_ASLICE, 0,
1596 list((ps[-1].val.opval)),
1597 ref((ps[-3].val.opval), OP_ASLICE)));
1598 if ((yyval.opval) && (ps[-3].val.opval))
1599 (yyval.opval)->op_private |=
1600 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1606 #line 1131 "perly.y"
1607 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1608 newOP(OP_PUSHMARK, 0),
1609 newLISTOP(OP_KVASLICE, 0,
1610 list((ps[-1].val.opval)),
1611 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1612 if ((yyval.opval) && (ps[-3].val.opval))
1613 (yyval.opval)->op_private |=
1614 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1620 #line 1141 "perly.y"
1621 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1622 newOP(OP_PUSHMARK, 0),
1623 newLISTOP(OP_HSLICE, 0,
1624 list((ps[-2].val.opval)),
1625 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1626 if ((yyval.opval) && (ps[-4].val.opval))
1627 (yyval.opval)->op_private |=
1628 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1634 #line 1151 "perly.y"
1635 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1636 newOP(OP_PUSHMARK, 0),
1637 newLISTOP(OP_KVHSLICE, 0,
1638 list((ps[-2].val.opval)),
1639 ref((ps[-4].val.opval), OP_KVHSLICE)));
1640 if ((yyval.opval) && (ps[-4].val.opval))
1641 (yyval.opval)->op_private |=
1642 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1648 #line 1161 "perly.y"
1649 { (yyval.opval) = (ps[0].val.opval); }
1654 #line 1163 "perly.y"
1655 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1660 #line 1165 "perly.y"
1661 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1667 #line 1168 "perly.y"
1669 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1670 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1676 #line 1173 "perly.y"
1677 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1678 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1684 #line 1177 "perly.y"
1685 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1690 #line 1179 "perly.y"
1691 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1696 #line 1181 "perly.y"
1697 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1702 #line 1183 "perly.y"
1703 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1704 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1709 #line 1186 "perly.y"
1710 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1715 #line 1188 "perly.y"
1716 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1717 PL_hints |= HINT_BLOCK_SCOPE; }
1722 #line 1191 "perly.y"
1723 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1728 #line 1193 "perly.y"
1729 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1734 #line 1195 "perly.y"
1735 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1740 #line 1197 "perly.y"
1741 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1746 #line 1199 "perly.y"
1747 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1752 #line 1201 "perly.y"
1753 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1758 #line 1203 "perly.y"
1759 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1764 #line 1205 "perly.y"
1765 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1770 #line 1207 "perly.y"
1771 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1772 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1777 #line 1210 "perly.y"
1778 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1783 #line 1212 "perly.y"
1784 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1789 #line 1214 "perly.y"
1790 { (yyval.opval) = (ps[0].val.opval); }
1795 #line 1216 "perly.y"
1796 { (yyval.opval) = (ps[-2].val.opval); }
1801 #line 1218 "perly.y"
1802 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1807 #line 1220 "perly.y"
1808 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1809 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1810 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1815 #line 1224 "perly.y"
1816 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1821 #line 1226 "perly.y"
1823 if ( (ps[0].val.opval)->op_type != OP_TRANS
1824 && (ps[0].val.opval)->op_type != OP_TRANSR
1825 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1827 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1828 SAVEFREESV(PL_compcv);
1836 #line 1237 "perly.y"
1837 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1842 #line 1245 "perly.y"
1843 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1848 #line 1247 "perly.y"
1849 { (yyval.opval) = localize((ps[0].val.opval),1); }
1854 #line 1249 "perly.y"
1855 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1860 #line 1254 "perly.y"
1861 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1866 #line 1256 "perly.y"
1867 { (yyval.opval) = sawparens(newNULLLIST()); }
1872 #line 1259 "perly.y"
1873 { (yyval.opval) = (ps[0].val.opval); }
1878 #line 1261 "perly.y"
1879 { (yyval.opval) = (ps[0].val.opval); }
1884 #line 1263 "perly.y"
1885 { (yyval.opval) = (ps[0].val.opval); }
1890 #line 1268 "perly.y"
1891 { (yyval.opval) = NULL; }
1896 #line 1270 "perly.y"
1897 { (yyval.opval) = (ps[0].val.opval); }
1902 #line 1274 "perly.y"
1903 { (yyval.opval) = NULL; }
1908 #line 1276 "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 1288 "perly.y"
1927 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
1932 #line 1305 "perly.y"
1933 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
1938 #line 1309 "perly.y"
1939 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
1944 #line 1313 "perly.y"
1945 { (yyval.opval) = newAVREF((ps[0].val.opval));
1946 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1952 #line 1319 "perly.y"
1953 { (yyval.opval) = newHVREF((ps[0].val.opval));
1954 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1960 #line 1325 "perly.y"
1961 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
1966 #line 1327 "perly.y"
1967 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1972 #line 1331 "perly.y"
1973 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
1978 #line 1336 "perly.y"
1979 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
1984 #line 1341 "perly.y"
1985 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
1990 #line 1346 "perly.y"
1991 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
1996 #line 1351 "perly.y"
1997 { (yyval.opval) = scalar((ps[0].val.opval)); }
2002 #line 1353 "perly.y"
2003 { (yyval.opval) = scalar((ps[0].val.opval)); }
2008 #line 1355 "perly.y"
2009 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2014 #line 1358 "perly.y"
2015 { (yyval.opval) = (ps[0].val.opval); }
2026 * 41d458c12a47d69d8ab1315970582b2055ecea77bfc8a582b557e9b3df1c290a perly.y
2027 * 0947213b55d0ed11693554bea04987e886cf285f5c14cf9075fa1e7acc3f4061 regen_perly.pl