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[-8].val.ival), newFOROP(0, (ps[-6].val.opval), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
457 parser->copline = (line_t)(ps[-10].val.ival);
465 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(0,
466 op_lvalue((ps[-6].val.opval), OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
467 parser->copline = (line_t)(ps[-7].val.ival);
474 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
481 (yyval.opval) = block_end(
485 newUNOP(OP_REFGEN, 0,
488 (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
490 parser->copline = (line_t)(ps[-9].val.ival);
498 (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(
499 0, op_lvalue(newUNOP(OP_REFGEN, 0,
501 OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
502 parser->copline = (line_t)(ps[-8].val.ival);
510 (yyval.opval) = block_end((ps[-4].val.ival),
511 newFOROP(0, NULL, (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
512 parser->copline = (line_t)(ps[-6].val.ival);
519 { parser->in_my = 1; }
525 { parser->in_my = 0; intro_my(); }
532 (yyval.opval) = newTRYCATCHOP(0,
533 (ps[-8].val.opval), (ps[-3].val.opval), block_end((ps[-4].val.ival), op_scope((ps[0].val.opval))));
534 parser->copline = (line_t)(ps[-9].val.ival);
542 /* a block is a loop that happens once */
543 (yyval.opval) = newWHILEOP(0, 1, NULL,
544 NULL, (ps[-1].val.opval), (ps[0].val.opval), 0);
552 package((ps[-2].val.opval));
553 if ((ps[-3].val.opval)) {
554 package_version((ps[-3].val.opval));
563 /* a block is a loop that happens once */
564 (yyval.opval) = newWHILEOP(0, 1, NULL,
565 NULL, block_end((ps[-3].val.ival), (ps[-1].val.opval)), NULL, 0);
566 if (parser->copline > (line_t)(ps[-4].val.ival))
567 parser->copline = (line_t)(ps[-4].val.ival);
575 (yyval.opval) = (ps[-1].val.opval);
583 (yyval.opval) = newDEFEROP(0, op_scope((ps[0].val.opval)));
591 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
592 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
600 (yyval.opval) = NULL;
601 parser->copline = NOLINE;
609 if ((ps[0].val.opval)) {
610 OP *term = (ps[0].val.opval);
611 list = op_append_elem(OP_LIST, (ps[-1].val.opval), term);
614 list = (ps[-1].val.opval);
616 if (parser->copline == NOLINE)
617 parser->copline = CopLINE(PL_curcop)-1;
618 else parser->copline--;
619 (yyval.opval) = newSTATEOP(0, NULL,
620 op_convert_list(OP_FORMLINE, 0, list));
627 { (yyval.opval) = NULL; }
633 { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
639 { (yyval.opval) = NULL; }
645 { (yyval.opval) = (ps[0].val.opval); }
651 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
657 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
663 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
669 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
675 { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
676 parser->copline = (line_t)(ps[-1].val.ival); }
682 { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
688 { (yyval.opval) = NULL; }
695 ((ps[0].val.opval))->op_flags |= OPf_PARENS;
696 (yyval.opval) = op_scope((ps[0].val.opval));
703 { parser->copline = (line_t)(ps[-5].val.ival);
704 (yyval.opval) = newCONDOP(0,
705 newSTATEOP(OPf_SPECIAL,NULL,(ps[-3].val.opval)),
706 op_scope((ps[-1].val.opval)), (ps[0].val.opval));
707 PL_hints |= HINT_BLOCK_SCOPE;
714 { (yyval.opval) = NULL; }
720 { (yyval.opval) = op_scope((ps[0].val.opval)); }
726 { (yyval.ival) = (PL_min_intro_pending &&
727 PL_max_intro_pending >= PL_min_intro_pending);
734 { (yyval.opval) = NULL; }
741 (void)scan_num("1", &tmplval);
742 (yyval.opval) = tmplval.opval; }
748 { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
754 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
760 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
766 { (yyval.opval) = (ps[0].val.opval); }
772 { (yyval.opval) = NULL; }
778 { (yyval.ival) = start_subparse(FALSE, 0);
779 SAVEFREESV(PL_compcv); }
785 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
786 SAVEFREESV(PL_compcv); }
792 { (yyval.ival) = start_subparse(TRUE, 0);
793 SAVEFREESV(PL_compcv); }
799 { (yyval.opval) = NULL; }
805 { (yyval.opval) = NULL; }
811 { (yyval.opval) = (ps[0].val.opval); }
817 { (yyval.opval) = NULL; }
823 { (yyval.opval) = (ps[0].val.opval); }
829 { (yyval.opval) = NULL; }
835 { parser->in_my = 0; (yyval.opval) = NULL; }
841 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
847 { (yyval.ival) = '@'; }
853 { (yyval.ival) = '%'; }
860 I32 sigil = (ps[-2].val.ival);
861 OP *var = (ps[-1].val.opval);
862 OP *defexpr = (ps[0].val.opval);
864 if (parser->sig_slurpy)
865 yyerror("Multiple slurpy parameters not allowed");
866 parser->sig_slurpy = (char)sigil;
869 yyerror("A slurpy parameter may not have "
872 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
879 { (yyval.opval) = NULL; }
885 { (yyval.opval) = newOP(OP_NULL, 0); }
891 { (yyval.opval) = (ps[0].val.opval); }
898 OP *var = (ps[-1].val.opval);
899 OP *defexpr = (ps[0].val.opval);
901 if (parser->sig_slurpy)
902 yyerror("Slurpy parameter not last");
907 parser->sig_optelems++;
909 if ( defexpr->op_type == OP_NULL
910 && !(defexpr->op_flags & OPf_KIDS))
912 /* handle '$=' special case */
914 yyerror("Optional parameter "
915 "lacks default expression");
919 /* a normal '=default' expression */
920 OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
923 /* re-purpose op_targ to hold @_ index */
925 (PADOFFSET)(parser->sig_elems - 1);
928 var->op_flags |= OPf_STACKED;
929 (void)op_sibling_splice(var,
934 var = newUNOP(OP_NULL, 0, defop);
937 /* NB: normally the first child of a
938 * logop is executed before the logop,
939 * and it pushes a boolean result
940 * ready for the logop. For ARGDEFELEM,
941 * the op itself does the boolean
942 * calculation, so set the first op to
945 var->op_next = defop;
946 defexpr->op_next = var;
950 if (parser->sig_optelems)
951 yyerror("Mandatory parameter "
952 "follows optional parameter");
955 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
962 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
968 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
974 { (yyval.opval) = (ps[-1].val.opval); }
981 (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
988 { (yyval.opval) = (ps[0].val.opval); }
994 { (yyval.opval) = NULL; }
1000 { (yyval.opval) = (ps[0].val.opval); }
1006 { (yyval.opval) = NULL; }
1012 { (yyval.opval) = (ps[0].val.opval); }
1018 { (yyval.opval) = (ps[-1].val.opval); }
1026 SAVEIV(parser->sig_elems);
1027 SAVEIV(parser->sig_optelems);
1028 SAVEI8(parser->sig_slurpy);
1029 parser->sig_elems = 0;
1030 parser->sig_optelems = 0;
1031 parser->sig_slurpy = 0;
1032 parser->in_my = KEY_sigvar;
1040 OP *sigops = (ps[0].val.opval);
1041 struct op_argcheck_aux *aux;
1044 if (!FEATURE_SIGNATURES_IS_ENABLED)
1045 Perl_croak(aTHX_ "Experimental "
1046 "subroutine signatures not enabled");
1048 /* We shouldn't get here otherwise */
1049 Perl_ck_warner_d(aTHX_
1050 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
1051 "The signatures feature is experimental");
1053 aux = (struct op_argcheck_aux*)
1054 PerlMemShared_malloc(
1055 sizeof(struct op_argcheck_aux));
1056 aux->params = parser->sig_elems;
1057 aux->opt_params = parser->sig_optelems;
1058 aux->slurpy = parser->sig_slurpy;
1059 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL,
1060 (UNOP_AUX_item *)aux);
1061 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
1062 sigops = op_prepend_elem(OP_LINESEQ,
1063 newSTATEOP(0, NULL, NULL),
1065 /* a nextstate at the end handles context
1066 * correctly for an empty sub body */
1067 sigops = op_append_elem(OP_LINESEQ,
1069 newSTATEOP(0, NULL, NULL));
1070 /* wrap the list of arg ops in a NULL aux op.
1071 This serves two purposes. First, it makes
1072 the arg list a separate subtree from the
1073 body of the sub, and secondly the null op
1074 may in future be upgraded to an OP_SIGNATURE
1075 when implemented. For now leave it as
1077 (yyval.opval) = newUNOP_AUX(OP_ARGCHECK, 0, sigops, NULL);
1078 op_null((yyval.opval));
1081 /* tell the toker that attrributes can follow
1082 * this sig, but only so that the toker
1083 * can skip through any (illegal) trailing
1084 * attribute text then give a useful error
1085 * message about "attributes before sig",
1086 * rather than falling over ina mess at
1087 * unrecognised syntax.
1089 parser->expect = XATTRBLOCK;
1090 parser->sig_seen = TRUE;
1098 { (yyval.opval) = (ps[0].val.opval); }
1104 { (yyval.opval) = NULL; }
1111 if (parser->copline > (line_t)(ps[-2].val.ival))
1112 parser->copline = (line_t)(ps[-2].val.ival);
1113 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1120 { (yyval.opval) = (ps[0].val.opval); }
1126 { (yyval.opval) = NULL; }
1133 if (parser->copline > (line_t)(ps[-2].val.ival))
1134 parser->copline = (line_t)(ps[-2].val.ival);
1135 (yyval.opval) = block_end((ps[-4].val.ival),
1136 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1143 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1149 { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1155 { (yyval.opval) = (ps[-1].val.opval); }
1162 OP* term = (ps[0].val.opval);
1163 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1170 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1171 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1178 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1179 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1186 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1187 op_append_elem(OP_LIST,
1188 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1189 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1196 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1197 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1198 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1205 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1206 op_append_elem(OP_LIST,
1207 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1208 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1215 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1216 op_append_elem(OP_LIST,
1217 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1218 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1225 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1231 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1237 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1243 { SvREFCNT_inc_simple_void(PL_compcv);
1244 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1250 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1251 op_append_elem(OP_LIST,
1252 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1259 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1265 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1271 #line 1001 "perly.y"
1272 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1273 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1274 scalar((ps[-1].val.opval)));
1280 #line 1006 "perly.y"
1281 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1282 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1283 scalar((ps[-1].val.opval)));
1289 #line 1011 "perly.y"
1290 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1296 #line 1014 "perly.y"
1297 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1298 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1299 jmaybe((ps[-2].val.opval))); }
1304 #line 1018 "perly.y"
1305 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1306 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1307 jmaybe((ps[-2].val.opval))); }
1312 #line 1022 "perly.y"
1313 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1314 newCVREF(0, scalar((ps[-3].val.opval))));
1315 if (parser->expect == XBLOCK)
1316 parser->expect = XOPERATOR;
1322 #line 1028 "perly.y"
1323 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1324 op_append_elem(OP_LIST, (ps[-1].val.opval),
1325 newCVREF(0, scalar((ps[-4].val.opval)))));
1326 if (parser->expect == XBLOCK)
1327 parser->expect = XOPERATOR;
1333 #line 1036 "perly.y"
1334 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1335 op_append_elem(OP_LIST, (ps[-1].val.opval),
1336 newCVREF(0, scalar((ps[-3].val.opval)))));
1337 if (parser->expect == XBLOCK)
1338 parser->expect = XOPERATOR;
1344 #line 1043 "perly.y"
1345 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1346 newCVREF(0, scalar((ps[-2].val.opval))));
1347 if (parser->expect == XBLOCK)
1348 parser->expect = XOPERATOR;
1354 #line 1049 "perly.y"
1355 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1360 #line 1051 "perly.y"
1361 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1366 #line 1053 "perly.y"
1367 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1372 #line 1058 "perly.y"
1373 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1378 #line 1060 "perly.y"
1379 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1384 #line 1062 "perly.y"
1385 { if ((ps[-1].val.ival) != OP_REPEAT)
1386 scalar((ps[-2].val.opval));
1387 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1393 #line 1067 "perly.y"
1394 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1399 #line 1069 "perly.y"
1400 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1405 #line 1071 "perly.y"
1406 { (yyval.opval) = (ps[0].val.opval); }
1411 #line 1073 "perly.y"
1412 { (yyval.opval) = (ps[0].val.opval); }
1417 #line 1075 "perly.y"
1418 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1423 #line 1077 "perly.y"
1424 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1429 #line 1079 "perly.y"
1430 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1435 #line 1081 "perly.y"
1436 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1441 #line 1083 "perly.y"
1442 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1447 #line 1085 "perly.y"
1448 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1453 #line 1087 "perly.y"
1454 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1459 #line 1091 "perly.y"
1460 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1465 #line 1093 "perly.y"
1466 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1471 #line 1095 "perly.y"
1472 { yyerror("syntax error"); YYERROR; }
1477 #line 1097 "perly.y"
1478 { yyerror("syntax error"); YYERROR; }
1483 #line 1101 "perly.y"
1484 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1489 #line 1103 "perly.y"
1490 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1495 #line 1107 "perly.y"
1496 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1501 #line 1109 "perly.y"
1502 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1507 #line 1111 "perly.y"
1508 { yyerror("syntax error"); YYERROR; }
1513 #line 1113 "perly.y"
1514 { yyerror("syntax error"); YYERROR; }
1519 #line 1117 "perly.y"
1520 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1525 #line 1119 "perly.y"
1526 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1531 #line 1124 "perly.y"
1532 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1537 #line 1126 "perly.y"
1538 { (yyval.opval) = (ps[0].val.opval); }
1543 #line 1129 "perly.y"
1544 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1549 #line 1131 "perly.y"
1550 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1555 #line 1133 "perly.y"
1556 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1557 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1562 #line 1136 "perly.y"
1563 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1564 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1569 #line 1139 "perly.y"
1570 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1584 #line 1150 "perly.y"
1585 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1586 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1591 #line 1153 "perly.y"
1592 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1593 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1598 #line 1160 "perly.y"
1599 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1604 #line 1162 "perly.y"
1605 { (yyval.opval) = newANONLIST(NULL);}
1610 #line 1164 "perly.y"
1611 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1616 #line 1166 "perly.y"
1617 { (yyval.opval) = newANONHASH(NULL); }
1622 #line 1168 "perly.y"
1623 { SvREFCNT_inc_simple_void(PL_compcv);
1624 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1629 #line 1171 "perly.y"
1630 { SvREFCNT_inc_simple_void(PL_compcv);
1631 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1636 #line 1177 "perly.y"
1637 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1642 #line 1179 "perly.y"
1643 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1648 #line 1187 "perly.y"
1649 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1654 #line 1189 "perly.y"
1655 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1660 #line 1191 "perly.y"
1661 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1666 #line 1193 "perly.y"
1667 { (yyval.opval) = (ps[0].val.opval); }
1672 #line 1195 "perly.y"
1673 { (yyval.opval) = localize((ps[0].val.opval),0); }
1678 #line 1197 "perly.y"
1679 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1684 #line 1199 "perly.y"
1685 { (yyval.opval) = (ps[0].val.opval); }
1690 #line 1201 "perly.y"
1691 { (yyval.opval) = sawparens(newNULLLIST()); }
1696 #line 1203 "perly.y"
1697 { (yyval.opval) = (ps[0].val.opval); }
1702 #line 1205 "perly.y"
1703 { (yyval.opval) = (ps[0].val.opval); }
1708 #line 1207 "perly.y"
1709 { (yyval.opval) = (ps[0].val.opval); }
1714 #line 1209 "perly.y"
1715 { (yyval.opval) = (ps[0].val.opval); }
1720 #line 1211 "perly.y"
1721 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1726 #line 1213 "perly.y"
1727 { (yyval.opval) = (ps[0].val.opval); }
1732 #line 1215 "perly.y"
1733 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1734 newOP(OP_PUSHMARK, 0),
1735 newLISTOP(OP_ASLICE, 0,
1736 list((ps[-1].val.opval)),
1737 ref((ps[-3].val.opval), OP_ASLICE)));
1738 if ((yyval.opval) && (ps[-3].val.opval))
1739 (yyval.opval)->op_private |=
1740 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1746 #line 1225 "perly.y"
1747 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1748 newOP(OP_PUSHMARK, 0),
1749 newLISTOP(OP_KVASLICE, 0,
1750 list((ps[-1].val.opval)),
1751 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1752 if ((yyval.opval) && (ps[-3].val.opval))
1753 (yyval.opval)->op_private |=
1754 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1760 #line 1235 "perly.y"
1761 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1762 newOP(OP_PUSHMARK, 0),
1763 newLISTOP(OP_HSLICE, 0,
1764 list((ps[-2].val.opval)),
1765 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1766 if ((yyval.opval) && (ps[-4].val.opval))
1767 (yyval.opval)->op_private |=
1768 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1774 #line 1245 "perly.y"
1775 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1776 newOP(OP_PUSHMARK, 0),
1777 newLISTOP(OP_KVHSLICE, 0,
1778 list((ps[-2].val.opval)),
1779 ref((ps[-4].val.opval), OP_KVHSLICE)));
1780 if ((yyval.opval) && (ps[-4].val.opval))
1781 (yyval.opval)->op_private |=
1782 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1788 #line 1255 "perly.y"
1789 { (yyval.opval) = (ps[0].val.opval); }
1794 #line 1257 "perly.y"
1795 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1800 #line 1259 "perly.y"
1801 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1807 #line 1262 "perly.y"
1809 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1810 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1816 #line 1267 "perly.y"
1817 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1818 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1824 #line 1271 "perly.y"
1825 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1830 #line 1273 "perly.y"
1831 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1836 #line 1275 "perly.y"
1837 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1842 #line 1277 "perly.y"
1843 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1844 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1849 #line 1280 "perly.y"
1850 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1855 #line 1282 "perly.y"
1856 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1857 PL_hints |= HINT_BLOCK_SCOPE; }
1862 #line 1285 "perly.y"
1863 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1868 #line 1287 "perly.y"
1869 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1874 #line 1289 "perly.y"
1875 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1880 #line 1291 "perly.y"
1881 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1886 #line 1293 "perly.y"
1887 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1892 #line 1295 "perly.y"
1893 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1898 #line 1297 "perly.y"
1899 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1904 #line 1299 "perly.y"
1905 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1910 #line 1301 "perly.y"
1911 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1912 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1917 #line 1304 "perly.y"
1918 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1923 #line 1306 "perly.y"
1924 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1929 #line 1308 "perly.y"
1930 { (yyval.opval) = (ps[0].val.opval); }
1935 #line 1310 "perly.y"
1936 { (yyval.opval) = (ps[-2].val.opval); }
1941 #line 1312 "perly.y"
1942 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1947 #line 1314 "perly.y"
1948 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1949 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1950 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1955 #line 1318 "perly.y"
1956 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1961 #line 1320 "perly.y"
1963 if ( (ps[0].val.opval)->op_type != OP_TRANS
1964 && (ps[0].val.opval)->op_type != OP_TRANSR
1965 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1967 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1968 SAVEFREESV(PL_compcv);
1976 #line 1331 "perly.y"
1977 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1982 #line 1339 "perly.y"
1983 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1988 #line 1341 "perly.y"
1989 { (yyval.opval) = localize((ps[0].val.opval),1); }
1994 #line 1343 "perly.y"
1995 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
2000 #line 1348 "perly.y"
2001 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
2006 #line 1350 "perly.y"
2007 { (yyval.opval) = sawparens(newNULLLIST()); }
2012 #line 1353 "perly.y"
2013 { (yyval.opval) = (ps[0].val.opval); }
2018 #line 1355 "perly.y"
2019 { (yyval.opval) = (ps[0].val.opval); }
2024 #line 1357 "perly.y"
2025 { (yyval.opval) = (ps[0].val.opval); }
2030 #line 1362 "perly.y"
2031 { (yyval.opval) = NULL; }
2036 #line 1364 "perly.y"
2037 { (yyval.opval) = (ps[0].val.opval); }
2042 #line 1368 "perly.y"
2043 { (yyval.opval) = NULL; }
2048 #line 1370 "perly.y"
2049 { (yyval.opval) = (ps[0].val.opval); }
2054 #line 1374 "perly.y"
2055 { (yyval.opval) = NULL; }
2060 #line 1376 "perly.y"
2061 { (yyval.opval) = (ps[0].val.opval); }
2066 #line 1382 "perly.y"
2067 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
2072 #line 1387 "perly.y"
2073 { (yyval.opval) = (ps[-1].val.opval); }
2078 #line 1389 "perly.y"
2080 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), (ps[0].val.opval));
2086 #line 1396 "perly.y"
2087 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
2092 #line 1413 "perly.y"
2093 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
2098 #line 1417 "perly.y"
2099 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
2104 #line 1421 "perly.y"
2105 { (yyval.opval) = newAVREF((ps[0].val.opval));
2106 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2112 #line 1427 "perly.y"
2113 { (yyval.opval) = newHVREF((ps[0].val.opval));
2114 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2120 #line 1433 "perly.y"
2121 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
2126 #line 1435 "perly.y"
2127 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
2132 #line 1439 "perly.y"
2133 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
2138 #line 1444 "perly.y"
2139 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2144 #line 1449 "perly.y"
2145 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2150 #line 1454 "perly.y"
2151 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2156 #line 1459 "perly.y"
2157 { (yyval.opval) = scalar((ps[0].val.opval)); }
2162 #line 1461 "perly.y"
2163 { (yyval.opval) = scalar((ps[0].val.opval)); }
2168 #line 1463 "perly.y"
2169 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2174 #line 1466 "perly.y"
2175 { (yyval.opval) = (ps[0].val.opval); }
2186 * 15f94e78bed944fe5a2da8ead4096a620ad573562953c479348c65e9eaa51629 perly.y
2187 * acf1cbfd2545faeaaa58b1cf0cf9d7f98b5be0752eb7a54528ef904a9e2e1ca7 regen_perly.pl