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