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);
510 { parser->in_my = 1; }
516 { parser->in_my = 0; intro_my(); }
523 (yyval.opval) = newTRYCATCHOP(0,
524 (ps[-8].val.opval), (ps[-3].val.opval), block_end((ps[-4].val.ival), op_scope((ps[0].val.opval))));
532 /* a block is a loop that happens once */
533 (yyval.opval) = newWHILEOP(0, 1, NULL,
534 NULL, (ps[-1].val.opval), (ps[0].val.opval), 0);
542 package((ps[-2].val.opval));
543 if ((ps[-3].val.opval)) {
544 package_version((ps[-3].val.opval));
553 /* a block is a loop that happens once */
554 (yyval.opval) = newWHILEOP(0, 1, NULL,
555 NULL, block_end((ps[-3].val.ival), (ps[-1].val.opval)), NULL, 0);
556 if (parser->copline > (line_t)(ps[-4].val.ival))
557 parser->copline = (line_t)(ps[-4].val.ival);
565 (yyval.opval) = (ps[-1].val.opval);
573 (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
574 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
582 (yyval.opval) = NULL;
583 parser->copline = NOLINE;
591 if ((ps[0].val.opval)) {
592 OP *term = (ps[0].val.opval);
593 list = op_append_elem(OP_LIST, (ps[-1].val.opval), term);
596 list = (ps[-1].val.opval);
598 if (parser->copline == NOLINE)
599 parser->copline = CopLINE(PL_curcop)-1;
600 else parser->copline--;
601 (yyval.opval) = newSTATEOP(0, NULL,
602 op_convert_list(OP_FORMLINE, 0, list));
609 { (yyval.opval) = NULL; }
615 { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
621 { (yyval.opval) = NULL; }
627 { (yyval.opval) = (ps[0].val.opval); }
633 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
639 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
645 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
651 { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
657 { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
658 parser->copline = (line_t)(ps[-1].val.ival); }
664 { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
670 { (yyval.opval) = NULL; }
677 ((ps[0].val.opval))->op_flags |= OPf_PARENS;
678 (yyval.opval) = op_scope((ps[0].val.opval));
685 { parser->copline = (line_t)(ps[-5].val.ival);
686 (yyval.opval) = newCONDOP(0,
687 newSTATEOP(OPf_SPECIAL,NULL,(ps[-3].val.opval)),
688 op_scope((ps[-1].val.opval)), (ps[0].val.opval));
689 PL_hints |= HINT_BLOCK_SCOPE;
696 { (yyval.opval) = NULL; }
702 { (yyval.opval) = op_scope((ps[0].val.opval)); }
708 { (yyval.ival) = (PL_min_intro_pending &&
709 PL_max_intro_pending >= PL_min_intro_pending);
716 { (yyval.opval) = NULL; }
723 (void)scan_num("1", &tmplval);
724 (yyval.opval) = tmplval.opval; }
730 { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
736 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
742 { (yyval.opval) = (ps[0].val.opval); intro_my(); }
748 { (yyval.opval) = (ps[0].val.opval); }
754 { (yyval.opval) = NULL; }
760 { (yyval.ival) = start_subparse(FALSE, 0);
761 SAVEFREESV(PL_compcv); }
767 { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
768 SAVEFREESV(PL_compcv); }
774 { (yyval.ival) = start_subparse(TRUE, 0);
775 SAVEFREESV(PL_compcv); }
781 { (yyval.opval) = NULL; }
787 { (yyval.opval) = NULL; }
793 { (yyval.opval) = (ps[0].val.opval); }
799 { (yyval.opval) = NULL; }
805 { (yyval.opval) = (ps[0].val.opval); }
811 { (yyval.opval) = NULL; }
817 { parser->in_my = 0; (yyval.opval) = NULL; }
823 { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
829 { (yyval.ival) = '@'; }
835 { (yyval.ival) = '%'; }
842 I32 sigil = (ps[-2].val.ival);
843 OP *var = (ps[-1].val.opval);
844 OP *defexpr = (ps[0].val.opval);
846 if (parser->sig_slurpy)
847 yyerror("Multiple slurpy parameters not allowed");
848 parser->sig_slurpy = (char)sigil;
851 yyerror("A slurpy parameter may not have "
854 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
861 { (yyval.opval) = NULL; }
867 { (yyval.opval) = newOP(OP_NULL, 0); }
873 { (yyval.opval) = (ps[0].val.opval); }
880 OP *var = (ps[-1].val.opval);
881 OP *defexpr = (ps[0].val.opval);
883 if (parser->sig_slurpy)
884 yyerror("Slurpy parameter not last");
889 parser->sig_optelems++;
891 if ( defexpr->op_type == OP_NULL
892 && !(defexpr->op_flags & OPf_KIDS))
894 /* handle '$=' special case */
896 yyerror("Optional parameter "
897 "lacks default expression");
901 /* a normal '=default' expression */
902 OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
905 /* re-purpose op_targ to hold @_ index */
907 (PADOFFSET)(parser->sig_elems - 1);
910 var->op_flags |= OPf_STACKED;
911 (void)op_sibling_splice(var,
916 var = newUNOP(OP_NULL, 0, defop);
919 /* NB: normally the first child of a
920 * logop is executed before the logop,
921 * and it pushes a boolean result
922 * ready for the logop. For ARGDEFELEM,
923 * the op itself does the boolean
924 * calculation, so set the first op to
927 var->op_next = defop;
928 defexpr->op_next = var;
932 if (parser->sig_optelems)
933 yyerror("Mandatory parameter "
934 "follows optional parameter");
937 (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
944 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
950 { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
956 { (yyval.opval) = (ps[-1].val.opval); }
963 (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
970 { (yyval.opval) = (ps[0].val.opval); }
976 { (yyval.opval) = NULL; }
982 { (yyval.opval) = (ps[0].val.opval); }
988 { (yyval.opval) = NULL; }
994 { (yyval.opval) = (ps[0].val.opval); }
1000 { (yyval.opval) = (ps[-1].val.opval); }
1008 SAVEIV(parser->sig_elems);
1009 SAVEIV(parser->sig_optelems);
1010 SAVEI8(parser->sig_slurpy);
1011 parser->sig_elems = 0;
1012 parser->sig_optelems = 0;
1013 parser->sig_slurpy = 0;
1014 parser->in_my = KEY_sigvar;
1022 OP *sigops = (ps[0].val.opval);
1023 struct op_argcheck_aux *aux;
1026 if (!FEATURE_SIGNATURES_IS_ENABLED)
1027 Perl_croak(aTHX_ "Experimental "
1028 "subroutine signatures not enabled");
1030 /* We shouldn't get here otherwise */
1031 Perl_ck_warner_d(aTHX_
1032 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
1033 "The signatures feature is experimental");
1035 aux = (struct op_argcheck_aux*)
1036 PerlMemShared_malloc(
1037 sizeof(struct op_argcheck_aux));
1038 aux->params = parser->sig_elems;
1039 aux->opt_params = parser->sig_optelems;
1040 aux->slurpy = parser->sig_slurpy;
1041 check = newUNOP_AUX(OP_ARGCHECK, 0, NULL,
1042 (UNOP_AUX_item *)aux);
1043 sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
1044 sigops = op_prepend_elem(OP_LINESEQ,
1045 newSTATEOP(0, NULL, NULL),
1047 /* a nextstate at the end handles context
1048 * correctly for an empty sub body */
1049 sigops = op_append_elem(OP_LINESEQ,
1051 newSTATEOP(0, NULL, NULL));
1052 /* wrap the list of arg ops in a NULL aux op.
1053 This serves two purposes. First, it makes
1054 the arg list a separate subtree from the
1055 body of the sub, and secondly the null op
1056 may in future be upgraded to an OP_SIGNATURE
1057 when implemented. For now leave it as
1059 (yyval.opval) = newUNOP_AUX(OP_ARGCHECK, 0, sigops, NULL);
1060 op_null((yyval.opval));
1063 /* tell the toker that attrributes can follow
1064 * this sig, but only so that the toker
1065 * can skip through any (illegal) trailing
1066 * attribute text then give a useful error
1067 * message about "attributes before sig",
1068 * rather than falling over ina mess at
1069 * unrecognised syntax.
1071 parser->expect = XATTRBLOCK;
1072 parser->sig_seen = TRUE;
1080 { (yyval.opval) = (ps[0].val.opval); }
1086 { (yyval.opval) = NULL; }
1093 if (parser->copline > (line_t)(ps[-2].val.ival))
1094 parser->copline = (line_t)(ps[-2].val.ival);
1095 (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1102 { (yyval.opval) = (ps[0].val.opval); }
1108 { (yyval.opval) = NULL; }
1115 if (parser->copline > (line_t)(ps[-2].val.ival))
1116 parser->copline = (line_t)(ps[-2].val.ival);
1117 (yyval.opval) = block_end((ps[-4].val.ival),
1118 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1125 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1131 { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1137 { (yyval.opval) = (ps[-1].val.opval); }
1144 OP* term = (ps[0].val.opval);
1145 (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1152 { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1153 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1160 { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1161 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1168 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1169 op_append_elem(OP_LIST,
1170 op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1171 newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1178 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1179 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1180 newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1187 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1188 op_append_elem(OP_LIST,
1189 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1190 newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1197 { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1198 op_append_elem(OP_LIST,
1199 op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1200 newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1207 { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1213 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1219 { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1225 { SvREFCNT_inc_simple_void(PL_compcv);
1226 (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1232 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1233 op_append_elem(OP_LIST,
1234 op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1241 { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1247 { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1254 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1255 ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1256 scalar((ps[-1].val.opval)));
1263 { (yyval.opval) = newBINOP(OP_AELEM, 0,
1264 ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1265 scalar((ps[-1].val.opval)));
1271 #line 1000 "perly.y"
1272 { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1278 #line 1003 "perly.y"
1279 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1280 ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1281 jmaybe((ps[-2].val.opval))); }
1286 #line 1007 "perly.y"
1287 { (yyval.opval) = newBINOP(OP_HELEM, 0,
1288 ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1289 jmaybe((ps[-2].val.opval))); }
1294 #line 1011 "perly.y"
1295 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1296 newCVREF(0, scalar((ps[-3].val.opval))));
1297 if (parser->expect == XBLOCK)
1298 parser->expect = XOPERATOR;
1304 #line 1017 "perly.y"
1305 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1306 op_append_elem(OP_LIST, (ps[-1].val.opval),
1307 newCVREF(0, scalar((ps[-4].val.opval)))));
1308 if (parser->expect == XBLOCK)
1309 parser->expect = XOPERATOR;
1315 #line 1025 "perly.y"
1316 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1317 op_append_elem(OP_LIST, (ps[-1].val.opval),
1318 newCVREF(0, scalar((ps[-3].val.opval)))));
1319 if (parser->expect == XBLOCK)
1320 parser->expect = XOPERATOR;
1326 #line 1032 "perly.y"
1327 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1328 newCVREF(0, scalar((ps[-2].val.opval))));
1329 if (parser->expect == XBLOCK)
1330 parser->expect = XOPERATOR;
1336 #line 1038 "perly.y"
1337 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1342 #line 1040 "perly.y"
1343 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1348 #line 1042 "perly.y"
1349 { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1354 #line 1047 "perly.y"
1355 { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1360 #line 1049 "perly.y"
1361 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1366 #line 1051 "perly.y"
1367 { if ((ps[-1].val.ival) != OP_REPEAT)
1368 scalar((ps[-2].val.opval));
1369 (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1375 #line 1056 "perly.y"
1376 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1381 #line 1058 "perly.y"
1382 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1387 #line 1060 "perly.y"
1388 { (yyval.opval) = (ps[0].val.opval); }
1393 #line 1062 "perly.y"
1394 { (yyval.opval) = (ps[0].val.opval); }
1399 #line 1064 "perly.y"
1400 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1405 #line 1066 "perly.y"
1406 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1411 #line 1068 "perly.y"
1412 { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1417 #line 1070 "perly.y"
1418 { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1423 #line 1072 "perly.y"
1424 { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1429 #line 1074 "perly.y"
1430 { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1435 #line 1076 "perly.y"
1436 { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1441 #line 1080 "perly.y"
1442 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1447 #line 1082 "perly.y"
1448 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1453 #line 1084 "perly.y"
1454 { yyerror("syntax error"); YYERROR; }
1459 #line 1086 "perly.y"
1460 { yyerror("syntax error"); YYERROR; }
1465 #line 1090 "perly.y"
1466 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1471 #line 1092 "perly.y"
1472 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1477 #line 1096 "perly.y"
1478 { (yyval.opval) = cmpchain_finish((ps[0].val.opval)); }
1483 #line 1098 "perly.y"
1484 { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1489 #line 1100 "perly.y"
1490 { yyerror("syntax error"); YYERROR; }
1495 #line 1102 "perly.y"
1496 { yyerror("syntax error"); YYERROR; }
1501 #line 1106 "perly.y"
1502 { (yyval.opval) = cmpchain_start((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1507 #line 1108 "perly.y"
1508 { (yyval.opval) = cmpchain_extend((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1513 #line 1113 "perly.y"
1514 { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1519 #line 1115 "perly.y"
1520 { (yyval.opval) = (ps[0].val.opval); }
1525 #line 1118 "perly.y"
1526 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1531 #line 1120 "perly.y"
1532 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1537 #line 1122 "perly.y"
1538 { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1539 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1544 #line 1125 "perly.y"
1545 { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1546 op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1551 #line 1128 "perly.y"
1552 { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1566 #line 1139 "perly.y"
1567 { (yyval.opval) = newUNOP(OP_PREINC, 0,
1568 op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1573 #line 1142 "perly.y"
1574 { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1575 op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1580 #line 1149 "perly.y"
1581 { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1586 #line 1151 "perly.y"
1587 { (yyval.opval) = newANONLIST(NULL);}
1592 #line 1153 "perly.y"
1593 { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1598 #line 1155 "perly.y"
1599 { (yyval.opval) = newANONHASH(NULL); }
1604 #line 1157 "perly.y"
1605 { SvREFCNT_inc_simple_void(PL_compcv);
1606 (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1611 #line 1160 "perly.y"
1612 { SvREFCNT_inc_simple_void(PL_compcv);
1613 (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1618 #line 1166 "perly.y"
1619 { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1624 #line 1168 "perly.y"
1625 { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1630 #line 1176 "perly.y"
1631 { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1636 #line 1178 "perly.y"
1637 { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1642 #line 1180 "perly.y"
1643 { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1648 #line 1182 "perly.y"
1649 { (yyval.opval) = (ps[0].val.opval); }
1654 #line 1184 "perly.y"
1655 { (yyval.opval) = localize((ps[0].val.opval),0); }
1660 #line 1186 "perly.y"
1661 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1666 #line 1188 "perly.y"
1667 { (yyval.opval) = (ps[0].val.opval); }
1672 #line 1190 "perly.y"
1673 { (yyval.opval) = sawparens(newNULLLIST()); }
1678 #line 1192 "perly.y"
1679 { (yyval.opval) = (ps[0].val.opval); }
1684 #line 1194 "perly.y"
1685 { (yyval.opval) = (ps[0].val.opval); }
1690 #line 1196 "perly.y"
1691 { (yyval.opval) = (ps[0].val.opval); }
1696 #line 1198 "perly.y"
1697 { (yyval.opval) = (ps[0].val.opval); }
1702 #line 1200 "perly.y"
1703 { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1708 #line 1202 "perly.y"
1709 { (yyval.opval) = (ps[0].val.opval); }
1714 #line 1204 "perly.y"
1715 { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1716 newOP(OP_PUSHMARK, 0),
1717 newLISTOP(OP_ASLICE, 0,
1718 list((ps[-1].val.opval)),
1719 ref((ps[-3].val.opval), OP_ASLICE)));
1720 if ((yyval.opval) && (ps[-3].val.opval))
1721 (yyval.opval)->op_private |=
1722 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1728 #line 1214 "perly.y"
1729 { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1730 newOP(OP_PUSHMARK, 0),
1731 newLISTOP(OP_KVASLICE, 0,
1732 list((ps[-1].val.opval)),
1733 ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1734 if ((yyval.opval) && (ps[-3].val.opval))
1735 (yyval.opval)->op_private |=
1736 (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1742 #line 1224 "perly.y"
1743 { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1744 newOP(OP_PUSHMARK, 0),
1745 newLISTOP(OP_HSLICE, 0,
1746 list((ps[-2].val.opval)),
1747 ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1748 if ((yyval.opval) && (ps[-4].val.opval))
1749 (yyval.opval)->op_private |=
1750 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1756 #line 1234 "perly.y"
1757 { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1758 newOP(OP_PUSHMARK, 0),
1759 newLISTOP(OP_KVHSLICE, 0,
1760 list((ps[-2].val.opval)),
1761 ref((ps[-4].val.opval), OP_KVHSLICE)));
1762 if ((yyval.opval) && (ps[-4].val.opval))
1763 (yyval.opval)->op_private |=
1764 (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1770 #line 1244 "perly.y"
1771 { (yyval.opval) = (ps[0].val.opval); }
1776 #line 1246 "perly.y"
1777 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1782 #line 1248 "perly.y"
1783 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1789 #line 1251 "perly.y"
1791 (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1792 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1798 #line 1256 "perly.y"
1799 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1800 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1806 #line 1260 "perly.y"
1807 { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1812 #line 1262 "perly.y"
1813 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1818 #line 1264 "perly.y"
1819 { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1824 #line 1266 "perly.y"
1825 { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1826 scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1831 #line 1269 "perly.y"
1832 { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1837 #line 1271 "perly.y"
1838 { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1839 PL_hints |= HINT_BLOCK_SCOPE; }
1844 #line 1274 "perly.y"
1845 { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1850 #line 1276 "perly.y"
1851 { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1856 #line 1278 "perly.y"
1857 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1862 #line 1280 "perly.y"
1863 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1868 #line 1282 "perly.y"
1869 { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1874 #line 1284 "perly.y"
1875 { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1880 #line 1286 "perly.y"
1881 { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1886 #line 1288 "perly.y"
1887 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1892 #line 1290 "perly.y"
1893 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1894 op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1899 #line 1293 "perly.y"
1900 { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1905 #line 1295 "perly.y"
1906 { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1911 #line 1297 "perly.y"
1912 { (yyval.opval) = (ps[0].val.opval); }
1917 #line 1299 "perly.y"
1918 { (yyval.opval) = (ps[-2].val.opval); }
1923 #line 1301 "perly.y"
1924 { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1929 #line 1303 "perly.y"
1930 { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1931 ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1932 : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1937 #line 1307 "perly.y"
1938 { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1943 #line 1309 "perly.y"
1945 if ( (ps[0].val.opval)->op_type != OP_TRANS
1946 && (ps[0].val.opval)->op_type != OP_TRANSR
1947 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1949 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1950 SAVEFREESV(PL_compcv);
1958 #line 1320 "perly.y"
1959 { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1964 #line 1328 "perly.y"
1965 { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1970 #line 1330 "perly.y"
1971 { (yyval.opval) = localize((ps[0].val.opval),1); }
1976 #line 1332 "perly.y"
1977 { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1982 #line 1337 "perly.y"
1983 { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1988 #line 1339 "perly.y"
1989 { (yyval.opval) = sawparens(newNULLLIST()); }
1994 #line 1342 "perly.y"
1995 { (yyval.opval) = (ps[0].val.opval); }
2000 #line 1344 "perly.y"
2001 { (yyval.opval) = (ps[0].val.opval); }
2006 #line 1346 "perly.y"
2007 { (yyval.opval) = (ps[0].val.opval); }
2012 #line 1351 "perly.y"
2013 { (yyval.opval) = NULL; }
2018 #line 1353 "perly.y"
2019 { (yyval.opval) = (ps[0].val.opval); }
2024 #line 1357 "perly.y"
2025 { (yyval.opval) = NULL; }
2030 #line 1359 "perly.y"
2031 { (yyval.opval) = (ps[0].val.opval); }
2036 #line 1363 "perly.y"
2037 { (yyval.opval) = NULL; }
2042 #line 1365 "perly.y"
2043 { (yyval.opval) = (ps[0].val.opval); }
2048 #line 1371 "perly.y"
2049 { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
2054 #line 1388 "perly.y"
2055 { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
2060 #line 1392 "perly.y"
2061 { (yyval.opval) = newSVREF((ps[0].val.opval)); }
2066 #line 1396 "perly.y"
2067 { (yyval.opval) = newAVREF((ps[0].val.opval));
2068 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2074 #line 1402 "perly.y"
2075 { (yyval.opval) = newHVREF((ps[0].val.opval));
2076 if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
2082 #line 1408 "perly.y"
2083 { (yyval.opval) = newAVREF((ps[0].val.opval)); }
2088 #line 1410 "perly.y"
2089 { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
2094 #line 1414 "perly.y"
2095 { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
2100 #line 1419 "perly.y"
2101 { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2106 #line 1424 "perly.y"
2107 { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2112 #line 1429 "perly.y"
2113 { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2118 #line 1434 "perly.y"
2119 { (yyval.opval) = scalar((ps[0].val.opval)); }
2124 #line 1436 "perly.y"
2125 { (yyval.opval) = scalar((ps[0].val.opval)); }
2130 #line 1438 "perly.y"
2131 { (yyval.opval) = op_scope((ps[0].val.opval)); }
2136 #line 1441 "perly.y"
2137 { (yyval.opval) = (ps[0].val.opval); }
2147 * 427b422b0ce1154d834dc461973a3254729575694f98ab600032f67ccab7b9e5 perly.y
2148 * acf1cbfd2545faeaaa58b1cf0cf9d7f98b5be0752eb7a54528ef904a9e2e1ca7 regen_perly.pl