This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
[MERGE] fixup add+use si_cxsubix field
[perl5.git] / perly.act
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!
5  */
6
7 case 2:
8 #line 120 "perly.y"
9     {
10                           parser->expect = XSTATE;
11                           (yyval.ival) = 0;
12                         }
13
14     break;
15
16   case 3:
17 #line 125 "perly.y"
18     {
19                           newPROG(block_end((ps[-1].val.ival),(ps[0].val.opval)));
20                           PL_compiling.cop_seq = 0;
21                           (yyval.ival) = 0;
22                         }
23
24     break;
25
26   case 4:
27 #line 131 "perly.y"
28     {
29                           parser->expect = XTERM;
30                           (yyval.ival) = 0;
31                         }
32
33     break;
34
35   case 5:
36 #line 136 "perly.y"
37     {
38                           PL_eval_root = (ps[0].val.opval);
39                           (yyval.ival) = 0;
40                         }
41
42     break;
43
44   case 6:
45 #line 141 "perly.y"
46     {
47                           parser->expect = XBLOCK;
48                           (yyval.ival) = 0;
49                         }
50
51     break;
52
53   case 7:
54 #line 146 "perly.y"
55     {
56                           PL_pad_reset_pending = TRUE;
57                           PL_eval_root = (ps[0].val.opval);
58                           (yyval.ival) = 0;
59                           yyunlex();
60                           parser->yychar = yytoken = YYEOF;
61                         }
62
63     break;
64
65   case 8:
66 #line 154 "perly.y"
67     {
68                           parser->expect = XSTATE;
69                           (yyval.ival) = 0;
70                         }
71
72     break;
73
74   case 9:
75 #line 159 "perly.y"
76     {
77                           PL_pad_reset_pending = TRUE;
78                           PL_eval_root = (ps[0].val.opval);
79                           (yyval.ival) = 0;
80                           yyunlex();
81                           parser->yychar = yytoken = YYEOF;
82                         }
83
84     break;
85
86   case 10:
87 #line 167 "perly.y"
88     {
89                           parser->expect = XSTATE;
90                           (yyval.ival) = 0;
91                         }
92
93     break;
94
95   case 11:
96 #line 172 "perly.y"
97     {
98                           PL_pad_reset_pending = TRUE;
99                           PL_eval_root = (ps[0].val.opval);
100                           (yyval.ival) = 0;
101                           yyunlex();
102                           parser->yychar = yytoken = YYEOF;
103                         }
104
105     break;
106
107   case 12:
108 #line 180 "perly.y"
109     {
110                           parser->expect = XSTATE;
111                           (yyval.ival) = 0;
112                         }
113
114     break;
115
116   case 13:
117 #line 185 "perly.y"
118     {
119                           PL_eval_root = (ps[0].val.opval);
120                           (yyval.ival) = 0;
121                         }
122
123     break;
124
125   case 14:
126 #line 190 "perly.y"
127     {
128                           parser->expect = XSTATE;
129                           (yyval.ival) = 0;
130                         }
131
132     break;
133
134   case 15:
135 #line 195 "perly.y"
136     {
137                           PL_eval_root = (ps[0].val.opval);
138                           (yyval.ival) = 0;
139                         }
140
141     break;
142
143   case 16:
144 #line 203 "perly.y"
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));
148                         }
149
150     break;
151
152   case 17:
153 #line 211 "perly.y"
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));
157                         }
158
159     break;
160
161   case 18:
162 #line 218 "perly.y"
163     { (yyval.ival) = block_start(TRUE);
164                           parser->parsed_sub = 0; }
165
166     break;
167
168   case 19:
169 #line 223 "perly.y"
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));
173                         }
174
175     break;
176
177   case 20:
178 #line 230 "perly.y"
179     { (yyval.ival) = block_start(FALSE);
180                           parser->parsed_sub = 0; }
181
182     break;
183
184   case 21:
185 #line 236 "perly.y"
186     { (yyval.opval) = NULL; }
187
188     break;
189
190   case 22:
191 #line 238 "perly.y"
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;
196                         }
197
198     break;
199
200   case 23:
201 #line 247 "perly.y"
202     { (yyval.opval) = NULL; }
203
204     break;
205
206   case 24:
207 #line 249 "perly.y"
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;
212                         }
213
214     break;
215
216   case 25:
217 #line 258 "perly.y"
218     {
219                           (yyval.opval) = (ps[0].val.opval) ? newSTATEOP(0, NULL, (ps[0].val.opval)) : NULL;
220                         }
221
222     break;
223
224   case 26:
225 #line 262 "perly.y"
226     { (yyval.opval) = (ps[0].val.opval); }
227
228     break;
229
230   case 27:
231 #line 266 "perly.y"
232     {
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));
237                         }
238
239     break;
240
241   case 28:
242 #line 273 "perly.y"
243     {
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));
248                         }
249
250     break;
251
252   case 29:
253 #line 283 "perly.y"
254     { (yyval.opval) = (ps[0].val.opval); }
255
256     break;
257
258   case 30:
259 #line 285 "perly.y"
260     {
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);
266                           }
267                           parser->parsed_sub = 1;
268                         }
269
270     break;
271
272   case 31:
273 #line 297 "perly.y"
274     {
275                           init_named_cv(PL_compcv, (ps[-1].val.opval));
276                           parser->in_my = 0;
277                           parser->in_my_stash = NULL;
278                         }
279
280     break;
281
282   case 32:
283 #line 303 "perly.y"
284     {
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))
289                           ;
290                           (yyval.opval) = NULL;
291                           intro_my();
292                           parser->parsed_sub = 1;
293                         }
294
295     break;
296
297   case 33:
298 #line 318 "perly.y"
299     {
300                           init_named_cv(PL_compcv, (ps[-1].val.opval));
301                           parser->in_my = 0;
302                           parser->in_my_stash = NULL;
303                         }
304
305     break;
306
307   case 34:
308 #line 324 "perly.y"
309     {
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))
314                           ;
315                           (yyval.opval) = NULL;
316                           intro_my();
317                           parser->parsed_sub = 1;
318                         }
319
320     break;
321
322   case 35:
323 #line 335 "perly.y"
324     {
325                           package((ps[-1].val.opval));
326                           if ((ps[-2].val.opval))
327                               package_version((ps[-2].val.opval));
328                           (yyval.opval) = NULL;
329                         }
330
331     break;
332
333   case 36:
334 #line 342 "perly.y"
335     { CvSPECIAL_on(PL_compcv); /* It's a BEGIN {} */ }
336
337     break;
338
339   case 37:
340 #line 344 "perly.y"
341     {
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;
346                         }
347
348     break;
349
350   case 38:
351 #line 351 "perly.y"
352     {
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);
356                         }
357
358     break;
359
360   case 39:
361 #line 357 "perly.y"
362     {
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);
366                         }
367
368     break;
369
370   case 40:
371 #line 363 "perly.y"
372     {
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);
375                         }
376
377     break;
378
379   case 41:
380 #line 368 "perly.y"
381     { (yyval.opval) = block_end((ps[-3].val.ival), newWHENOP((ps[-2].val.opval), op_scope((ps[0].val.opval)))); }
382
383     break;
384
385   case 42:
386 #line 370 "perly.y"
387     { (yyval.opval) = newWHENOP(0, op_scope((ps[0].val.opval))); }
388
389     break;
390
391   case 43:
392 #line 372 "perly.y"
393     {
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);
398                         }
399
400     break;
401
402   case 44:
403 #line 379 "perly.y"
404     {
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);
409                         }
410
411     break;
412
413   case 45:
414 #line 386 "perly.y"
415     { parser->expect = XTERM; }
416
417     break;
418
419   case 46:
420 #line 388 "perly.y"
421     { parser->expect = XTERM; }
422
423     break;
424
425   case 47:
426 #line 391 "perly.y"
427     {
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));
431                           if (initop) {
432                               forop = op_prepend_elem(OP_LINESEQ, initop,
433                                   op_append_elem(OP_LINESEQ,
434                                       newOP(OP_UNSTACK, OPf_SPECIAL),
435                                       forop));
436                           }
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);
440                         }
441
442     break;
443
444   case 48:
445 #line 406 "perly.y"
446     {
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);
449                         }
450
451     break;
452
453   case 49:
454 #line 411 "perly.y"
455     {
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);
459                         }
460
461     break;
462
463   case 50:
464 #line 417 "perly.y"
465     { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
466
467     break;
468
469   case 51:
470 #line 419 "perly.y"
471     {
472                           (yyval.opval) = block_end(
473                                 (ps[-7].val.ival),
474                                 newFOROP(0,
475                                          op_lvalue(
476                                             newUNOP(OP_REFGEN, 0,
477                                                     (ps[-5].val.opval)),
478                                             OP_ENTERLOOP),
479                                          (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval))
480                           );
481                           parser->copline = (line_t)(ps[-9].val.ival);
482                         }
483
484     break;
485
486   case 52:
487 #line 432 "perly.y"
488     {
489                           (yyval.opval) = block_end((ps[-4].val.ival), newFOROP(
490                                 0, op_lvalue(newUNOP(OP_REFGEN, 0,
491                                                      (ps[-6].val.opval)),
492                                              OP_ENTERLOOP), (ps[-3].val.opval), (ps[-1].val.opval), (ps[0].val.opval)));
493                           parser->copline = (line_t)(ps[-8].val.ival);
494                         }
495
496     break;
497
498   case 53:
499 #line 440 "perly.y"
500     {
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);
504                         }
505
506     break;
507
508   case 54:
509 #line 446 "perly.y"
510     {
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);
514                         }
515
516     break;
517
518   case 55:
519 #line 452 "perly.y"
520     {
521                           package((ps[-2].val.opval));
522                           if ((ps[-3].val.opval)) {
523                               package_version((ps[-3].val.opval));
524                           }
525                         }
526
527     break;
528
529   case 56:
530 #line 459 "perly.y"
531     {
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);
537                         }
538
539     break;
540
541   case 57:
542 #line 467 "perly.y"
543     {
544                           (yyval.opval) = (ps[-1].val.opval);
545                         }
546
547     break;
548
549   case 58:
550 #line 471 "perly.y"
551     {
552                           (yyval.opval) = newLISTOP(OP_DIE, 0, newOP(OP_PUSHMARK, 0),
553                                 newSVOP(OP_CONST, 0, newSVpvs("Unimplemented")));
554                         }
555
556     break;
557
558   case 59:
559 #line 476 "perly.y"
560     {
561                           (yyval.opval) = NULL;
562                           parser->copline = NOLINE;
563                         }
564
565     break;
566
567   case 60:
568 #line 484 "perly.y"
569     { OP *list;
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);
573                           }
574                           else {
575                               list = (ps[-1].val.opval);
576                           }
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));
582                         }
583
584     break;
585
586   case 61:
587 #line 501 "perly.y"
588     { (yyval.opval) = NULL; }
589
590     break;
591
592   case 62:
593 #line 503 "perly.y"
594     { (yyval.opval) = op_unscope((ps[-1].val.opval)); }
595
596     break;
597
598   case 63:
599 #line 508 "perly.y"
600     { (yyval.opval) = NULL; }
601
602     break;
603
604   case 64:
605 #line 510 "perly.y"
606     { (yyval.opval) = (ps[0].val.opval); }
607
608     break;
609
610   case 65:
611 #line 512 "perly.y"
612     { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
613
614     break;
615
616   case 66:
617 #line 514 "perly.y"
618     { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[0].val.opval), (ps[-2].val.opval)); }
619
620     break;
621
622   case 67:
623 #line 516 "perly.y"
624     { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, scalar((ps[0].val.opval)), (ps[-2].val.opval)); }
625
626     break;
627
628   case 68:
629 #line 518 "perly.y"
630     { (yyval.opval) = newLOOPOP(OPf_PARENS, 1, (ps[0].val.opval), (ps[-2].val.opval)); }
631
632     break;
633
634   case 69:
635 #line 520 "perly.y"
636     { (yyval.opval) = newFOROP(0, NULL, (ps[0].val.opval), (ps[-2].val.opval), NULL);
637                           parser->copline = (line_t)(ps[-1].val.ival); }
638
639     break;
640
641   case 70:
642 #line 523 "perly.y"
643     { (yyval.opval) = newWHENOP((ps[0].val.opval), op_scope((ps[-2].val.opval))); }
644
645     break;
646
647   case 71:
648 #line 528 "perly.y"
649     { (yyval.opval) = NULL; }
650
651     break;
652
653   case 72:
654 #line 530 "perly.y"
655     {
656                           ((ps[0].val.opval))->op_flags |= OPf_PARENS;
657                           (yyval.opval) = op_scope((ps[0].val.opval));
658                         }
659
660     break;
661
662   case 73:
663 #line 535 "perly.y"
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;
669                         }
670
671     break;
672
673   case 74:
674 #line 545 "perly.y"
675     { (yyval.opval) = NULL; }
676
677     break;
678
679   case 75:
680 #line 547 "perly.y"
681     { (yyval.opval) = op_scope((ps[0].val.opval)); }
682
683     break;
684
685   case 76:
686 #line 552 "perly.y"
687     { (yyval.ival) = (PL_min_intro_pending &&
688                             PL_max_intro_pending >=  PL_min_intro_pending);
689                           intro_my(); }
690
691     break;
692
693   case 77:
694 #line 558 "perly.y"
695     { (yyval.opval) = NULL; }
696
697     break;
698
699   case 79:
700 #line 564 "perly.y"
701     { YYSTYPE tmplval;
702                           (void)scan_num("1", &tmplval);
703                           (yyval.opval) = tmplval.opval; }
704
705     break;
706
707   case 81:
708 #line 572 "perly.y"
709     { (yyval.opval) = invert(scalar((ps[0].val.opval))); }
710
711     break;
712
713   case 82:
714 #line 577 "perly.y"
715     { (yyval.opval) = (ps[0].val.opval); intro_my(); }
716
717     break;
718
719   case 83:
720 #line 581 "perly.y"
721     { (yyval.opval) = (ps[0].val.opval); intro_my(); }
722
723     break;
724
725   case 84:
726 #line 584 "perly.y"
727     { (yyval.opval) = (ps[0].val.opval); }
728
729     break;
730
731   case 85:
732 #line 585 "perly.y"
733     { (yyval.opval) = NULL; }
734
735     break;
736
737   case 86:
738 #line 589 "perly.y"
739     { (yyval.ival) = start_subparse(FALSE, 0);
740                             SAVEFREESV(PL_compcv); }
741
742     break;
743
744   case 87:
745 #line 595 "perly.y"
746     { (yyval.ival) = start_subparse(FALSE, CVf_ANON);
747                             SAVEFREESV(PL_compcv); }
748
749     break;
750
751   case 88:
752 #line 600 "perly.y"
753     { (yyval.ival) = start_subparse(TRUE, 0);
754                             SAVEFREESV(PL_compcv); }
755
756     break;
757
758   case 91:
759 #line 611 "perly.y"
760     { (yyval.opval) = NULL; }
761
762     break;
763
764   case 93:
765 #line 617 "perly.y"
766     { (yyval.opval) = NULL; }
767
768     break;
769
770   case 94:
771 #line 619 "perly.y"
772     { (yyval.opval) = (ps[0].val.opval); }
773
774     break;
775
776   case 95:
777 #line 621 "perly.y"
778     { (yyval.opval) = NULL; }
779
780     break;
781
782   case 96:
783 #line 626 "perly.y"
784     { (yyval.opval) = (ps[0].val.opval); }
785
786     break;
787
788   case 97:
789 #line 628 "perly.y"
790     { (yyval.opval) = NULL; }
791
792     break;
793
794   case 98:
795 #line 639 "perly.y"
796     { parser->in_my = 0; (yyval.opval) = NULL; }
797
798     break;
799
800   case 99:
801 #line 641 "perly.y"
802     { parser->in_my = 0; (yyval.opval) = (ps[0].val.opval); }
803
804     break;
805
806   case 100:
807 #line 646 "perly.y"
808     { (yyval.ival) = '@'; }
809
810     break;
811
812   case 101:
813 #line 648 "perly.y"
814     { (yyval.ival) = '%'; }
815
816     break;
817
818   case 102:
819 #line 652 "perly.y"
820     {
821                             I32 sigil   = (ps[-2].val.ival);
822                             OP *var     = (ps[-1].val.opval);
823                             OP *defexpr = (ps[0].val.opval);
824
825                             if (parser->sig_slurpy)
826                                 yyerror("Multiple slurpy parameters not allowed");
827                             parser->sig_slurpy = (char)sigil;
828
829                             if (defexpr)
830                                 yyerror("A slurpy parameter may not have "
831                                         "a default value");
832
833                             (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
834                         }
835
836     break;
837
838   case 103:
839 #line 671 "perly.y"
840     { (yyval.opval) = NULL; }
841
842     break;
843
844   case 104:
845 #line 673 "perly.y"
846     { (yyval.opval) = newOP(OP_NULL, 0); }
847
848     break;
849
850   case 105:
851 #line 675 "perly.y"
852     { (yyval.opval) = (ps[0].val.opval); }
853
854     break;
855
856   case 106:
857 #line 681 "perly.y"
858     {
859                             OP *var     = (ps[-1].val.opval);
860                             OP *defexpr = (ps[0].val.opval);
861
862                             if (parser->sig_slurpy)
863                                 yyerror("Slurpy parameter not last");
864
865                             parser->sig_elems++;
866
867                             if (defexpr) {
868                                 parser->sig_optelems++;
869
870                                 if (   defexpr->op_type == OP_NULL
871                                     && !(defexpr->op_flags & OPf_KIDS))
872                                 {
873                                     /* handle '$=' special case */
874                                     if (var)
875                                         yyerror("Optional parameter "
876                                                     "lacks default expression");
877                                     op_free(defexpr);
878                                 }
879                                 else { 
880                                     /* a normal '=default' expression */ 
881                                     OP *defop = (OP*)alloc_LOGOP(OP_ARGDEFELEM,
882                                                         defexpr,
883                                                         LINKLIST(defexpr));
884                                     /* re-purpose op_targ to hold @_ index */
885                                     defop->op_targ =
886                                         (PADOFFSET)(parser->sig_elems - 1);
887
888                                     if (var) {
889                                         var->op_flags |= OPf_STACKED;
890                                         (void)op_sibling_splice(var,
891                                                         NULL, 0, defop);
892                                         scalar(defop);
893                                     }
894                                     else
895                                         var = newUNOP(OP_NULL, 0, defop);
896
897                                     LINKLIST(var);
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
904                                      * it instead.
905                                      */
906                                     var->op_next = defop;
907                                     defexpr->op_next = var;
908                                 }
909                             }
910                             else {
911                                 if (parser->sig_optelems)
912                                     yyerror("Mandatory parameter "
913                                             "follows optional parameter");
914                             }
915
916                             (yyval.opval) = var ? newSTATEOP(0, NULL, var) : NULL;
917                         }
918
919     break;
920
921   case 107:
922 #line 746 "perly.y"
923     { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
924
925     break;
926
927   case 108:
928 #line 748 "perly.y"
929     { parser->in_my = KEY_sigvar; (yyval.opval) = (ps[0].val.opval); }
930
931     break;
932
933   case 109:
934 #line 754 "perly.y"
935     { (yyval.opval) = (ps[-1].val.opval); }
936
937     break;
938
939   case 110:
940 #line 756 "perly.y"
941     {
942                           (yyval.opval) = op_append_list(OP_LINESEQ, (ps[-2].val.opval), (ps[0].val.opval));
943                         }
944
945     break;
946
947   case 111:
948 #line 760 "perly.y"
949     { (yyval.opval) = (ps[0].val.opval); }
950
951     break;
952
953   case 112:
954 #line 765 "perly.y"
955     { (yyval.opval) = NULL; }
956
957     break;
958
959   case 113:
960 #line 767 "perly.y"
961     { (yyval.opval) = (ps[0].val.opval); }
962
963     break;
964
965   case 114:
966 #line 771 "perly.y"
967     { (yyval.opval) = NULL; }
968
969     break;
970
971   case 115:
972 #line 773 "perly.y"
973     { (yyval.opval) = (ps[0].val.opval); }
974
975     break;
976
977   case 116:
978 #line 777 "perly.y"
979     { (yyval.opval) = (ps[-1].val.opval); }
980
981     break;
982
983   case 117:
984 #line 780 "perly.y"
985     {
986                             ENTER;
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;
994                         }
995
996     break;
997
998   case 118:
999 #line 791 "perly.y"
1000     {
1001                             OP            *sigops = (ps[0].val.opval);
1002                             UNOP_AUX_item *aux;
1003                             OP            *check;
1004
1005                             if (!FEATURE_SIGNATURES_IS_ENABLED)
1006                                 Perl_croak(aTHX_ "Experimental "
1007                                     "subroutine signatures not enabled");
1008
1009                             /* We shouldn't get here otherwise */
1010                             Perl_ck_warner_d(aTHX_
1011                                 packWARN(WARN_EXPERIMENTAL__SIGNATURES),
1012                                 "The signatures feature is experimental");
1013
1014                             aux = (UNOP_AUX_item*)PerlMemShared_malloc(
1015                                 sizeof(UNOP_AUX_item) * 3);
1016                             aux[0].iv = parser->sig_elems;
1017                             aux[1].iv = parser->sig_optelems;
1018                             aux[2].iv = parser->sig_slurpy;
1019                             check = newUNOP_AUX(OP_ARGCHECK, 0, NULL, aux);
1020                             sigops = op_prepend_elem(OP_LINESEQ, check, sigops);
1021                             sigops = op_prepend_elem(OP_LINESEQ,
1022                                                 newSTATEOP(0, NULL, NULL),
1023                                                 sigops);
1024                             /* a nextstate at the end handles context
1025                              * correctly for an empty sub body */
1026                             (yyval.opval) = op_append_elem(OP_LINESEQ,
1027                                                 sigops,
1028                                                 newSTATEOP(0, NULL, NULL));
1029
1030                             parser->in_my = 0;
1031                             /* tell the toker that attrributes can follow
1032                              * this sig, but only so that the toker
1033                              * can skip through any (illegal) trailing
1034                              * attribute text then give a useful error
1035                              * message about "attributes before sig",
1036                              * rather than falling over ina mess at
1037                              * unrecognised syntax.
1038                              */
1039                             parser->expect = XATTRBLOCK;
1040                             parser->sig_seen = TRUE;
1041                             LEAVE;
1042                         }
1043
1044     break;
1045
1046   case 119:
1047 #line 837 "perly.y"
1048     { (yyval.opval) = (ps[0].val.opval); }
1049
1050     break;
1051
1052   case 120:
1053 #line 838 "perly.y"
1054     { (yyval.opval) = NULL; }
1055
1056     break;
1057
1058   case 121:
1059 #line 844 "perly.y"
1060     {
1061                           if (parser->copline > (line_t)(ps[-2].val.ival))
1062                               parser->copline = (line_t)(ps[-2].val.ival);
1063                           (yyval.opval) = block_end((ps[-3].val.ival), (ps[-1].val.opval));
1064                         }
1065
1066     break;
1067
1068   case 122:
1069 #line 854 "perly.y"
1070     { (yyval.opval) = (ps[0].val.opval); }
1071
1072     break;
1073
1074   case 123:
1075 #line 855 "perly.y"
1076     { (yyval.opval) = NULL; }
1077
1078     break;
1079
1080   case 124:
1081 #line 859 "perly.y"
1082     {
1083                           if (parser->copline > (line_t)(ps[-2].val.ival))
1084                               parser->copline = (line_t)(ps[-2].val.ival);
1085                           (yyval.opval) = block_end((ps[-4].val.ival),
1086                                 op_append_list(OP_LINESEQ, (ps[-3].val.opval), (ps[-1].val.opval)));
1087                         }
1088
1089     break;
1090
1091   case 125:
1092 #line 870 "perly.y"
1093     { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1094
1095     break;
1096
1097   case 126:
1098 #line 872 "perly.y"
1099     { (yyval.opval) = newLOGOP((ps[-1].val.ival), 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1100
1101     break;
1102
1103   case 127:
1104 #line 874 "perly.y"
1105     { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1106
1107     break;
1108
1109   case 129:
1110 #line 880 "perly.y"
1111     { (yyval.opval) = (ps[-1].val.opval); }
1112
1113     break;
1114
1115   case 130:
1116 #line 882 "perly.y"
1117     {
1118                           OP* term = (ps[0].val.opval);
1119                           (yyval.opval) = op_append_elem(OP_LIST, (ps[-2].val.opval), term);
1120                         }
1121
1122     break;
1123
1124   case 132:
1125 #line 891 "perly.y"
1126     { (yyval.opval) = op_convert_list((ps[-2].val.ival), OPf_STACKED,
1127                                 op_prepend_elem(OP_LIST, newGVREF((ps[-2].val.ival),(ps[-1].val.opval)), (ps[0].val.opval)) );
1128                         }
1129
1130     break;
1131
1132   case 133:
1133 #line 895 "perly.y"
1134     { (yyval.opval) = op_convert_list((ps[-4].val.ival), OPf_STACKED,
1135                                 op_prepend_elem(OP_LIST, newGVREF((ps[-4].val.ival),(ps[-2].val.opval)), (ps[-1].val.opval)) );
1136                         }
1137
1138     break;
1139
1140   case 134:
1141 #line 899 "perly.y"
1142     { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1143                                 op_append_elem(OP_LIST,
1144                                     op_prepend_elem(OP_LIST, scalar((ps[-5].val.opval)), (ps[-1].val.opval)),
1145                                     newMETHOP(OP_METHOD, 0, (ps[-3].val.opval))));
1146                         }
1147
1148     break;
1149
1150   case 135:
1151 #line 905 "perly.y"
1152     { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1153                                 op_append_elem(OP_LIST, scalar((ps[-2].val.opval)),
1154                                     newMETHOP(OP_METHOD, 0, (ps[0].val.opval))));
1155                         }
1156
1157     break;
1158
1159   case 136:
1160 #line 910 "perly.y"
1161     { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1162                                 op_append_elem(OP_LIST,
1163                                     op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)),
1164                                     newMETHOP(OP_METHOD, 0, (ps[-2].val.opval))));
1165                         }
1166
1167     break;
1168
1169   case 137:
1170 #line 916 "perly.y"
1171     { (yyval.opval) = op_convert_list(OP_ENTERSUB, OPf_STACKED,
1172                                 op_append_elem(OP_LIST,
1173                                     op_prepend_elem(OP_LIST, (ps[-3].val.opval), (ps[-1].val.opval)),
1174                                     newMETHOP(OP_METHOD, 0, (ps[-4].val.opval))));
1175                         }
1176
1177     break;
1178
1179   case 138:
1180 #line 922 "perly.y"
1181     { (yyval.opval) = op_convert_list((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1182
1183     break;
1184
1185   case 139:
1186 #line 924 "perly.y"
1187     { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1188
1189     break;
1190
1191   case 140:
1192 #line 926 "perly.y"
1193     { (yyval.opval) = op_convert_list((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1194
1195     break;
1196
1197   case 141:
1198 #line 928 "perly.y"
1199     { SvREFCNT_inc_simple_void(PL_compcv);
1200                           (yyval.opval) = newANONATTRSUB((ps[-1].val.ival), 0, NULL, (ps[0].val.opval)); }
1201
1202     break;
1203
1204   case 142:
1205 #line 931 "perly.y"
1206     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1207                                  op_append_elem(OP_LIST,
1208                                    op_prepend_elem(OP_LIST, (ps[-1].val.opval), (ps[0].val.opval)), (ps[-4].val.opval)));
1209                         }
1210
1211     break;
1212
1213   case 145:
1214 #line 946 "perly.y"
1215     { (yyval.opval) = newBINOP(OP_GELEM, 0, (ps[-4].val.opval), scalar((ps[-2].val.opval))); }
1216
1217     break;
1218
1219   case 146:
1220 #line 948 "perly.y"
1221     { (yyval.opval) = newBINOP(OP_AELEM, 0, oopsAV((ps[-3].val.opval)), scalar((ps[-1].val.opval)));
1222                         }
1223
1224     break;
1225
1226   case 147:
1227 #line 951 "perly.y"
1228     { (yyval.opval) = newBINOP(OP_AELEM, 0,
1229                                         ref(newAVREF((ps[-4].val.opval)),OP_RV2AV),
1230                                         scalar((ps[-1].val.opval)));
1231                         }
1232
1233     break;
1234
1235   case 148:
1236 #line 956 "perly.y"
1237     { (yyval.opval) = newBINOP(OP_AELEM, 0,
1238                                         ref(newAVREF((ps[-3].val.opval)),OP_RV2AV),
1239                                         scalar((ps[-1].val.opval)));
1240                         }
1241
1242     break;
1243
1244   case 149:
1245 #line 961 "perly.y"
1246     { (yyval.opval) = newBINOP(OP_HELEM, 0, oopsHV((ps[-4].val.opval)), jmaybe((ps[-2].val.opval)));
1247                         }
1248
1249     break;
1250
1251   case 150:
1252 #line 964 "perly.y"
1253     { (yyval.opval) = newBINOP(OP_HELEM, 0,
1254                                         ref(newHVREF((ps[-5].val.opval)),OP_RV2HV),
1255                                         jmaybe((ps[-2].val.opval))); }
1256
1257     break;
1258
1259   case 151:
1260 #line 968 "perly.y"
1261     { (yyval.opval) = newBINOP(OP_HELEM, 0,
1262                                         ref(newHVREF((ps[-4].val.opval)),OP_RV2HV),
1263                                         jmaybe((ps[-2].val.opval))); }
1264
1265     break;
1266
1267   case 152:
1268 #line 972 "perly.y"
1269     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1270                                    newCVREF(0, scalar((ps[-3].val.opval))));
1271                           if (parser->expect == XBLOCK)
1272                               parser->expect = XOPERATOR;
1273                         }
1274
1275     break;
1276
1277   case 153:
1278 #line 978 "perly.y"
1279     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1280                                    op_append_elem(OP_LIST, (ps[-1].val.opval),
1281                                        newCVREF(0, scalar((ps[-4].val.opval)))));
1282                           if (parser->expect == XBLOCK)
1283                               parser->expect = XOPERATOR;
1284                         }
1285
1286     break;
1287
1288   case 154:
1289 #line 986 "perly.y"
1290     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1291                                    op_append_elem(OP_LIST, (ps[-1].val.opval),
1292                                                newCVREF(0, scalar((ps[-3].val.opval)))));
1293                           if (parser->expect == XBLOCK)
1294                               parser->expect = XOPERATOR;
1295                         }
1296
1297     break;
1298
1299   case 155:
1300 #line 993 "perly.y"
1301     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1302                                    newCVREF(0, scalar((ps[-2].val.opval))));
1303                           if (parser->expect == XBLOCK)
1304                               parser->expect = XOPERATOR;
1305                         }
1306
1307     break;
1308
1309   case 156:
1310 #line 999 "perly.y"
1311     { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-4].val.opval)); }
1312
1313     break;
1314
1315   case 157:
1316 #line 1001 "perly.y"
1317     { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), (ps[-3].val.opval)); }
1318
1319     break;
1320
1321   case 158:
1322 #line 1003 "perly.y"
1323     { (yyval.opval) = newSLICEOP(0, (ps[-1].val.opval), NULL); }
1324
1325     break;
1326
1327   case 159:
1328 #line 1008 "perly.y"
1329     { (yyval.opval) = newASSIGNOP(OPf_STACKED, (ps[-2].val.opval), (ps[-1].val.ival), (ps[0].val.opval)); }
1330
1331     break;
1332
1333   case 160:
1334 #line 1010 "perly.y"
1335     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1336
1337     break;
1338
1339   case 161:
1340 #line 1012 "perly.y"
1341     {   if ((ps[-1].val.ival) != OP_REPEAT)
1342                                 scalar((ps[-2].val.opval));
1343                             (yyval.opval) = newBINOP((ps[-1].val.ival), 0, (ps[-2].val.opval), scalar((ps[0].val.opval)));
1344                         }
1345
1346     break;
1347
1348   case 162:
1349 #line 1017 "perly.y"
1350     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1351
1352     break;
1353
1354   case 163:
1355 #line 1019 "perly.y"
1356     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1357
1358     break;
1359
1360   case 164:
1361 #line 1021 "perly.y"
1362     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1363
1364     break;
1365
1366   case 165:
1367 #line 1023 "perly.y"
1368     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1369
1370     break;
1371
1372   case 166:
1373 #line 1025 "perly.y"
1374     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1375
1376     break;
1377
1378   case 167:
1379 #line 1027 "perly.y"
1380     { (yyval.opval) = newBINOP((ps[-1].val.ival), 0, scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1381
1382     break;
1383
1384   case 168:
1385 #line 1029 "perly.y"
1386     { (yyval.opval) = newRANGE((ps[-1].val.ival), scalar((ps[-2].val.opval)), scalar((ps[0].val.opval))); }
1387
1388     break;
1389
1390   case 169:
1391 #line 1031 "perly.y"
1392     { (yyval.opval) = newLOGOP(OP_AND, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1393
1394     break;
1395
1396   case 170:
1397 #line 1033 "perly.y"
1398     { (yyval.opval) = newLOGOP(OP_OR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1399
1400     break;
1401
1402   case 171:
1403 #line 1035 "perly.y"
1404     { (yyval.opval) = newLOGOP(OP_DOR, 0, (ps[-2].val.opval), (ps[0].val.opval)); }
1405
1406     break;
1407
1408   case 172:
1409 #line 1037 "perly.y"
1410     { (yyval.opval) = bind_match((ps[-1].val.ival), (ps[-2].val.opval), (ps[0].val.opval)); }
1411
1412     break;
1413
1414   case 173:
1415 #line 1042 "perly.y"
1416     { (yyval.opval) = newUNOP(OP_NEGATE, 0, scalar((ps[0].val.opval))); }
1417
1418     break;
1419
1420   case 174:
1421 #line 1044 "perly.y"
1422     { (yyval.opval) = (ps[0].val.opval); }
1423
1424     break;
1425
1426   case 175:
1427 #line 1047 "perly.y"
1428     { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1429
1430     break;
1431
1432   case 176:
1433 #line 1049 "perly.y"
1434     { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, scalar((ps[0].val.opval))); }
1435
1436     break;
1437
1438   case 177:
1439 #line 1051 "perly.y"
1440     { (yyval.opval) = newUNOP(OP_POSTINC, 0,
1441                                         op_lvalue(scalar((ps[-1].val.opval)), OP_POSTINC)); }
1442
1443     break;
1444
1445   case 178:
1446 #line 1054 "perly.y"
1447     { (yyval.opval) = newUNOP(OP_POSTDEC, 0,
1448                                         op_lvalue(scalar((ps[-1].val.opval)), OP_POSTDEC));}
1449
1450     break;
1451
1452   case 179:
1453 #line 1057 "perly.y"
1454     { (yyval.opval) = op_convert_list(OP_JOIN, 0,
1455                                        op_append_elem(
1456                                         OP_LIST,
1457                                         newSVREF(scalar(
1458                                             newSVOP(OP_CONST,0,
1459                                                     newSVpvs("\""))
1460                                         )),
1461                                         (ps[-1].val.opval)
1462                                        ));
1463                         }
1464
1465     break;
1466
1467   case 180:
1468 #line 1068 "perly.y"
1469     { (yyval.opval) = newUNOP(OP_PREINC, 0,
1470                                         op_lvalue(scalar((ps[0].val.opval)), OP_PREINC)); }
1471
1472     break;
1473
1474   case 181:
1475 #line 1071 "perly.y"
1476     { (yyval.opval) = newUNOP(OP_PREDEC, 0,
1477                                         op_lvalue(scalar((ps[0].val.opval)), OP_PREDEC)); }
1478
1479     break;
1480
1481   case 182:
1482 #line 1078 "perly.y"
1483     { (yyval.opval) = newANONLIST((ps[-1].val.opval)); }
1484
1485     break;
1486
1487   case 183:
1488 #line 1080 "perly.y"
1489     { (yyval.opval) = newANONLIST(NULL);}
1490
1491     break;
1492
1493   case 184:
1494 #line 1082 "perly.y"
1495     { (yyval.opval) = newANONHASH((ps[-2].val.opval)); }
1496
1497     break;
1498
1499   case 185:
1500 #line 1084 "perly.y"
1501     { (yyval.opval) = newANONHASH(NULL); }
1502
1503     break;
1504
1505   case 186:
1506 #line 1086 "perly.y"
1507     { SvREFCNT_inc_simple_void(PL_compcv);
1508                           (yyval.opval) = newANONATTRSUB((ps[-3].val.ival), (ps[-2].val.opval), (ps[-1].val.opval), (ps[0].val.opval)); }
1509
1510     break;
1511
1512   case 187:
1513 #line 1089 "perly.y"
1514     { SvREFCNT_inc_simple_void(PL_compcv);
1515                           (yyval.opval) = newANONATTRSUB((ps[-2].val.ival), NULL, (ps[-1].val.opval), (ps[0].val.opval)); }
1516
1517     break;
1518
1519   case 188:
1520 #line 1095 "perly.y"
1521     { (yyval.opval) = dofile((ps[0].val.opval), (ps[-1].val.ival));}
1522
1523     break;
1524
1525   case 189:
1526 #line 1097 "perly.y"
1527     { (yyval.opval) = newUNOP(OP_NULL, OPf_SPECIAL, op_scope((ps[0].val.opval)));}
1528
1529     break;
1530
1531   case 194:
1532 #line 1105 "perly.y"
1533     { (yyval.opval) = newCONDOP(0, (ps[-4].val.opval), (ps[-2].val.opval), (ps[0].val.opval)); }
1534
1535     break;
1536
1537   case 195:
1538 #line 1107 "perly.y"
1539     { (yyval.opval) = newUNOP(OP_REFGEN, 0, (ps[0].val.opval)); }
1540
1541     break;
1542
1543   case 196:
1544 #line 1109 "perly.y"
1545     { (yyval.opval) = newUNOP(OP_REFGEN, 0, localize((ps[0].val.opval),1)); }
1546
1547     break;
1548
1549   case 197:
1550 #line 1111 "perly.y"
1551     { (yyval.opval) = (ps[0].val.opval); }
1552
1553     break;
1554
1555   case 198:
1556 #line 1113 "perly.y"
1557     { (yyval.opval) = localize((ps[0].val.opval),0); }
1558
1559     break;
1560
1561   case 199:
1562 #line 1115 "perly.y"
1563     { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1564
1565     break;
1566
1567   case 200:
1568 #line 1117 "perly.y"
1569     { (yyval.opval) = (ps[0].val.opval); }
1570
1571     break;
1572
1573   case 201:
1574 #line 1119 "perly.y"
1575     { (yyval.opval) = sawparens(newNULLLIST()); }
1576
1577     break;
1578
1579   case 202:
1580 #line 1121 "perly.y"
1581     { (yyval.opval) = (ps[0].val.opval); }
1582
1583     break;
1584
1585   case 203:
1586 #line 1123 "perly.y"
1587     { (yyval.opval) = (ps[0].val.opval); }
1588
1589     break;
1590
1591   case 204:
1592 #line 1125 "perly.y"
1593     { (yyval.opval) = (ps[0].val.opval); }
1594
1595     break;
1596
1597   case 205:
1598 #line 1127 "perly.y"
1599     { (yyval.opval) = (ps[0].val.opval); }
1600
1601     break;
1602
1603   case 206:
1604 #line 1129 "perly.y"
1605     { (yyval.opval) = newUNOP(OP_AV2ARYLEN, 0, ref((ps[0].val.opval), OP_AV2ARYLEN));}
1606
1607     break;
1608
1609   case 207:
1610 #line 1131 "perly.y"
1611     { (yyval.opval) = (ps[0].val.opval); }
1612
1613     break;
1614
1615   case 208:
1616 #line 1133 "perly.y"
1617     { (yyval.opval) = op_prepend_elem(OP_ASLICE,
1618                                 newOP(OP_PUSHMARK, 0),
1619                                     newLISTOP(OP_ASLICE, 0,
1620                                         list((ps[-1].val.opval)),
1621                                         ref((ps[-3].val.opval), OP_ASLICE)));
1622                           if ((yyval.opval) && (ps[-3].val.opval))
1623                               (yyval.opval)->op_private |=
1624                                   (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1625                         }
1626
1627     break;
1628
1629   case 209:
1630 #line 1143 "perly.y"
1631     { (yyval.opval) = op_prepend_elem(OP_KVASLICE,
1632                                 newOP(OP_PUSHMARK, 0),
1633                                     newLISTOP(OP_KVASLICE, 0,
1634                                         list((ps[-1].val.opval)),
1635                                         ref(oopsAV((ps[-3].val.opval)), OP_KVASLICE)));
1636                           if ((yyval.opval) && (ps[-3].val.opval))
1637                               (yyval.opval)->op_private |=
1638                                   (ps[-3].val.opval)->op_private & OPpSLICEWARNING;
1639                         }
1640
1641     break;
1642
1643   case 210:
1644 #line 1153 "perly.y"
1645     { (yyval.opval) = op_prepend_elem(OP_HSLICE,
1646                                 newOP(OP_PUSHMARK, 0),
1647                                     newLISTOP(OP_HSLICE, 0,
1648                                         list((ps[-2].val.opval)),
1649                                         ref(oopsHV((ps[-4].val.opval)), OP_HSLICE)));
1650                           if ((yyval.opval) && (ps[-4].val.opval))
1651                               (yyval.opval)->op_private |=
1652                                   (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1653                         }
1654
1655     break;
1656
1657   case 211:
1658 #line 1163 "perly.y"
1659     { (yyval.opval) = op_prepend_elem(OP_KVHSLICE,
1660                                 newOP(OP_PUSHMARK, 0),
1661                                     newLISTOP(OP_KVHSLICE, 0,
1662                                         list((ps[-2].val.opval)),
1663                                         ref((ps[-4].val.opval), OP_KVHSLICE)));
1664                           if ((yyval.opval) && (ps[-4].val.opval))
1665                               (yyval.opval)->op_private |=
1666                                   (ps[-4].val.opval)->op_private & OPpSLICEWARNING;
1667                         }
1668
1669     break;
1670
1671   case 212:
1672 #line 1173 "perly.y"
1673     { (yyval.opval) = (ps[0].val.opval); }
1674
1675     break;
1676
1677   case 213:
1678 #line 1175 "perly.y"
1679     { (yyval.opval) = newUNOP(OP_ENTERSUB, 0, scalar((ps[0].val.opval))); }
1680
1681     break;
1682
1683   case 214:
1684 #line 1177 "perly.y"
1685     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[-2].val.opval)));
1686                         }
1687
1688     break;
1689
1690   case 215:
1691 #line 1180 "perly.y"
1692     {
1693                           (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1694                                 op_append_elem(OP_LIST, (ps[-1].val.opval), scalar((ps[-3].val.opval))));
1695                         }
1696
1697     break;
1698
1699   case 216:
1700 #line 1185 "perly.y"
1701     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1702                             op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval))));
1703                         }
1704
1705     break;
1706
1707   case 217:
1708 #line 1189 "perly.y"
1709     { (yyval.opval) = newSVREF((ps[-3].val.opval)); }
1710
1711     break;
1712
1713   case 218:
1714 #line 1191 "perly.y"
1715     { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1716
1717     break;
1718
1719   case 219:
1720 #line 1193 "perly.y"
1721     { (yyval.opval) = newHVREF((ps[-3].val.opval)); }
1722
1723     break;
1724
1725   case 220:
1726 #line 1195 "perly.y"
1727     { (yyval.opval) = newUNOP(OP_ENTERSUB, 0,
1728                                        scalar(newCVREF((ps[-1].val.ival),(ps[-3].val.opval)))); }
1729
1730     break;
1731
1732   case 221:
1733 #line 1198 "perly.y"
1734     { (yyval.opval) = newGVREF(0,(ps[-3].val.opval)); }
1735
1736     break;
1737
1738   case 222:
1739 #line 1200 "perly.y"
1740     { (yyval.opval) = newOP((ps[0].val.ival), OPf_SPECIAL);
1741                             PL_hints |= HINT_BLOCK_SCOPE; }
1742
1743     break;
1744
1745   case 223:
1746 #line 1203 "perly.y"
1747     { (yyval.opval) = newLOOPEX((ps[-1].val.ival),(ps[0].val.opval)); }
1748
1749     break;
1750
1751   case 224:
1752 #line 1205 "perly.y"
1753     { (yyval.opval) = newUNOP(OP_NOT, 0, scalar((ps[0].val.opval))); }
1754
1755     break;
1756
1757   case 225:
1758 #line 1207 "perly.y"
1759     { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1760
1761     break;
1762
1763   case 226:
1764 #line 1209 "perly.y"
1765     { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1766
1767     break;
1768
1769   case 227:
1770 #line 1211 "perly.y"
1771     { (yyval.opval) = newUNOP((ps[-1].val.ival), 0, (ps[0].val.opval)); }
1772
1773     break;
1774
1775   case 228:
1776 #line 1213 "perly.y"
1777     { (yyval.opval) = newOP(OP_REQUIRE, (ps[0].val.ival) ? OPf_SPECIAL : 0); }
1778
1779     break;
1780
1781   case 229:
1782 #line 1215 "perly.y"
1783     { (yyval.opval) = newUNOP(OP_REQUIRE, (ps[-1].val.ival) ? OPf_SPECIAL : 0, (ps[0].val.opval)); }
1784
1785     break;
1786
1787   case 230:
1788 #line 1217 "perly.y"
1789     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1790
1791     break;
1792
1793   case 231:
1794 #line 1219 "perly.y"
1795     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED,
1796                             op_append_elem(OP_LIST, (ps[0].val.opval), scalar((ps[-1].val.opval)))); }
1797
1798     break;
1799
1800   case 232:
1801 #line 1222 "perly.y"
1802     { (yyval.opval) = newOP((ps[0].val.ival), 0); }
1803
1804     break;
1805
1806   case 233:
1807 #line 1224 "perly.y"
1808     { (yyval.opval) = newOP((ps[-2].val.ival), 0);}
1809
1810     break;
1811
1812   case 234:
1813 #line 1226 "perly.y"
1814     { (yyval.opval) = (ps[0].val.opval); }
1815
1816     break;
1817
1818   case 235:
1819 #line 1228 "perly.y"
1820     { (yyval.opval) = (ps[-2].val.opval); }
1821
1822     break;
1823
1824   case 236:
1825 #line 1230 "perly.y"
1826     { (yyval.opval) = newUNOP(OP_ENTERSUB, OPf_STACKED, scalar((ps[0].val.opval))); }
1827
1828     break;
1829
1830   case 237:
1831 #line 1232 "perly.y"
1832     { (yyval.opval) = ((ps[-2].val.ival) == OP_NOT)
1833                           ? newUNOP((ps[-2].val.ival), 0, newSVOP(OP_CONST, 0, newSViv(0)))
1834                           : newOP((ps[-2].val.ival), OPf_SPECIAL); }
1835
1836     break;
1837
1838   case 238:
1839 #line 1236 "perly.y"
1840     { (yyval.opval) = newUNOP((ps[-3].val.ival), 0, (ps[-1].val.opval)); }
1841
1842     break;
1843
1844   case 239:
1845 #line 1238 "perly.y"
1846     {
1847                             if (   (ps[0].val.opval)->op_type != OP_TRANS
1848                                 && (ps[0].val.opval)->op_type != OP_TRANSR
1849                                 && (((PMOP*)(ps[0].val.opval))->op_pmflags & PMf_HAS_CV))
1850                             {
1851                                 (yyval.ival) = start_subparse(FALSE, CVf_ANON);
1852                                 SAVEFREESV(PL_compcv);
1853                             } else
1854                                 (yyval.ival) = 0;
1855                         }
1856
1857     break;
1858
1859   case 240:
1860 #line 1249 "perly.y"
1861     { (yyval.opval) = pmruntime((ps[-5].val.opval), (ps[-2].val.opval), (ps[-1].val.opval), 1, (ps[-4].val.ival)); }
1862
1863     break;
1864
1865   case 244:
1866 #line 1257 "perly.y"
1867     { (yyval.opval) = my_attrs((ps[-1].val.opval),(ps[0].val.opval)); }
1868
1869     break;
1870
1871   case 245:
1872 #line 1259 "perly.y"
1873     { (yyval.opval) = localize((ps[0].val.opval),1); }
1874
1875     break;
1876
1877   case 246:
1878 #line 1261 "perly.y"
1879     { (yyval.opval) = newUNOP(OP_REFGEN, 0, my_attrs((ps[-1].val.opval),(ps[0].val.opval))); }
1880
1881     break;
1882
1883   case 247:
1884 #line 1266 "perly.y"
1885     { (yyval.opval) = sawparens((ps[-1].val.opval)); }
1886
1887     break;
1888
1889   case 248:
1890 #line 1268 "perly.y"
1891     { (yyval.opval) = sawparens(newNULLLIST()); }
1892
1893     break;
1894
1895   case 249:
1896 #line 1271 "perly.y"
1897     { (yyval.opval) = (ps[0].val.opval); }
1898
1899     break;
1900
1901   case 250:
1902 #line 1273 "perly.y"
1903     { (yyval.opval) = (ps[0].val.opval); }
1904
1905     break;
1906
1907   case 251:
1908 #line 1275 "perly.y"
1909     { (yyval.opval) = (ps[0].val.opval); }
1910
1911     break;
1912
1913   case 252:
1914 #line 1280 "perly.y"
1915     { (yyval.opval) = NULL; }
1916
1917     break;
1918
1919   case 253:
1920 #line 1282 "perly.y"
1921     { (yyval.opval) = (ps[0].val.opval); }
1922
1923     break;
1924
1925   case 254:
1926 #line 1286 "perly.y"
1927     { (yyval.opval) = NULL; }
1928
1929     break;
1930
1931   case 255:
1932 #line 1288 "perly.y"
1933     { (yyval.opval) = (ps[0].val.opval); }
1934
1935     break;
1936
1937   case 256:
1938 #line 1292 "perly.y"
1939     { (yyval.opval) = NULL; }
1940
1941     break;
1942
1943   case 257:
1944 #line 1294 "perly.y"
1945     { (yyval.opval) = (ps[0].val.opval); }
1946
1947     break;
1948
1949   case 258:
1950 #line 1300 "perly.y"
1951     { parser->in_my = 0; (yyval.opval) = my((ps[0].val.opval)); }
1952
1953     break;
1954
1955   case 266:
1956 #line 1317 "perly.y"
1957     { (yyval.opval) = newCVREF((ps[-1].val.ival),(ps[0].val.opval)); }
1958
1959     break;
1960
1961   case 267:
1962 #line 1321 "perly.y"
1963     { (yyval.opval) = newSVREF((ps[0].val.opval)); }
1964
1965     break;
1966
1967   case 268:
1968 #line 1325 "perly.y"
1969     { (yyval.opval) = newAVREF((ps[0].val.opval));
1970                           if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1971                         }
1972
1973     break;
1974
1975   case 269:
1976 #line 1331 "perly.y"
1977     { (yyval.opval) = newHVREF((ps[0].val.opval));
1978                           if ((yyval.opval)) (yyval.opval)->op_private |= (ps[-1].val.ival);
1979                         }
1980
1981     break;
1982
1983   case 270:
1984 #line 1337 "perly.y"
1985     { (yyval.opval) = newAVREF((ps[0].val.opval)); }
1986
1987     break;
1988
1989   case 271:
1990 #line 1339 "perly.y"
1991     { (yyval.opval) = newAVREF((ps[-3].val.opval)); }
1992
1993     break;
1994
1995   case 272:
1996 #line 1343 "perly.y"
1997     { (yyval.opval) = newGVREF(0,(ps[0].val.opval)); }
1998
1999     break;
2000
2001   case 274:
2002 #line 1348 "perly.y"
2003     { (yyval.opval) = newAVREF((ps[-2].val.opval)); }
2004
2005     break;
2006
2007   case 276:
2008 #line 1353 "perly.y"
2009     { (yyval.opval) = newHVREF((ps[-2].val.opval)); }
2010
2011     break;
2012
2013   case 278:
2014 #line 1358 "perly.y"
2015     { (yyval.opval) = newGVREF(0,(ps[-2].val.opval)); }
2016
2017     break;
2018
2019   case 279:
2020 #line 1363 "perly.y"
2021     { (yyval.opval) = scalar((ps[0].val.opval)); }
2022
2023     break;
2024
2025   case 280:
2026 #line 1365 "perly.y"
2027     { (yyval.opval) = scalar((ps[0].val.opval)); }
2028
2029     break;
2030
2031   case 281:
2032 #line 1367 "perly.y"
2033     { (yyval.opval) = op_scope((ps[0].val.opval)); }
2034
2035     break;
2036
2037   case 282:
2038 #line 1370 "perly.y"
2039     { (yyval.opval) = (ps[0].val.opval); }
2040
2041     break;
2042
2043
2044
2045
2046       default: break;
2047     
2048
2049 /* Generated from:
2050  * 4d7581de6482210c9b2f3302b589173c8d8c0a88724cc58b659ca9dcd2a35761 perly.y
2051  * 0947213b55d0ed11693554bea04987e886cf285f5c14cf9075fa1e7acc3f4061 regen_perly.pl
2052  * ex: set ro: */