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);
1002 struct op_argcheck_aux *aux;
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 = (struct op_argcheck_aux*)
1015 PerlMemShared_malloc(
1016 sizeof(struct op_argcheck_aux));
1017 aux->params = parser->sig_elems;
1018 aux->opt_params = parser->sig_optelems;
1019 aux->slurpy = parser->sig_slurpy;
1020 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL,
1021 (UNOP_AUX_item *)aux);
1022 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
1023 sigops = op_prepend_elem(OP_LINESEQ,
1024 newSTATEOP(0, NULL, NULL),
1026 /* a nextstate at the end handles context
1027 * correctly for an empty sub body */
1028 sigops = op_append_elem(OP_LINESEQ,
1030 newSTATEOP(0, NULL, NULL));
1031 /* wrap the list of arg ops in a NULL aux op.
1032 This serves two purposes. First, it makes
1033 the arg list a separate subtree from the
1034 body of the sub, and secondly the null op
1035 may in future be upgraded to an OP_SIGNATURE
1036 when implemented. For now leave it as
1038 (yyval.opval) = newUNOP_AUX(OP_ARGCHECK, 0, sigops, NULL);
1039 op_null((yyval.opval));
1042 /* tell the toker that attrributes can follow
1043 * this sig, but only so that the toker
1044 * can skip through any (illegal) trailing
1045 * attribute text then give a useful error
1046 * message about "attributes before sig",
1047 * rather than falling over ina mess at
1048 * unrecognised syntax.
1050 parser->expect = XATTRBLOCK;
1051 parser->sig_seen = TRUE;
1059 { (yyval.opval) = (ps[0].val.opval); }
1065 { (yyval.opval) = NULL; }
1072 if (parser->copline > (line_t)(ps[-2].val.ival))
1073 parser->copline = (line_t)(ps[-2].val.ival);
1074 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1081 { (yyval.opval) = (ps[0].val.opval); }
1087 { (yyval.opval) = NULL; }
1094 if (parser->copline > (line_t)(ps[-2].val.ival))
1095 parser->copline = (line_t)(ps[-2].val.ival);
1096 (yyval.opval) = block_end((ps[-4].val.ival),
1097 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1104 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1110 { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1116 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1122 { (yyval.opval) = (ps[-1].val.opval); }
1129 OP* term = (ps[0].val.opval);
1130 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1137 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1138 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1145 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1146 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1153 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1154 op_append_elem(OP_LIST,
1155 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1156 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1163 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1164 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1165 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1172 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1173 op_append_elem(OP_LIST,
1174 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1175 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1182 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1183 op_append_elem(OP_LIST,
1184 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1185 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1192 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1198 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1204 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1210 { SvREFCNT_inc_simple_void(PL_compcv);
1211 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1217 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1218 op_append_elem(OP_LIST,
1219 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1226 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1232 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1239 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1240 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1241 scalar((ps[-1].val.opval)));
1248 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1249 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1250 scalar((ps[-1].val.opval)));
1257 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1264 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1265 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1266 jmaybe((ps[-2].val.opval))); }
1272 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1273 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1274 jmaybe((ps[-2].val.opval))); }
1280 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1281 newCVREF(0, scalar((ps[-3].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[-4].val.opval)))));
1293 if (parser->expect == XBLOCK)
1294 parser->expect = XOPERATOR;
1301 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1302 op_append_elem(OP_LIST, (ps[-1].val.opval),
1303 newCVREF(0, scalar((ps[-3].val.opval)))));
1304 if (parser->expect == XBLOCK)
1305 parser->expect = XOPERATOR;
1311 #line 1005 "perly.y"
1312 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1313 newCVREF(0, scalar((ps[-2].val.opval))));
1314 if (parser->expect == XBLOCK)
1315 parser->expect = XOPERATOR;
1321 #line 1011 "perly.y"
1322 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1327 #line 1013 "perly.y"
1328 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1333 #line 1015 "perly.y"
1334 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1339 #line 1020 "perly.y"
1340 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1345 #line 1022 "perly.y"
1346 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1351 #line 1024 "perly.y"
1352 { if ((ps[-1].val.ival) != OP_REPEAT)
1353 scalar((ps[-2].val.opval));
1354 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1360 #line 1029 "perly.y"
1361 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1366 #line 1031 "perly.y"
1367 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1372 #line 1033 "perly.y"
1373 { (yyval.opval) = (ps[0].val.opval); }
1378 #line 1035 "perly.y"
1379 { (yyval.opval) = (ps[0].val.opval); }
1384 #line 1037 "perly.y"
1385 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1390 #line 1039 "perly.y"
1391 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1396 #line 1041 "perly.y"
1397 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1402 #line 1043 "perly.y"
1403 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1408 #line 1045 "perly.y"
1409 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1414 #line 1047 "perly.y"
1415 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1420 #line 1049 "perly.y"
1421 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1426 #line 1053 "perly.y"
1427 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1432 #line 1055 "perly.y"
1433 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1438 #line 1057 "perly.y"
1439 { yyerror("syntax error"); YYERROR; }
1444 #line 1059 "perly.y"
1445 { yyerror("syntax error"); YYERROR; }
1450 #line 1063 "perly.y"
1451 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1456 #line 1065 "perly.y"
1457 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1462 #line 1069 "perly.y"
1463 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1468 #line 1071 "perly.y"
1469 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1474 #line 1073 "perly.y"
1475 { yyerror("syntax error"); YYERROR; }
1480 #line 1075 "perly.y"
1481 { yyerror("syntax error"); YYERROR; }
1486 #line 1079 "perly.y"
1487 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1492 #line 1081 "perly.y"
1493 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1498 #line 1086 "perly.y"
1499 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1504 #line 1088 "perly.y"
1505 { (yyval.opval) = (ps[0].val.opval); }
1510 #line 1091 "perly.y"
1511 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1516 #line 1093 "perly.y"
1517 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1522 #line 1095 "perly.y"
1523 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1524 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1529 #line 1098 "perly.y"
1530 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1531 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1536 #line 1101 "perly.y"
1537 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1551 #line 1112 "perly.y"
1552 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1553 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1558 #line 1115 "perly.y"
1559 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1560 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1565 #line 1122 "perly.y"
1566 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1571 #line 1124 "perly.y"
1572 { (yyval.opval) = newANONLIST(NULL);}
1577 #line 1126 "perly.y"
1578 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1583 #line 1128 "perly.y"
1584 { (yyval.opval) = newANONHASH(NULL); }
1589 #line 1130 "perly.y"
1590 { SvREFCNT_inc_simple_void(PL_compcv);
1591 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1596 #line 1133 "perly.y"
1597 { SvREFCNT_inc_simple_void(PL_compcv);
1598 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1603 #line 1139 "perly.y"
1604 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1609 #line 1141 "perly.y"
1610 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1615 #line 1149 "perly.y"
1616 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1621 #line 1151 "perly.y"
1622 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1627 #line 1153 "perly.y"
1628 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1633 #line 1155 "perly.y"
1634 { (yyval.opval) = (ps[0].val.opval); }
1639 #line 1157 "perly.y"
1640 { (yyval.opval) = localize((ps[0].val.opval),0); }
1645 #line 1159 "perly.y"
1646 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1651 #line 1161 "perly.y"
1652 { (yyval.opval) = (ps[0].val.opval); }
1657 #line 1163 "perly.y"
1658 { (yyval.opval) = sawparens(newNULLLIST()); }
1663 #line 1165 "perly.y"
1664 { (yyval.opval) = (ps[0].val.opval); }
1669 #line 1167 "perly.y"
1670 { (yyval.opval) = (ps[0].val.opval); }
1675 #line 1169 "perly.y"
1676 { (yyval.opval) = (ps[0].val.opval); }
1681 #line 1171 "perly.y"
1682 { (yyval.opval) = (ps[0].val.opval); }
1687 #line 1173 "perly.y"
1688 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1693 #line 1175 "perly.y"
1694 { (yyval.opval) = (ps[0].val.opval); }
1699 #line 1177 "perly.y"
1700 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1701 newOP(OP_PUSHMARK, 0),
1702 newLISTOP(OP_ASLICE, 0,
1703 list((ps[-1].val.opval)),
1704 ref((ps[-3].val.opval), OP_ASLICE)));
1705 if ((yyval.opval) && (ps[-3].val.opval))
1706 (yyval.opval)->op_private |=
1707 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1713 #line 1187 "perly.y"
1714 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1715 newOP(OP_PUSHMARK, 0),
1716 newLISTOP(OP_KVASLICE, 0,
1717 list((ps[-1].val.opval)),
1718 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1719 if ((yyval.opval) && (ps[-3].val.opval))
1720 (yyval.opval)->op_private |=
1721 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1727 #line 1197 "perly.y"
1728 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1729 newOP(OP_PUSHMARK, 0),
1730 newLISTOP(OP_HSLICE, 0,
1731 list((ps[-2].val.opval)),
1732 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1733 if ((yyval.opval) && (ps[-4].val.opval))
1734 (yyval.opval)->op_private |=
1735 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1741 #line 1207 "perly.y"
1742 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1743 newOP(OP_PUSHMARK, 0),
1744 newLISTOP(OP_KVHSLICE, 0,
1745 list((ps[-2].val.opval)),
1746 ref((ps[-4].val.opval), OP_KVHSLICE)));
1747 if ((yyval.opval) && (ps[-4].val.opval))
1748 (yyval.opval)->op_private |=
1749 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1755 #line 1217 "perly.y"
1756 { (yyval.opval) = (ps[0].val.opval); }
1761 #line 1219 "perly.y"
1762 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1767 #line 1221 "perly.y"
1768 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1774 #line 1224 "perly.y"
1776 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1777 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1783 #line 1229 "perly.y"
1784 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1785 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1791 #line 1233 "perly.y"
1792 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1797 #line 1235 "perly.y"
1798 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1803 #line 1237 "perly.y"
1804 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1809 #line 1239 "perly.y"
1810 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1811 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1816 #line 1242 "perly.y"
1817 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1822 #line 1244 "perly.y"
1823 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1824 PL_hints |= HINT_BLOCK_SCOPE; }
1829 #line 1247 "perly.y"
1830 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1835 #line 1249 "perly.y"
1836 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1841 #line 1251 "perly.y"
1842 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1847 #line 1253 "perly.y"
1848 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1853 #line 1255 "perly.y"
1854 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1859 #line 1257 "perly.y"
1860 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1865 #line 1259 "perly.y"
1866 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1871 #line 1261 "perly.y"
1872 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1877 #line 1263 "perly.y"
1878 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1879 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1884 #line 1266 "perly.y"
1885 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1890 #line 1268 "perly.y"
1891 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1896 #line 1270 "perly.y"
1897 { (yyval.opval) = (ps[0].val.opval); }
1902 #line 1272 "perly.y"
1903 { (yyval.opval) = (ps[-2].val.opval); }
1908 #line 1274 "perly.y"
1909 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1914 #line 1276 "perly.y"
1915 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1916 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1917 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1922 #line 1280 "perly.y"
1923 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1928 #line 1282 "perly.y"
1930 if ( (ps[0].val.opval)->op_type != OP_TRANS
1931 && (ps[0].val.opval)->op_type != OP_TRANSR
1932 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1934 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1935 SAVEFREESV(PL_compcv);
1943 #line 1293 "perly.y"
1944 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1949 #line 1301 "perly.y"
1950 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1955 #line 1303 "perly.y"
1956 { (yyval.opval) = localize((ps[0].val.opval),1); }
1961 #line 1305 "perly.y"
1962 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1967 #line 1310 "perly.y"
1968 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1973 #line 1312 "perly.y"
1974 { (yyval.opval) = sawparens(newNULLLIST()); }
1979 #line 1315 "perly.y"
1980 { (yyval.opval) = (ps[0].val.opval); }
1985 #line 1317 "perly.y"
1986 { (yyval.opval) = (ps[0].val.opval); }
1991 #line 1319 "perly.y"
1992 { (yyval.opval) = (ps[0].val.opval); }
1997 #line 1324 "perly.y"
1998 { (yyval.opval) = NULL; }
2003 #line 1326 "perly.y"
2004 { (yyval.opval) = (ps[0].val.opval); }
2009 #line 1330 "perly.y"
2010 { (yyval.opval) = NULL; }
2015 #line 1332 "perly.y"
2016 { (yyval.opval) = (ps[0].val.opval); }
2021 #line 1336 "perly.y"
2022 { (yyval.opval) = NULL; }
2027 #line 1338 "perly.y"
2028 { (yyval.opval) = (ps[0].val.opval); }
2033 #line 1344 "perly.y"
2034 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
2039 #line 1361 "perly.y"
2040 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
2045 #line 1365 "perly.y"
2046 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
2051 #line 1369 "perly.y"
2052 { (yyval.opval) = newAVREF((ps[0].val.opval));
2053 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2059 #line 1375 "perly.y"
2060 { (yyval.opval) = newHVREF((ps[0].val.opval));
2061 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2067 #line 1381 "perly.y"
2068 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
2073 #line 1383 "perly.y"
2074 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
2079 #line 1387 "perly.y"
2080 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
2085 #line 1392 "perly.y"
2086 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2091 #line 1397 "perly.y"
2092 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2097 #line 1402 "perly.y"
2098 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2103 #line 1407 "perly.y"
2104 { (yyval.opval) = scalar((ps[0].val.opval)); }
2109 #line 1409 "perly.y"
2110 { (yyval.opval) = scalar((ps[0].val.opval)); }
2115 #line 1411 "perly.y"
2116 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2121 #line 1414 "perly.y"
2122 { (yyval.opval) = (ps[0].val.opval); }
2132 * f83d884147747f2d8f5a62eebc4ccd07d71b6b34e5ba1a8d7559526ad864dc97 perly.y
2133 * 01ce33b49f9f04b8d3112b7f042cde113a7d29763a846e870f9766072a5bc614 regen_perly.pl