summaryrefslogtreecommitdiff
path: root/perly.c.yacc
diff options
context:
space:
mode:
Diffstat (limited to 'perly.c.yacc')
-rw-r--r--perly.c.yacc1767
1 files changed, 1767 insertions, 0 deletions
diff --git a/perly.c.yacc b/perly.c.yacc
new file mode 100644
index 0000000000..f1f410ac5f
--- /dev/null
+++ b/perly.c.yacc
@@ -0,0 +1,1767 @@
+extern char *malloc(), *realloc();
+
+# line 39 "perly.y"
+#include "EXTERN.h"
+#include "perl.h"
+
+/*SUPPRESS 530*/
+/*SUPPRESS 593*/
+/*SUPPRESS 595*/
+
+
+# line 50 "perly.y"
+typedef union {
+ I32 ival;
+ char *pval;
+ OP *opval;
+ GV *gvval;
+} YYSTYPE;
+# define WORD 257
+# define METHOD 258
+# define THING 259
+# define PMFUNC 260
+# define PRIVATEREF 261
+# define LABEL 262
+# define FORMAT 263
+# define SUB 264
+# define PACKAGE 265
+# define WHILE 266
+# define UNTIL 267
+# define IF 268
+# define UNLESS 269
+# define ELSE 270
+# define ELSIF 271
+# define CONTINUE 272
+# define FOR 273
+# define LOOPEX 274
+# define DOTDOT 275
+# define FUNC0 276
+# define FUNC1 277
+# define FUNC 278
+# define RELOP 279
+# define EQOP 280
+# define MULOP 281
+# define ADDOP 282
+# define DOLSHARP 283
+# define DO 284
+# define LOCAL 285
+# define DELETE 286
+# define HASHBRACK 287
+# define LSTOP 288
+# define OROR 289
+# define ANDAND 290
+# define BITOROP 291
+# define BITANDOP 292
+# define UNIOP 293
+# define SHIFTOP 294
+# define MATCHOP 295
+# define ARROW 296
+# define UMINUS 297
+# define REFGEN 298
+# define POWOP 299
+# define PREINC 300
+# define PREDEC 301
+# define POSTINC 302
+# define POSTDEC 303
+#define yyclearin yychar = -1
+#define yyerrok yyerrflag = 0
+extern int yychar;
+extern int yyerrflag;
+#ifndef YYMAXDEPTH
+#define YYMAXDEPTH 150
+#endif
+YYSTYPE yylval, yyval;
+# define YYERRCODE 256
+
+# line 573 "perly.y"
+ /* PROGRAM */
+int yyexca[] ={
+-1, 1,
+ 0, -1,
+ -2, 0,
+-1, 3,
+ 0, 2,
+ -2, 39,
+-1, 21,
+ 296, 146,
+ -2, 25,
+-1, 40,
+ 41, 98,
+ 266, 98,
+ 267, 98,
+ 268, 98,
+ 269, 98,
+ 275, 98,
+ 279, 98,
+ 280, 98,
+ 281, 98,
+ 282, 98,
+ 44, 98,
+ 61, 98,
+ 63, 98,
+ 58, 98,
+ 289, 98,
+ 290, 98,
+ 291, 98,
+ 292, 98,
+ 294, 98,
+ 295, 98,
+ 296, 98,
+ 299, 98,
+ 302, 98,
+ 303, 98,
+ 59, 98,
+ 93, 98,
+ -2, 145,
+-1, 54,
+ 41, 134,
+ 266, 134,
+ 267, 134,
+ 268, 134,
+ 269, 134,
+ 275, 134,
+ 279, 134,
+ 280, 134,
+ 281, 134,
+ 282, 134,
+ 44, 134,
+ 61, 134,
+ 63, 134,
+ 58, 134,
+ 289, 134,
+ 290, 134,
+ 291, 134,
+ 292, 134,
+ 294, 134,
+ 295, 134,
+ 296, 134,
+ 299, 134,
+ 302, 134,
+ 303, 134,
+ 59, 134,
+ 93, 134,
+ -2, 144,
+-1, 78,
+ 59, 35,
+ -2, 0,
+-1, 114,
+ 302, 0,
+ 303, 0,
+ -2, 89,
+-1, 115,
+ 302, 0,
+ 303, 0,
+ -2, 90,
+-1, 194,
+ 279, 0,
+ -2, 72,
+-1, 195,
+ 280, 0,
+ -2, 73,
+-1, 196,
+ 275, 0,
+ -2, 76,
+-1, 312,
+ 41, 35,
+ -2, 0,
+ };
+# define YYNPROD 154
+# define YYLAST 2319
+int yyact[]={
+
+ 109, 106, 107, 164, 92, 104, 231, 105, 150, 92,
+ 21, 241, 68, 106, 107, 152, 230, 80, 25, 74,
+ 76, 242, 243, 82, 84, 56, 26, 93, 94, 326,
+ 31, 319, 134, 56, 58, 61, 69, 37, 157, 57,
+ 30, 104, 29, 317, 300, 92, 117, 119, 121, 131,
+ 246, 135, 299, 93, 94, 93, 16, 298, 79, 125,
+ 264, 59, 14, 11, 12, 13, 95, 104, 154, 104,
+ 155, 92, 212, 92, 71, 159, 123, 161, 83, 81,
+ 75, 166, 158, 168, 160, 170, 26, 163, 38, 270,
+ 167, 126, 169, 200, 171, 172, 173, 174, 217, 260,
+ 73, 205, 222, 312, 239, 156, 31, 89, 124, 56,
+ 58, 61, 26, 37, 89, 57, 30, 3, 29, 89,
+ 26, 89, 89, 32, 72, 201, 89, 329, 100, 101,
+ 93, 94, 213, 214, 215, 216, 327, 59, 220, 100,
+ 101, 93, 94, 95, 104, 322, 89, 225, 92, 99,
+ 98, 97, 96, 123, 95, 104, 318, 316, 306, 92,
+ 67, 26, 26, 26, 38, 89, 280, 233, 297, 31,
+ 294, 237, 56, 58, 61, 267, 37, 290, 57, 30,
+ 320, 29, 245, 26, 223, 124, 89, 14, 11, 12,
+ 13, 100, 101, 93, 94, 265, 26, 282, 256, 32,
+ 59, 301, 98, 97, 96, 221, 95, 104, 176, 257,
+ 258, 92, 206, 100, 261, 93, 94, 89, 234, 162,
+ 236, 151, 100, 101, 93, 94, 269, 38, 95, 104,
+ 273, 275, 295, 92, 283, 96, 284, 95, 104, 286,
+ 139, 288, 92, 289, 204, 291, 141, 202, 158, 138,
+ 66, 137, 89, 24, 54, 65, 46, 53, 66, 26,
+ 199, 208, 32, 18, 19, 22, 23, 268, 129, 296,
+ 20, 49, 70, 51, 52, 63, 149, 89, 287, 302,
+ 60, 48, 36, 45, 39, 62, 310, 209, 325, 56,
+ 50, 89, 266, 203, 8, 33, 7, 34, 35, 314,
+ 313, 204, 211, 315, 202, 276, 244, 56, 89, 89,
+ 31, 128, 2, 56, 58, 61, 324, 37, 274, 57,
+ 30, 25, 29, 9, 240, 165, 328, 89, 330, 24,
+ 54, 65, 46, 53, 66, 17, 87, 88, 85, 86,
+ 331, 59, 308, 309, 56, 311, 55, 49, 78, 51,
+ 52, 63, 235, 47, 41, 89, 60, 48, 36, 45,
+ 39, 62, 44, 42, 43, 15, 50, 10, 38, 323,
+ 5, 33, 210, 34, 35, 31, 207, 90, 56, 58,
+ 61, 6, 37, 272, 57, 30, 4, 29, 1, 100,
+ 101, 93, 94, 54, 65, 46, 53, 66, 0, 0,
+ 26, 97, 96, 32, 95, 104, 59, 0, 0, 92,
+ 49, 0, 51, 52, 63, 0, 0, 0, 28, 60,
+ 48, 36, 45, 39, 62, 227, 0, 0, 229, 50,
+ 232, 0, 152, 38, 33, 31, 34, 35, 56, 58,
+ 61, 0, 37, 0, 57, 30, 0, 29, 108, 110,
+ 111, 112, 113, 114, 115, 0, 0, 238, 64, 0,
+ 0, 263, 0, 0, 0, 26, 59, 0, 32, 87,
+ 88, 85, 86, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 31, 38, 0, 56, 58, 61, 0, 37,
+ 0, 57, 30, 0, 29, 279, 0, 281, 0, 0,
+ 0, 0, 0, 0, 271, 140, 143, 144, 145, 146,
+ 147, 148, 0, 59, 153, 26, 0, 0, 32, 0,
+ 0, 285, 0, 293, 54, 65, 46, 53, 66, 0,
+ 0, 0, 0, 0, 0, 0, 277, 0, 0, 278,
+ 38, 49, 262, 51, 52, 63, 0, 0, 0, 307,
+ 60, 48, 36, 45, 39, 62, 91, 303, 103, 304,
+ 50, 0, 0, 0, 0, 33, 0, 34, 35, 0,
+ 0, 0, 26, 0, 0, 32, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 54,
+ 65, 46, 53, 66, 0, 0, 0, 0, 0, 0,
+ 228, 0, 0, 0, 0, 0, 49, 0, 51, 52,
+ 63, 0, 0, 0, 0, 60, 48, 36, 45, 39,
+ 62, 0, 0, 0, 0, 50, 0, 0, 0, 0,
+ 33, 31, 34, 35, 56, 58, 61, 40, 37, 259,
+ 57, 30, 0, 29, 0, 0, 0, 0, 0, 54,
+ 65, 46, 53, 66, 0, 0, 0, 0, 77, 0,
+ 0, 0, 59, 0, 0, 0, 49, 0, 51, 52,
+ 63, 0, 0, 0, 0, 60, 48, 36, 45, 39,
+ 62, 0, 0, 127, 0, 50, 133, 0, 0, 38,
+ 33, 0, 34, 35, 142, 142, 142, 142, 142, 142,
+ 0, 0, 0, 142, 0, 0, 54, 65, 46, 53,
+ 66, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 26, 0, 49, 32, 51, 52, 63, 0, 103,
+ 0, 0, 60, 48, 36, 45, 39, 62, 0, 0,
+ 0, 0, 50, 0, 0, 0, 0, 33, 31, 34,
+ 35, 56, 58, 61, 0, 37, 224, 57, 30, 0,
+ 29, 0, 0, 0, 0, 0, 218, 0, 0, 0,
+ 102, 0, 0, 0, 100, 101, 93, 94, 0, 59,
+ 0, 0, 0, 0, 99, 98, 97, 96, 0, 95,
+ 104, 0, 0, 0, 92, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 31, 0, 38, 56, 58, 61,
+ 0, 37, 219, 57, 30, 0, 29, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 59, 0, 0, 26, 0,
+ 0, 32, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 54, 65, 46, 53, 66,
+ 0, 31, 38, 0, 56, 58, 61, 0, 37, 0,
+ 57, 30, 49, 29, 51, 52, 63, 0, 0, 0,
+ 0, 60, 48, 36, 45, 39, 62, 0, 0, 192,
+ 0, 50, 59, 0, 26, 0, 33, 32, 34, 35,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
+ 0, 31, 0, 0, 56, 58, 61, 0, 37, 0,
+ 57, 30, 0, 29, 0, 0, 0, 0, 0, 0,
+ 0, 102, 0, 0, 321, 100, 101, 93, 94, 190,
+ 0, 26, 59, 0, 32, 99, 98, 97, 96, 0,
+ 95, 104, 0, 0, 91, 92, 103, 0, 0, 0,
+ 0, 0, 54, 65, 46, 53, 66, 0, 0, 38,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 49,
+ 0, 51, 52, 63, 0, 0, 0, 0, 60, 48,
+ 36, 45, 39, 62, 0, 0, 0, 255, 50, 0,
+ 91, 26, 103, 33, 32, 34, 35, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 54, 65,
+ 46, 53, 66, 0, 31, 0, 0, 56, 58, 61,
+ 0, 37, 0, 57, 30, 49, 29, 51, 52, 63,
+ 0, 0, 0, 0, 60, 48, 36, 45, 39, 62,
+ 0, 0, 188, 0, 50, 59, 0, 0, 0, 33,
+ 0, 34, 35, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 54, 65, 46, 53, 66,
+ 0, 0, 38, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 49, 0, 51, 52, 63, 91, 0, 103,
+ 0, 60, 48, 36, 45, 39, 62, 0, 0, 0,
+ 0, 50, 0, 0, 26, 0, 33, 32, 34, 35,
+ 0, 0, 31, 0, 0, 56, 58, 61, 0, 37,
+ 0, 57, 30, 0, 29, 54, 65, 46, 53, 66,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 186, 0, 49, 59, 51, 52, 63, 0, 0, 0,
+ 0, 60, 48, 36, 45, 39, 62, 0, 102, 0,
+ 0, 50, 100, 101, 93, 94, 33, 0, 34, 35,
+ 38, 0, 99, 98, 97, 96, 0, 95, 104, 0,
+ 0, 0, 92, 0, 0, 31, 0, 0, 56, 58,
+ 61, 0, 37, 0, 57, 30, 0, 29, 0, 0,
+ 0, 0, 26, 0, 102, 32, 0, 0, 100, 101,
+ 93, 94, 0, 184, 0, 0, 59, 0, 99, 98,
+ 97, 96, 0, 95, 104, 0, 0, 0, 92, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 54, 65,
+ 46, 53, 66, 38, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 49, 0, 51, 52, 63,
+ 0, 0, 0, 0, 60, 48, 36, 45, 39, 62,
+ 0, 0, 0, 0, 50, 26, 0, 0, 32, 33,
+ 0, 34, 35, 31, 0, 0, 56, 58, 61, 0,
+ 37, 0, 57, 30, 0, 29, 0, 0, 0, 0,
+ 0, 102, 0, 0, 0, 100, 101, 93, 94, 0,
+ 0, 182, 0, 0, 59, 99, 98, 97, 96, 0,
+ 95, 104, 0, 0, 0, 92, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 54, 65, 46, 53,
+ 66, 38, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 49, 0, 51, 52, 63, 0, 0,
+ 0, 0, 60, 48, 36, 45, 39, 62, 0, 0,
+ 0, 0, 50, 26, 0, 0, 32, 33, 0, 34,
+ 35, 0, 0, 0, 0, 0, 31, 0, 0, 56,
+ 58, 61, 0, 37, 0, 57, 30, 0, 29, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 54,
+ 65, 46, 53, 66, 180, 0, 0, 59, 0, 0,
+ 0, 0, 0, 0, 0, 0, 49, 0, 51, 52,
+ 63, 0, 0, 0, 0, 60, 48, 36, 45, 39,
+ 62, 0, 0, 0, 38, 50, 0, 0, 0, 0,
+ 33, 0, 34, 35, 31, 0, 0, 56, 58, 61,
+ 0, 37, 0, 57, 30, 0, 29, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 26, 0, 0, 32,
+ 0, 0, 178, 0, 0, 59, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 54, 65, 46,
+ 53, 66, 38, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 49, 0, 51, 52, 63, 0,
+ 0, 0, 0, 60, 48, 36, 45, 39, 62, 0,
+ 0, 0, 0, 50, 26, 0, 0, 32, 33, 0,
+ 34, 35, 0, 0, 0, 0, 0, 31, 0, 0,
+ 56, 58, 61, 0, 37, 0, 57, 30, 0, 29,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 122, 0, 0, 0, 0, 59, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 54, 65, 46, 53, 66, 38, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 49, 0, 51,
+ 52, 63, 0, 0, 0, 0, 60, 48, 36, 45,
+ 39, 62, 0, 0, 0, 0, 50, 26, 0, 0,
+ 32, 33, 31, 34, 35, 56, 58, 61, 0, 37,
+ 0, 57, 30, 0, 29, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 54, 65,
+ 46, 53, 66, 59, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 49, 0, 51, 52, 63,
+ 0, 0, 0, 0, 60, 48, 36, 45, 39, 62,
+ 38, 0, 120, 0, 50, 0, 0, 0, 0, 33,
+ 0, 34, 35, 0, 0, 0, 0, 0, 31, 0,
+ 0, 56, 58, 61, 0, 37, 118, 57, 30, 0,
+ 29, 0, 26, 0, 0, 32, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 59,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 54, 65, 46, 53, 66, 38, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 49, 0,
+ 51, 52, 63, 0, 0, 0, 0, 60, 48, 36,
+ 45, 39, 62, 0, 0, 0, 0, 50, 26, 0,
+ 0, 32, 33, 31, 34, 35, 56, 58, 61, 0,
+ 37, 0, 57, 30, 0, 29, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 59, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 54, 65, 46, 53,
+ 66, 38, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 49, 0, 51, 52, 63, 0, 0,
+ 0, 0, 60, 48, 36, 45, 39, 62, 0, 0,
+ 0, 0, 50, 26, 0, 0, 32, 33, 31, 34,
+ 35, 56, 58, 61, 0, 37, 0, 57, 30, 0,
+ 29, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 59,
+ 0, 0, 54, 65, 46, 53, 66, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 49,
+ 0, 51, 52, 63, 0, 0, 38, 0, 60, 48,
+ 36, 45, 39, 62, 0, 0, 0, 0, 50, 0,
+ 0, 0, 0, 33, 0, 34, 35, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 26, 27,
+ 0, 32, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 116, 54, 65, 46,
+ 53, 66, 0, 0, 0, 0, 0, 0, 130, 0,
+ 136, 0, 0, 0, 49, 0, 51, 52, 63, 0,
+ 0, 0, 0, 60, 48, 36, 45, 39, 62, 0,
+ 0, 0, 0, 50, 0, 0, 0, 0, 33, 0,
+ 34, 35, 0, 0, 0, 0, 0, 0, 0, 175,
+ 0, 177, 179, 181, 183, 185, 187, 189, 191, 193,
+ 194, 195, 196, 197, 198, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 132, 65, 46, 53, 66, 0, 0, 226,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 49,
+ 0, 51, 52, 63, 0, 0, 0, 0, 60, 48,
+ 36, 45, 39, 62, 0, 0, 0, 0, 50, 0,
+ 0, 0, 0, 33, 0, 34, 35, 0, 247, 0,
+ 248, 0, 249, 0, 250, 0, 251, 0, 252, 0,
+ 253, 0, 254, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 175, 0, 0, 0, 175, 0, 0, 175,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 292, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 305 };
+int yypact[]={
+
+ -1000, -1000, -1000, -200, -1000, -1000, -1000, -1000, -1000, -3,
+ -1000, -97, -221, 15, -1000, -1000, -1000, 65, 60, 40,
+ 308, -255, 39, 38, -1000, 70, -1000, 1056, -289, 1820,
+ 1820, 1820, 1820, 1820, 1820, 1820, 1820, 1725, 1649, 1554,
+ -15, -1000, -1000, -32, -1000, 271, -1000, 228, 1915, -225,
+ 1820, 211, 209, 200, -1000, -1000, -11, -11, -11, -11,
+ -11, -11, 1820, 181, -281, -11, -1000, -37, -1000, -37,
+ 46, -1000, -1000, 1820, -37, 1820, -37, 179, 73, -1000,
+ -37, 1820, -37, 1820, -37, 1820, 1820, 1820, 1820, 1820,
+ -1000, 1820, 1451, 1383, 1280, 1182, 1109, 1011, 898, 838,
+ 1820, 1820, 1820, 1820, 1820, 2, -1000, -1000, -301, -1000,
+ -301, -301, -301, -301, -1000, -1000, -228, 260, 10, 168,
+ -1000, 243, -53, 1820, 1820, 1820, 1820, -25, 253, 781,
+ -228, -1000, 165, 62, -1000, -1000, -228, 143, 725, 1820,
+ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 136, -1000,
+ 78, 1820, -272, 1820, -1000, -1000, -1000, 126, 78, -255,
+ 311, -255, 1820, 203, 45, -1000, -1000, 283, -249, 265,
+ -249, 78, 78, 78, 78, 1056, -75, 1056, 1820, -295,
+ 1820, -290, 1820, -226, 1820, -254, 1820, -151, 1820, -57,
+ 1820, 110, 1820, -88, -228, -66, -140, 959, -295, 158,
+ 1820, 1820, 608, 8, -1000, 1820, 459, -1000, -1000, 402,
+ -1000, -65, -1000, 102, 233, 82, 208, 1820, -34, -1000,
+ 260, 342, 277, -1000, -1000, 264, 505, -1000, 136, 125,
+ 1820, 157, -1000, -37, -1000, -37, -1000, 260, -37, 1820,
+ -37, -1000, -37, 137, -37, -1000, -1000, 1056, 1056, 1056,
+ 1056, 1056, 1056, 1056, 1056, 1820, 1820, 77, 173, -1000,
+ 1820, 75, -1000, -68, -1000, -1000, -73, -1000, -81, 142,
+ 1820, -1000, -1000, 260, -1000, 260, -1000, -1000, 1820, 117,
+ -1000, -1000, 1820, -255, -255, -37, -255, 44, -249, -1000,
+ 1820, -249, 676, 116, -1000, -82, 63, -1000, -1000, -1000,
+ -1000, -94, 121, -1000, -1000, 913, -1000, 104, -1000, -1000,
+ -255, -1000, 73, -1000, 247, -1000, -1000, -1000, -1000, -1000,
+ -96, -1000, -1000, -1000, 95, -37, 86, -37, -249, -1000,
+ -1000, -1000 };
+int yypgo[]={
+
+ 0, 388, 386, 381, 377, 293, 376, 372, 0, 117,
+ 370, 367, 365, 3, 11, 8, 2039, 418, 647, 364,
+ 363, 362, 354, 353, 325, 276, 458, 38, 346, 323,
+ 58, 312, 296, 294 };
+int yyr1[]={
+
+ 0, 31, 1, 8, 4, 9, 9, 9, 10, 10,
+ 10, 10, 24, 24, 24, 24, 24, 24, 14, 14,
+ 14, 12, 12, 12, 12, 30, 30, 11, 11, 11,
+ 11, 11, 11, 11, 11, 13, 13, 27, 27, 29,
+ 29, 2, 2, 2, 3, 3, 32, 33, 33, 15,
+ 15, 28, 28, 28, 28, 28, 28, 28, 28, 16,
+ 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
+ 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
+ 16, 16, 17, 17, 17, 17, 17, 17, 17, 17,
+ 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
+ 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
+ 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
+ 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
+ 17, 17, 17, 17, 17, 17, 25, 25, 23, 18,
+ 19, 20, 21, 22, 26, 26, 26, 26, 5, 5,
+ 6, 6, 7, 7 };
+int yyr2[]={
+
+ 0, 1, 5, 9, 1, 1, 5, 5, 5, 2,
+ 5, 7, 3, 3, 7, 7, 7, 7, 1, 5,
+ 13, 13, 13, 9, 9, 1, 5, 15, 15, 11,
+ 11, 17, 15, 21, 7, 1, 2, 1, 2, 1,
+ 2, 3, 3, 3, 7, 5, 7, 7, 5, 7,
+ 2, 7, 11, 9, 13, 13, 7, 5, 9, 7,
+ 9, 9, 9, 9, 9, 9, 9, 9, 7, 7,
+ 7, 7, 7, 7, 7, 7, 7, 7, 7, 11,
+ 7, 3, 5, 5, 5, 5, 5, 5, 5, 5,
+ 5, 5, 7, 5, 7, 5, 7, 7, 3, 3,
+ 9, 11, 3, 3, 3, 11, 13, 13, 11, 9,
+ 11, 13, 17, 3, 3, 7, 9, 5, 5, 9,
+ 11, 9, 11, 3, 5, 3, 5, 5, 3, 7,
+ 7, 9, 9, 13, 2, 2, 1, 3, 5, 5,
+ 5, 5, 5, 5, 3, 3, 3, 3, 5, 3,
+ 5, 3, 7, 5 };
+int yychk[]={
+
+ -1000, -1, -31, -9, -2, -10, -3, -32, -33, -29,
+ -11, 263, 264, 265, 262, -12, 59, -24, 266, 267,
+ 273, -8, 268, 269, 256, -15, 123, -16, -17, 45,
+ 43, 33, 126, 298, 300, 301, 285, 40, 91, 287,
+ -18, -22, -20, -19, -21, 286, 259, -23, 284, 274,
+ 293, 276, 277, 260, 257, -28, 36, 42, 37, 64,
+ 283, 38, 288, 278, -26, 258, 261, 257, -8, 257,
+ 257, 59, 59, 40, -8, 40, -8, -18, 40, -30,
+ 272, 40, -8, 40, -8, 268, 269, 266, 267, 44,
+ -4, 61, 299, 281, 282, 294, 292, 291, 290, 289,
+ 279, 280, 275, 63, 295, 296, 302, 303, -17, -8,
+ -17, -17, -17, -17, -17, -17, -16, -15, 41, -15,
+ 93, -15, 59, 91, 123, 91, 123, -18, 40, 40,
+ -16, -8, 257, -18, 257, -8, -16, 40, 40, 40,
+ -26, 257, -18, -26, -26, -26, -26, -26, -26, -25,
+ -15, 40, 296, -26, -8, -8, 59, -27, -15, -8,
+ -15, -8, 40, -15, -13, -24, -8, -15, -8, -15,
+ -8, -15, -15, -15, -15, -16, -9, -16, 61, -16,
+ 61, -16, 61, -16, 61, -16, 61, -16, 61, -16,
+ 61, -16, 61, -16, -16, -16, -16, -16, -16, 258,
+ 91, 123, 44, -5, 41, 91, 44, -6, 93, 44,
+ -7, 59, 125, -15, -15, -15, -15, 123, -18, 41,
+ -15, 40, 40, 41, 41, -15, -16, -25, -26, -25,
+ 288, 278, -25, 41, -30, 41, -30, -15, -5, 59,
+ 41, -14, 270, 271, 41, -14, 125, -16, -16, -16,
+ -16, -16, -16, -16, -16, 58, 40, -15, -15, 41,
+ 91, -15, 93, 59, 125, 93, 59, 93, 59, -15,
+ 123, -5, 41, -15, 41, -15, 41, 41, 44, -25,
+ 41, -25, 40, -8, -8, -5, -8, -27, -8, -8,
+ 40, -8, -16, -25, 93, 59, -15, 93, 125, 125,
+ 125, 59, -15, -5, -5, -16, 41, -25, -30, -30,
+ -8, -30, 59, -14, -15, -14, 41, 125, 93, 125,
+ 59, 41, 41, -30, -13, 41, 125, 41, -8, 41,
+ -8, -14 };
+int yydef[]={
+
+ 1, -2, 5, -2, 6, 7, 41, 42, 43, 0,
+ 9, 0, 0, 0, 40, 8, 10, 0, 0, 0,
+ 0, -2, 0, 0, 12, 13, 4, 50, 81, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ -2, 99, 102, 103, 104, 0, 113, 114, 0, 123,
+ 125, 128, 0, 0, -2, 135, 0, 0, 0, 0,
+ 0, 0, 136, 0, 0, 0, 147, 0, 45, 0,
+ 0, 48, 11, 37, 0, 0, 0, 0, -2, 34,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 5, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 87, 88, 82, 146,
+ 83, 84, 85, 86, -2, -2, 91, 0, 93, 0,
+ 95, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 117, 118, 134, 98, 124, 126, 127, 0, 0, 0,
+ 139, 144, 145, 143, 141, 140, 142, 138, 136, 57,
+ 137, 136, 0, 136, 44, 46, 47, 0, 38, 25,
+ 0, 25, 0, 13, 0, 36, 26, 0, 18, 0,
+ 18, 14, 15, 16, 17, 49, 39, 59, 0, 68,
+ 0, 69, 0, 70, 0, 71, 0, 74, 0, 75,
+ 0, 77, 0, 78, -2, -2, -2, 0, 80, 0,
+ 0, 0, 0, 92, 149, 0, 0, 94, 151, 0,
+ 96, 0, 97, 0, 0, 0, 0, 0, 0, 115,
+ 0, 0, 0, 129, 130, 0, 0, 51, 136, 0,
+ 136, 0, 56, 0, 29, 0, 30, 0, 0, 37,
+ 0, 23, 0, 0, 0, 24, 3, 60, 61, 62,
+ 63, 64, 65, 66, 67, 0, 136, 0, 0, 148,
+ 0, 0, 150, 0, 153, 100, 0, 109, 0, 0,
+ 0, 116, 119, 0, 121, 0, 131, 132, 0, 0,
+ 58, 53, 136, 25, 25, 0, 25, 0, 18, 19,
+ 0, 18, 79, 0, 101, 0, 0, 108, 152, 105,
+ 110, 0, 0, 120, 122, 0, 52, 0, 27, 28,
+ 25, 32, -2, 21, 0, 22, 55, 106, 107, 111,
+ 0, 133, 54, 31, 0, 0, 0, 0, 18, 112,
+ 33, 20 };
+typedef struct { char *t_name; int t_val; } yytoktype;
+#ifndef YYDEBUG
+# define YYDEBUG 0 /* don't allow debugging */
+#endif
+
+#if YYDEBUG
+
+yytoktype yytoks[] =
+{
+ "{", 123,
+ ")", 41,
+ "WORD", 257,
+ "METHOD", 258,
+ "THING", 259,
+ "PMFUNC", 260,
+ "PRIVATEREF", 261,
+ "LABEL", 262,
+ "FORMAT", 263,
+ "SUB", 264,
+ "PACKAGE", 265,
+ "WHILE", 266,
+ "UNTIL", 267,
+ "IF", 268,
+ "UNLESS", 269,
+ "ELSE", 270,
+ "ELSIF", 271,
+ "CONTINUE", 272,
+ "FOR", 273,
+ "LOOPEX", 274,
+ "DOTDOT", 275,
+ "FUNC0", 276,
+ "FUNC1", 277,
+ "FUNC", 278,
+ "RELOP", 279,
+ "EQOP", 280,
+ "MULOP", 281,
+ "ADDOP", 282,
+ "DOLSHARP", 283,
+ "DO", 284,
+ "LOCAL", 285,
+ "DELETE", 286,
+ "HASHBRACK", 287,
+ "LSTOP", 288,
+ ",", 44,
+ "=", 61,
+ "?", 63,
+ ":", 58,
+ "OROR", 289,
+ "ANDAND", 290,
+ "BITOROP", 291,
+ "BITANDOP", 292,
+ "UNIOP", 293,
+ "SHIFTOP", 294,
+ "MATCHOP", 295,
+ "ARROW", 296,
+ "!", 33,
+ "~", 126,
+ "UMINUS", 297,
+ "REFGEN", 298,
+ "POWOP", 299,
+ "PREINC", 300,
+ "PREDEC", 301,
+ "POSTINC", 302,
+ "POSTDEC", 303,
+ "(", 40,
+ "-unknown-", -1 /* ends search */
+};
+
+char * yyreds[] =
+{
+ "-no such reduction-",
+ "prog : /* empty */",
+ "prog : lineseq",
+ "block : '{' remember lineseq '}'",
+ "remember : /* empty */",
+ "lineseq : /* empty */",
+ "lineseq : lineseq decl",
+ "lineseq : lineseq line",
+ "line : label cond",
+ "line : loop",
+ "line : label ';'",
+ "line : label sideff ';'",
+ "sideff : error",
+ "sideff : expr",
+ "sideff : expr IF expr",
+ "sideff : expr UNLESS expr",
+ "sideff : expr WHILE expr",
+ "sideff : expr UNTIL expr",
+ "else : /* empty */",
+ "else : ELSE block",
+ "else : ELSIF '(' expr ')' block else",
+ "cond : IF '(' expr ')' block else",
+ "cond : UNLESS '(' expr ')' block else",
+ "cond : IF block block else",
+ "cond : UNLESS block block else",
+ "cont : /* empty */",
+ "cont : CONTINUE block",
+ "loop : label WHILE '(' texpr ')' block cont",
+ "loop : label UNTIL '(' expr ')' block cont",
+ "loop : label WHILE block block cont",
+ "loop : label UNTIL block block cont",
+ "loop : label FOR scalar '(' expr crp block cont",
+ "loop : label FOR '(' expr crp block cont",
+ "loop : label FOR '(' nexpr ';' texpr ';' nexpr ')' block",
+ "loop : label block cont",
+ "nexpr : /* empty */",
+ "nexpr : sideff",
+ "texpr : /* empty */",
+ "texpr : expr",
+ "label : /* empty */",
+ "label : LABEL",
+ "decl : format",
+ "decl : subrout",
+ "decl : package",
+ "format : FORMAT WORD block",
+ "format : FORMAT block",
+ "subrout : SUB WORD block",
+ "package : PACKAGE WORD ';'",
+ "package : PACKAGE ';'",
+ "expr : expr ',' sexpr",
+ "expr : sexpr",
+ "listop : LSTOP indirob listexpr",
+ "listop : FUNC '(' indirob listexpr ')'",
+ "listop : indirob ARROW LSTOP listexpr",
+ "listop : indirob ARROW FUNC '(' listexpr ')'",
+ "listop : term ARROW METHOD '(' listexpr ')'",
+ "listop : METHOD indirob listexpr",
+ "listop : LSTOP listexpr",
+ "listop : FUNC '(' listexpr ')'",
+ "sexpr : sexpr '=' sexpr",
+ "sexpr : sexpr POWOP '=' sexpr",
+ "sexpr : sexpr MULOP '=' sexpr",
+ "sexpr : sexpr ADDOP '=' sexpr",
+ "sexpr : sexpr SHIFTOP '=' sexpr",
+ "sexpr : sexpr BITANDOP '=' sexpr",
+ "sexpr : sexpr BITOROP '=' sexpr",
+ "sexpr : sexpr ANDAND '=' sexpr",
+ "sexpr : sexpr OROR '=' sexpr",
+ "sexpr : sexpr POWOP sexpr",
+ "sexpr : sexpr MULOP sexpr",
+ "sexpr : sexpr ADDOP sexpr",
+ "sexpr : sexpr SHIFTOP sexpr",
+ "sexpr : sexpr RELOP sexpr",
+ "sexpr : sexpr EQOP sexpr",
+ "sexpr : sexpr BITANDOP sexpr",
+ "sexpr : sexpr BITOROP sexpr",
+ "sexpr : sexpr DOTDOT sexpr",
+ "sexpr : sexpr ANDAND sexpr",
+ "sexpr : sexpr OROR sexpr",
+ "sexpr : sexpr '?' sexpr ':' sexpr",
+ "sexpr : sexpr MATCHOP sexpr",
+ "sexpr : term",
+ "term : '-' term",
+ "term : '+' term",
+ "term : '!' term",
+ "term : '~' term",
+ "term : REFGEN term",
+ "term : term POSTINC",
+ "term : term POSTDEC",
+ "term : PREINC term",
+ "term : PREDEC term",
+ "term : LOCAL sexpr",
+ "term : '(' expr crp",
+ "term : '(' ')'",
+ "term : '[' expr crb",
+ "term : '[' ']'",
+ "term : HASHBRACK expr crhb",
+ "term : HASHBRACK ';' '}'",
+ "term : scalar",
+ "term : star",
+ "term : scalar '[' expr ']'",
+ "term : term ARROW '[' expr ']'",
+ "term : hsh",
+ "term : ary",
+ "term : arylen",
+ "term : scalar '{' expr ';' '}'",
+ "term : term ARROW '{' expr ';' '}'",
+ "term : '(' expr crp '[' expr ']'",
+ "term : '(' ')' '[' expr ']'",
+ "term : ary '[' expr ']'",
+ "term : ary '{' expr ';' '}'",
+ "term : DELETE scalar '{' expr ';' '}'",
+ "term : DELETE '(' scalar '{' expr ';' '}' ')'",
+ "term : THING",
+ "term : amper",
+ "term : amper '(' ')'",
+ "term : amper '(' expr crp",
+ "term : DO sexpr",
+ "term : DO block",
+ "term : DO WORD '(' ')'",
+ "term : DO WORD '(' expr crp",
+ "term : DO scalar '(' ')'",
+ "term : DO scalar '(' expr crp",
+ "term : LOOPEX",
+ "term : LOOPEX WORD",
+ "term : UNIOP",
+ "term : UNIOP block",
+ "term : UNIOP sexpr",
+ "term : FUNC0",
+ "term : FUNC0 '(' ')'",
+ "term : FUNC1 '(' ')'",
+ "term : FUNC1 '(' expr ')'",
+ "term : PMFUNC '(' sexpr ')'",
+ "term : PMFUNC '(' sexpr ',' sexpr ')'",
+ "term : WORD",
+ "term : listop",
+ "listexpr : /* empty */",
+ "listexpr : expr",
+ "amper : '&' indirob",
+ "scalar : '$' indirob",
+ "ary : '@' indirob",
+ "hsh : '%' indirob",
+ "arylen : DOLSHARP indirob",
+ "star : '*' indirob",
+ "indirob : WORD",
+ "indirob : scalar",
+ "indirob : block",
+ "indirob : PRIVATEREF",
+ "crp : ',' ')'",
+ "crp : ')'",
+ "crb : ',' ']'",
+ "crb : ']'",
+ "crhb : ',' ';' '}'",
+ "crhb : ';' '}'",
+};
+#endif /* YYDEBUG */
+#line 1 "/usr/lib/yaccpar"
+/* @(#)yaccpar 1.10 89/04/04 SMI; from S5R3 1.10 */
+
+/*
+** Skeleton parser driver for yacc output
+*/
+
+/*
+** yacc user known macros and defines
+*/
+#define YYERROR goto yyerrlab
+#define YYACCEPT { free(yys); free(yyv); return(0); }
+#define YYABORT { free(yys); free(yyv); return(1); }
+#define YYBACKUP( newtoken, newvalue )\
+{\
+ if ( yychar >= 0 || ( yyr2[ yytmp ] >> 1 ) != 1 )\
+ {\
+ yyerror( "syntax error - cannot backup" );\
+ goto yyerrlab;\
+ }\
+ yychar = newtoken;\
+ yystate = *yyps;\
+ yylval = newvalue;\
+ goto yynewstate;\
+}
+#define YYRECOVERING() (!!yyerrflag)
+#ifndef YYDEBUG
+# define YYDEBUG 1 /* make debugging available */
+#endif
+
+/*
+** user known globals
+*/
+int yydebug; /* set to 1 to get debugging */
+
+/*
+** driver internal defines
+*/
+#define YYFLAG (-1000)
+
+/*
+** static variables used by the parser
+*/
+static YYSTYPE *yyv; /* value stack */
+static int *yys; /* state stack */
+
+static YYSTYPE *yypv; /* top of value stack */
+static int *yyps; /* top of state stack */
+
+static int yystate; /* current state */
+static int yytmp; /* extra var (lasts between blocks) */
+
+int yynerrs; /* number of errors */
+
+int yyerrflag; /* error recovery flag */
+int yychar; /* current input token number */
+
+
+/*
+** yyparse - return 0 if worked, 1 if syntax error not recovered from
+*/
+int
+yyparse()
+{
+ register YYSTYPE *yypvt; /* top of value stack for $vars */
+ unsigned yymaxdepth = YYMAXDEPTH;
+
+ /*
+ ** Initialize externals - yyparse may be called more than once
+ */
+ yyv = (YYSTYPE*)malloc(yymaxdepth*sizeof(YYSTYPE));
+ yys = (int*)malloc(yymaxdepth*sizeof(int));
+ if (!yyv || !yys)
+ {
+ yyerror( "out of memory" );
+ return(1);
+ }
+ yypv = &yyv[-1];
+ yyps = &yys[-1];
+ yystate = 0;
+ yytmp = 0;
+ yynerrs = 0;
+ yyerrflag = 0;
+ yychar = -1;
+
+ goto yystack;
+ {
+ register YYSTYPE *yy_pv; /* top of value stack */
+ register int *yy_ps; /* top of state stack */
+ register int yy_state; /* current state */
+ register int yy_n; /* internal state number info */
+
+ /*
+ ** get globals into registers.
+ ** branch to here only if YYBACKUP was called.
+ */
+ yynewstate:
+ yy_pv = yypv;
+ yy_ps = yyps;
+ yy_state = yystate;
+ goto yy_newstate;
+
+ /*
+ ** get globals into registers.
+ ** either we just started, or we just finished a reduction
+ */
+ yystack:
+ yy_pv = yypv;
+ yy_ps = yyps;
+ yy_state = yystate;
+
+ /*
+ ** top of for (;;) loop while no reductions done
+ */
+ yy_stack:
+ /*
+ ** put a state and value onto the stacks
+ */
+#if YYDEBUG
+ /*
+ ** if debugging, look up token value in list of value vs.
+ ** name pairs. 0 and negative (-1) are special values.
+ ** Note: linear search is used since time is not a real
+ ** consideration while debugging.
+ */
+ if ( yydebug )
+ {
+ register int yy_i;
+
+ (void)printf( "State %d, token ", yy_state );
+ if ( yychar == 0 )
+ (void)printf( "end-of-file\n" );
+ else if ( yychar < 0 )
+ (void)printf( "-none-\n" );
+ else
+ {
+ for ( yy_i = 0; yytoks[yy_i].t_val >= 0;
+ yy_i++ )
+ {
+ if ( yytoks[yy_i].t_val == yychar )
+ break;
+ }
+ (void)printf( "%s\n", yytoks[yy_i].t_name );
+ }
+ }
+#endif /* YYDEBUG */
+ if ( ++yy_ps >= &yys[ yymaxdepth ] ) /* room on stack? */
+ {
+ /*
+ ** reallocate and recover. Note that pointers
+ ** have to be reset, or bad things will happen
+ */
+ int yyps_index = (yy_ps - yys);
+ int yypv_index = (yy_pv - yyv);
+ int yypvt_index = (yypvt - yyv);
+ yymaxdepth += YYMAXDEPTH;
+ yyv = (YYSTYPE*)realloc((char*)yyv,
+ yymaxdepth * sizeof(YYSTYPE));
+ yys = (int*)realloc((char*)yys,
+ yymaxdepth * sizeof(int));
+ if (!yyv || !yys)
+ {
+ yyerror( "yacc stack overflow" );
+ return(1);
+ }
+ yy_ps = yys + yyps_index;
+ yy_pv = yyv + yypv_index;
+ yypvt = yyv + yypvt_index;
+ }
+ *yy_ps = yy_state;
+ *++yy_pv = yyval;
+
+ /*
+ ** we have a new state - find out what to do
+ */
+ yy_newstate:
+ if ( ( yy_n = yypact[ yy_state ] ) <= YYFLAG )
+ goto yydefault; /* simple state */
+#if YYDEBUG
+ /*
+ ** if debugging, need to mark whether new token grabbed
+ */
+ yytmp = yychar < 0;
+#endif
+ if ( ( yychar < 0 ) && ( ( yychar = yylex() ) < 0 ) )
+ yychar = 0; /* reached EOF */
+#if YYDEBUG
+ if ( yydebug && yytmp )
+ {
+ register int yy_i;
+
+ (void)printf( " *** Received token " );
+ if ( yychar == 0 )
+ (void)printf( "end-of-file\n" );
+ else if ( yychar < 0 )
+ (void)printf( "-none-\n" );
+ else
+ {
+ for ( yy_i = 0; yytoks[yy_i].t_val >= 0;
+ yy_i++ )
+ {
+ if ( yytoks[yy_i].t_val == yychar )
+ break;
+ }
+ (void)printf( "%s\n", yytoks[yy_i].t_name );
+ }
+ }
+#endif /* YYDEBUG */
+ if ( ( ( yy_n += yychar ) < 0 ) || ( yy_n >= YYLAST ) )
+ goto yydefault;
+ if ( yychk[ yy_n = yyact[ yy_n ] ] == yychar ) /*valid shift*/
+ {
+ yychar = -1;
+ yyval = yylval;
+ yy_state = yy_n;
+ if ( yyerrflag > 0 )
+ yyerrflag--;
+ goto yy_stack;
+ }
+
+ yydefault:
+ if ( ( yy_n = yydef[ yy_state ] ) == -2 )
+ {
+#if YYDEBUG
+ yytmp = yychar < 0;
+#endif
+ if ( ( yychar < 0 ) && ( ( yychar = yylex() ) < 0 ) )
+ yychar = 0; /* reached EOF */
+#if YYDEBUG
+ if ( yydebug && yytmp )
+ {
+ register int yy_i;
+
+ (void)printf( " *** Received token " );
+ if ( yychar == 0 )
+ (void)printf( "end-of-file\n" );
+ else if ( yychar < 0 )
+ (void)printf( "-none-\n" );
+ else
+ {
+ for ( yy_i = 0;
+ yytoks[yy_i].t_val >= 0;
+ yy_i++ )
+ {
+ if ( yytoks[yy_i].t_val
+ == yychar )
+ {
+ break;
+ }
+ }
+ (void)printf( "%s\n", yytoks[yy_i].t_name );
+ }
+ }
+#endif /* YYDEBUG */
+ /*
+ ** look through exception table
+ */
+ {
+ register int *yyxi = yyexca;
+
+ while ( ( *yyxi != -1 ) ||
+ ( yyxi[1] != yy_state ) )
+ {
+ yyxi += 2;
+ }
+ while ( ( *(yyxi += 2) >= 0 ) &&
+ ( *yyxi != yychar ) )
+ ;
+ if ( ( yy_n = yyxi[1] ) < 0 )
+ YYACCEPT;
+ }
+ }
+
+ /*
+ ** check for syntax error
+ */
+ if ( yy_n == 0 ) /* have an error */
+ {
+ /* no worry about speed here! */
+ switch ( yyerrflag )
+ {
+ case 0: /* new error */
+ yyerror( "syntax error" );
+ goto skip_init;
+ yyerrlab:
+ /*
+ ** get globals into registers.
+ ** we have a user generated syntax type error
+ */
+ yy_pv = yypv;
+ yy_ps = yyps;
+ yy_state = yystate;
+ yynerrs++;
+ skip_init:
+ case 1:
+ case 2: /* incompletely recovered error */
+ /* try again... */
+ yyerrflag = 3;
+ /*
+ ** find state where "error" is a legal
+ ** shift action
+ */
+ while ( yy_ps >= yys )
+ {
+ yy_n = yypact[ *yy_ps ] + YYERRCODE;
+ if ( yy_n >= 0 && yy_n < YYLAST &&
+ yychk[yyact[yy_n]] == YYERRCODE) {
+ /*
+ ** simulate shift of "error"
+ */
+ yy_state = yyact[ yy_n ];
+ goto yy_stack;
+ }
+ /*
+ ** current state has no shift on
+ ** "error", pop stack
+ */
+#if YYDEBUG
+# define _POP_ "Error recovery pops state %d, uncovers state %d\n"
+ if ( yydebug )
+ (void)printf( _POP_, *yy_ps,
+ yy_ps[-1] );
+# undef _POP_
+#endif
+ yy_ps--;
+ yy_pv--;
+ }
+ /*
+ ** there is no state on stack with "error" as
+ ** a valid shift. give up.
+ */
+ YYABORT;
+ case 3: /* no shift yet; eat a token */
+#if YYDEBUG
+ /*
+ ** if debugging, look up token in list of
+ ** pairs. 0 and negative shouldn't occur,
+ ** but since timing doesn't matter when
+ ** debugging, it doesn't hurt to leave the
+ ** tests here.
+ */
+ if ( yydebug )
+ {
+ register int yy_i;
+
+ (void)printf( "Error recovery discards " );
+ if ( yychar == 0 )
+ (void)printf( "token end-of-file\n" );
+ else if ( yychar < 0 )
+ (void)printf( "token -none-\n" );
+ else
+ {
+ for ( yy_i = 0;
+ yytoks[yy_i].t_val >= 0;
+ yy_i++ )
+ {
+ if ( yytoks[yy_i].t_val
+ == yychar )
+ {
+ break;
+ }
+ }
+ (void)printf( "token %s\n",
+ yytoks[yy_i].t_name );
+ }
+ }
+#endif /* YYDEBUG */
+ if ( yychar == 0 ) /* reached EOF. quit */
+ YYABORT;
+ yychar = -1;
+ goto yy_newstate;
+ }
+ }/* end if ( yy_n == 0 ) */
+ /*
+ ** reduction by production yy_n
+ ** put stack tops, etc. so things right after switch
+ */
+#if YYDEBUG
+ /*
+ ** if debugging, print the string that is the user's
+ ** specification of the reduction which is just about
+ ** to be done.
+ */
+ if ( yydebug )
+ (void)printf( "Reduce by (%d) \"%s\"\n",
+ yy_n, yyreds[ yy_n ] );
+#endif
+ yytmp = yy_n; /* value to switch over */
+ yypvt = yy_pv; /* $vars top of value stack */
+ /*
+ ** Look in goto table for next state
+ ** Sorry about using yy_state here as temporary
+ ** register variable, but why not, if it works...
+ ** If yyr2[ yy_n ] doesn't have the low order bit
+ ** set, then there is no action to be done for
+ ** this reduction. So, no saving & unsaving of
+ ** registers done. The only difference between the
+ ** code just after the if and the body of the if is
+ ** the goto yy_stack in the body. This way the test
+ ** can be made before the choice of what to do is needed.
+ */
+ {
+ /* length of production doubled with extra bit */
+ register int yy_len = yyr2[ yy_n ];
+
+ if ( !( yy_len & 01 ) )
+ {
+ yy_len >>= 1;
+ yyval = ( yy_pv -= yy_len )[1]; /* $$ = $1 */
+ yy_state = yypgo[ yy_n = yyr1[ yy_n ] ] +
+ *( yy_ps -= yy_len ) + 1;
+ if ( yy_state >= YYLAST ||
+ yychk[ yy_state =
+ yyact[ yy_state ] ] != -yy_n )
+ {
+ yy_state = yyact[ yypgo[ yy_n ] ];
+ }
+ goto yy_stack;
+ }
+ yy_len >>= 1;
+ yyval = ( yy_pv -= yy_len )[1]; /* $$ = $1 */
+ yy_state = yypgo[ yy_n = yyr1[ yy_n ] ] +
+ *( yy_ps -= yy_len ) + 1;
+ if ( yy_state >= YYLAST ||
+ yychk[ yy_state = yyact[ yy_state ] ] != -yy_n )
+ {
+ yy_state = yyact[ yypgo[ yy_n ] ];
+ }
+ }
+ /* save until reenter driver code */
+ yystate = yy_state;
+ yyps = yy_ps;
+ yypv = yy_pv;
+ }
+ /*
+ ** code supplied by user is placed in this switch
+ */
+ switch( yytmp )
+ {
+
+case 1:
+# line 100 "perly.y"
+{
+#if defined(YYDEBUG) && defined(DEBUGGING)
+ yydebug = (debug & 1);
+#endif
+ expect = XBLOCK;
+ } break;
+case 2:
+# line 107 "perly.y"
+{ if (in_eval) {
+ eval_root = newUNOP(OP_LEAVEEVAL, 0, yypvt[-0].opval);
+ eval_start = linklist(eval_root);
+ eval_root->op_next = 0;
+ peep(eval_start);
+ }
+ else
+ main_root = block_head(yypvt[-0].opval, &main_start);
+ } break;
+case 3:
+# line 119 "perly.y"
+{ yyval.opval = scalarseq(yypvt[-1].opval);
+ if (copline > (line_t)yypvt[-3].ival)
+ copline = yypvt[-3].ival;
+ leave_scope(yypvt[-2].ival);
+ pad_leavemy(comppadnamefill);
+ expect = XBLOCK; } break;
+case 4:
+# line 128 "perly.y"
+{ yyval.ival = savestack_ix; SAVEINT(comppadnamefill); } break;
+case 5:
+# line 132 "perly.y"
+{ yyval.opval = Nullop; } break;
+case 6:
+# line 134 "perly.y"
+{ yyval.opval = yypvt[-1].opval; } break;
+case 7:
+# line 136 "perly.y"
+{ yyval.opval = append_list(OP_LINESEQ, yypvt[-1].opval, yypvt[-0].opval); pad_reset(); } break;
+case 8:
+# line 140 "perly.y"
+{ yyval.opval = newSTATEOP(0, yypvt[-1].pval, yypvt[-0].opval); } break;
+case 10:
+# line 143 "perly.y"
+{ if (yypvt[-1].pval != Nullch) {
+ yyval.opval = newSTATEOP(0, yypvt[-1].pval, newOP(OP_NULL, 0));
+ }
+ else {
+ yyval.opval = Nullop;
+ copline = NOLINE;
+ }
+ expect = XBLOCK; } break;
+case 11:
+# line 152 "perly.y"
+{ yyval.opval = newSTATEOP(0, yypvt[-2].pval, yypvt[-1].opval);
+ expect = XBLOCK; } break;
+case 12:
+# line 157 "perly.y"
+{ yyval.opval = Nullop; } break;
+case 13:
+# line 159 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 14:
+# line 161 "perly.y"
+{ yyval.opval = newLOGOP(OP_AND, 0, yypvt[-0].opval, yypvt[-2].opval); } break;
+case 15:
+# line 163 "perly.y"
+{ yyval.opval = newLOGOP(OP_OR, 0, yypvt[-0].opval, yypvt[-2].opval); } break;
+case 16:
+# line 165 "perly.y"
+{ yyval.opval = newLOOPOP(0, 1, scalar(yypvt[-0].opval), yypvt[-2].opval); } break;
+case 17:
+# line 167 "perly.y"
+{ yyval.opval = newLOOPOP(0, 1, invert(scalar(yypvt[-0].opval)), yypvt[-2].opval);} break;
+case 18:
+# line 171 "perly.y"
+{ yyval.opval = Nullop; } break;
+case 19:
+# line 173 "perly.y"
+{ yyval.opval = scope(yypvt[-0].opval); } break;
+case 20:
+# line 175 "perly.y"
+{ copline = yypvt[-5].ival;
+ yyval.opval = newCONDOP(0, yypvt[-3].opval, scope(yypvt[-1].opval), yypvt[-0].opval); } break;
+case 21:
+# line 180 "perly.y"
+{ copline = yypvt[-5].ival;
+ yyval.opval = newCONDOP(0, yypvt[-3].opval, scope(yypvt[-1].opval), yypvt[-0].opval); } break;
+case 22:
+# line 183 "perly.y"
+{ copline = yypvt[-5].ival;
+ yyval.opval = newCONDOP(0,
+ invert(scalar(yypvt[-3].opval)), scope(yypvt[-1].opval), yypvt[-0].opval); } break;
+case 23:
+# line 187 "perly.y"
+{ copline = yypvt[-3].ival;
+ yyval.opval = newCONDOP(0, scope(yypvt[-2].opval), scope(yypvt[-1].opval), yypvt[-0].opval); } break;
+case 24:
+# line 190 "perly.y"
+{ copline = yypvt[-3].ival;
+ yyval.opval = newCONDOP(0, invert(scalar(scope(yypvt[-2].opval))),
+ scope(yypvt[-1].opval), yypvt[-0].opval); } break;
+case 25:
+# line 196 "perly.y"
+{ yyval.opval = Nullop; } break;
+case 26:
+# line 198 "perly.y"
+{ yyval.opval = scope(yypvt[-0].opval); } break;
+case 27:
+# line 202 "perly.y"
+{ copline = yypvt[-5].ival;
+ yyval.opval = newSTATEOP(0, yypvt[-6].pval,
+ newWHILEOP(0, 1, Nullop, yypvt[-3].opval, yypvt[-1].opval, yypvt[-0].opval) ); } break;
+case 28:
+# line 206 "perly.y"
+{ copline = yypvt[-5].ival;
+ yyval.opval = newSTATEOP(0, yypvt[-6].pval,
+ newWHILEOP(0, 1, Nullop,
+ invert(scalar(yypvt[-3].opval)), yypvt[-1].opval, yypvt[-0].opval) ); } break;
+case 29:
+# line 211 "perly.y"
+{ copline = yypvt[-3].ival;
+ yyval.opval = newSTATEOP(0, yypvt[-4].pval,
+ newWHILEOP(0, 1, Nullop,
+ scope(yypvt[-2].opval), yypvt[-1].opval, yypvt[-0].opval) ); } break;
+case 30:
+# line 216 "perly.y"
+{ copline = yypvt[-3].ival;
+ yyval.opval = newSTATEOP(0, yypvt[-4].pval,
+ newWHILEOP(0, 1, Nullop,
+ invert(scalar(scope(yypvt[-2].opval))), yypvt[-1].opval, yypvt[-0].opval)); } break;
+case 31:
+# line 221 "perly.y"
+{ yyval.opval = newFOROP(0, yypvt[-7].pval, yypvt[-6].ival, ref(yypvt[-5].opval, OP_ENTERLOOP),
+ yypvt[-3].opval, yypvt[-1].opval, yypvt[-0].opval); } break;
+case 32:
+# line 224 "perly.y"
+{ yyval.opval = newFOROP(0, yypvt[-6].pval, yypvt[-5].ival, Nullop, yypvt[-3].opval, yypvt[-1].opval, yypvt[-0].opval); } break;
+case 33:
+# line 227 "perly.y"
+{ copline = yypvt[-8].ival;
+ yyval.opval = append_elem(OP_LINESEQ,
+ newSTATEOP(0, yypvt[-9].pval, scalar(yypvt[-6].opval)),
+ newSTATEOP(0, yypvt[-9].pval,
+ newWHILEOP(0, 1, Nullop,
+ scalar(yypvt[-4].opval), yypvt[-0].opval, scalar(yypvt[-2].opval)) )); } break;
+case 34:
+# line 234 "perly.y"
+{ yyval.opval = newSTATEOP(0,
+ yypvt[-2].pval, newWHILEOP(0, 1, Nullop, Nullop, yypvt[-1].opval, yypvt[-0].opval)); } break;
+case 35:
+# line 239 "perly.y"
+{ yyval.opval = Nullop; } break;
+case 37:
+# line 244 "perly.y"
+{ (void)scan_num("1"); yyval.opval = yylval.opval; } break;
+case 39:
+# line 249 "perly.y"
+{ yyval.pval = Nullch; } break;
+case 41:
+# line 254 "perly.y"
+{ yyval.ival = 0; } break;
+case 42:
+# line 256 "perly.y"
+{ yyval.ival = 0; } break;
+case 43:
+# line 258 "perly.y"
+{ yyval.ival = 0; } break;
+case 44:
+# line 262 "perly.y"
+{ newFORM(yypvt[-2].ival, yypvt[-1].opval, yypvt[-0].opval); } break;
+case 45:
+# line 264 "perly.y"
+{ newFORM(yypvt[-1].ival, Nullop, yypvt[-0].opval); } break;
+case 46:
+# line 268 "perly.y"
+{ newSUB(yypvt[-2].ival, yypvt[-1].opval, yypvt[-0].opval); } break;
+case 47:
+# line 272 "perly.y"
+{ package(yypvt[-1].opval); } break;
+case 48:
+# line 274 "perly.y"
+{ package(Nullop); } break;
+case 49:
+# line 278 "perly.y"
+{ yyval.opval = append_elem(OP_LIST, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 51:
+# line 283 "perly.y"
+{ yyval.opval = convert(yypvt[-2].ival, OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF(yypvt[-1].opval), yypvt[-0].opval) ); } break;
+case 52:
+# line 286 "perly.y"
+{ yyval.opval = convert(yypvt[-4].ival, OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF(yypvt[-2].opval), yypvt[-1].opval) ); } break;
+case 53:
+# line 289 "perly.y"
+{ yyval.opval = convert(yypvt[-1].ival, OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF(yypvt[-3].opval), yypvt[-0].opval) ); } break;
+case 54:
+# line 292 "perly.y"
+{ yyval.opval = convert(yypvt[-3].ival, OPf_STACKED,
+ prepend_elem(OP_LIST, newGVREF(yypvt[-5].opval), yypvt[-1].opval) ); } break;
+case 55:
+# line 295 "perly.y"
+{ yyval.opval = convert(OP_ENTERSUBR, OPf_STACKED|OPf_SPECIAL,
+ prepend_elem(OP_LIST, newMETHOD(yypvt[-5].opval,yypvt[-3].opval), yypvt[-1].opval)); } break;
+case 56:
+# line 298 "perly.y"
+{ yyval.opval = convert(OP_ENTERSUBR, OPf_STACKED|OPf_SPECIAL,
+ prepend_elem(OP_LIST, newMETHOD(yypvt[-1].opval,yypvt[-2].opval), yypvt[-0].opval)); } break;
+case 57:
+# line 301 "perly.y"
+{ yyval.opval = convert(yypvt[-1].ival, 0, yypvt[-0].opval); } break;
+case 58:
+# line 303 "perly.y"
+{ yyval.opval = convert(yypvt[-3].ival, 0, yypvt[-1].opval); } break;
+case 59:
+# line 307 "perly.y"
+{ yyval.opval = newASSIGNOP(OPf_STACKED, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 60:
+# line 309 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval)); } break;
+case 61:
+# line 312 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval)); } break;
+case 62:
+# line 315 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval));} break;
+case 63:
+# line 318 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval)); } break;
+case 64:
+# line 321 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval)); } break;
+case 65:
+# line 324 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-2].ival, OPf_STACKED,
+ ref(scalar(yypvt[-3].opval), yypvt[-2].ival), scalar(yypvt[-0].opval)); } break;
+case 66:
+# line 327 "perly.y"
+{ yyval.opval = newLOGOP(OP_ANDASSIGN, 0,
+ ref(scalar(yypvt[-3].opval), OP_ANDASSIGN),
+ newUNOP(OP_SASSIGN, 0, scalar(yypvt[-0].opval))); } break;
+case 67:
+# line 331 "perly.y"
+{ yyval.opval = newLOGOP(OP_ORASSIGN, 0,
+ ref(scalar(yypvt[-3].opval), OP_ORASSIGN),
+ newUNOP(OP_SASSIGN, 0, scalar(yypvt[-0].opval))); } break;
+case 68:
+# line 337 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 69:
+# line 339 "perly.y"
+{ if (yypvt[-1].ival != OP_REPEAT)
+ scalar(yypvt[-2].opval);
+ yyval.opval = newBINOP(yypvt[-1].ival, 0, yypvt[-2].opval, scalar(yypvt[-0].opval)); } break;
+case 70:
+# line 343 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 71:
+# line 345 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 72:
+# line 347 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 73:
+# line 349 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 74:
+# line 351 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 75:
+# line 353 "perly.y"
+{ yyval.opval = newBINOP(yypvt[-1].ival, 0, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval)); } break;
+case 76:
+# line 355 "perly.y"
+{ yyval.opval = newRANGE(yypvt[-1].ival, scalar(yypvt[-2].opval), scalar(yypvt[-0].opval));} break;
+case 77:
+# line 357 "perly.y"
+{ yyval.opval = newLOGOP(OP_AND, 0, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 78:
+# line 359 "perly.y"
+{ yyval.opval = newLOGOP(OP_OR, 0, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 79:
+# line 361 "perly.y"
+{ yyval.opval = newCONDOP(0, yypvt[-4].opval, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 80:
+# line 363 "perly.y"
+{ yyval.opval = bind_match(yypvt[-1].ival, yypvt[-2].opval, yypvt[-0].opval); } break;
+case 81:
+# line 365 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 82:
+# line 369 "perly.y"
+{ yyval.opval = newUNOP(OP_NEGATE, 0, scalar(yypvt[-0].opval)); } break;
+case 83:
+# line 371 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 84:
+# line 373 "perly.y"
+{ yyval.opval = newUNOP(OP_NOT, 0, scalar(yypvt[-0].opval)); } break;
+case 85:
+# line 375 "perly.y"
+{ yyval.opval = newUNOP(OP_COMPLEMENT, 0, scalar(yypvt[-0].opval));} break;
+case 86:
+# line 377 "perly.y"
+{ yyval.opval = newUNOP(OP_REFGEN, 0, ref(yypvt[-0].opval, OP_REFGEN)); } break;
+case 87:
+# line 379 "perly.y"
+{ yyval.opval = newUNOP(OP_POSTINC, 0,
+ ref(scalar(yypvt[-1].opval), OP_POSTINC)); } break;
+case 88:
+# line 382 "perly.y"
+{ yyval.opval = newUNOP(OP_POSTDEC, 0,
+ ref(scalar(yypvt[-1].opval), OP_POSTDEC)); } break;
+case 89:
+# line 385 "perly.y"
+{ yyval.opval = newUNOP(OP_PREINC, 0,
+ ref(scalar(yypvt[-0].opval), OP_PREINC)); } break;
+case 90:
+# line 388 "perly.y"
+{ yyval.opval = newUNOP(OP_PREDEC, 0,
+ ref(scalar(yypvt[-0].opval), OP_PREDEC)); } break;
+case 91:
+# line 391 "perly.y"
+{ yyval.opval = localize(yypvt[-0].opval,yypvt[-1].ival); } break;
+case 92:
+# line 393 "perly.y"
+{ yyval.opval = sawparens(yypvt[-1].opval); } break;
+case 93:
+# line 395 "perly.y"
+{ yyval.opval = newNULLLIST(); } break;
+case 94:
+# line 397 "perly.y"
+{ yyval.opval = newANONLIST(yypvt[-1].opval); } break;
+case 95:
+# line 399 "perly.y"
+{ yyval.opval = newANONLIST(Nullop); } break;
+case 96:
+# line 401 "perly.y"
+{ yyval.opval = newANONHASH(yypvt[-1].opval); } break;
+case 97:
+# line 403 "perly.y"
+{ yyval.opval = newANONHASH(Nullop); } break;
+case 98:
+# line 405 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 99:
+# line 407 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 100:
+# line 409 "perly.y"
+{ yyval.opval = newBINOP(OP_AELEM, 0, oopsAV(yypvt[-3].opval), scalar(yypvt[-1].opval)); } break;
+case 101:
+# line 411 "perly.y"
+{ yyval.opval = newBINOP(OP_AELEM, 0,
+ scalar(ref(newAVREF(yypvt[-4].opval),OP_RV2AV)),
+ scalar(yypvt[-1].opval));} break;
+case 102:
+# line 415 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 103:
+# line 417 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 104:
+# line 419 "perly.y"
+{ yyval.opval = newUNOP(OP_AV2ARYLEN, 0, ref(yypvt[-0].opval, OP_AV2ARYLEN));} break;
+case 105:
+# line 421 "perly.y"
+{ yyval.opval = newBINOP(OP_HELEM, 0, oopsHV(yypvt[-4].opval), jmaybe(yypvt[-2].opval));
+ expect = XOPERATOR; } break;
+case 106:
+# line 424 "perly.y"
+{ yyval.opval = newBINOP(OP_HELEM, 0,
+ scalar(ref(newHVREF(yypvt[-5].opval),OP_RV2HV)),
+ jmaybe(yypvt[-2].opval));
+ expect = XOPERATOR; } break;
+case 107:
+# line 429 "perly.y"
+{ yyval.opval = newSLICEOP(0, yypvt[-1].opval, yypvt[-4].opval); } break;
+case 108:
+# line 431 "perly.y"
+{ yyval.opval = newSLICEOP(0, yypvt[-1].opval, Nullop); } break;
+case 109:
+# line 433 "perly.y"
+{ yyval.opval = prepend_elem(OP_ASLICE,
+ newOP(OP_PUSHMARK, 0),
+ list(
+ newLISTOP(OP_ASLICE, 0,
+ list(yypvt[-1].opval),
+ ref(yypvt[-3].opval, OP_ASLICE)))); } break;
+case 110:
+# line 440 "perly.y"
+{ yyval.opval = prepend_elem(OP_HSLICE,
+ newOP(OP_PUSHMARK, 0),
+ list(
+ newLISTOP(OP_HSLICE, 0,
+ list(yypvt[-2].opval),
+ ref(oopsHV(yypvt[-4].opval), OP_HSLICE))));
+ expect = XOPERATOR; } break;
+case 111:
+# line 448 "perly.y"
+{ yyval.opval = newBINOP(OP_DELETE, 0, oopsHV(yypvt[-4].opval), jmaybe(yypvt[-2].opval));
+ expect = XOPERATOR; } break;
+case 112:
+# line 451 "perly.y"
+{ yyval.opval = newBINOP(OP_DELETE, 0, oopsHV(yypvt[-5].opval), jmaybe(yypvt[-3].opval));
+ expect = XOPERATOR; } break;
+case 113:
+# line 454 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 114:
+# line 456 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, 0,
+ scalar(yypvt[-0].opval)); } break;
+case 115:
+# line 459 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_STACKED, scalar(yypvt[-2].opval)); } break;
+case 116:
+# line 461 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_STACKED,
+ list(prepend_elem(OP_LIST, scalar(yypvt[-3].opval), yypvt[-1].opval))); } break;
+case 117:
+# line 464 "perly.y"
+{ yyval.opval = newUNOP(OP_DOFILE, 0, scalar(yypvt[-0].opval));
+ allgvs = TRUE;} break;
+case 118:
+# line 467 "perly.y"
+{ yyval.opval = newUNOP(OP_NULL, OPf_SPECIAL, scope(yypvt[-0].opval)); } break;
+case 119:
+# line 469 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_SPECIAL|OPf_STACKED,
+ list(prepend_elem(OP_LIST,
+ scalar(newCVREF(scalar(yypvt[-2].opval))), newNULLLIST()))); } break;
+case 120:
+# line 473 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_SPECIAL|OPf_STACKED,
+ list(prepend_elem(OP_LIST,
+ scalar(newCVREF(scalar(yypvt[-3].opval))),
+ yypvt[-1].opval))); } break;
+case 121:
+# line 478 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_SPECIAL|OPf_STACKED,
+ list(prepend_elem(OP_LIST,
+ scalar(newCVREF(scalar(yypvt[-2].opval))), newNULLLIST())));} break;
+case 122:
+# line 482 "perly.y"
+{ yyval.opval = newUNOP(OP_ENTERSUBR, OPf_SPECIAL|OPf_STACKED,
+ list(prepend_elem(OP_LIST,
+ scalar(newCVREF(scalar(yypvt[-3].opval))),
+ yypvt[-1].opval))); } break;
+case 123:
+# line 487 "perly.y"
+{ yyval.opval = newOP(yypvt[-0].ival, OPf_SPECIAL); } break;
+case 124:
+# line 489 "perly.y"
+{ yyval.opval = newPVOP(yypvt[-1].ival, 0,
+ savestr(SvPVnx(((SVOP*)yypvt[-0].opval)->op_sv)));
+ op_free(yypvt[-0].opval); } break;
+case 125:
+# line 493 "perly.y"
+{ yyval.opval = newOP(yypvt[-0].ival, 0); } break;
+case 126:
+# line 495 "perly.y"
+{ yyval.opval = newUNOP(yypvt[-1].ival, 0, yypvt[-0].opval); } break;
+case 127:
+# line 497 "perly.y"
+{ yyval.opval = newUNOP(yypvt[-1].ival, 0, yypvt[-0].opval); } break;
+case 128:
+# line 499 "perly.y"
+{ yyval.opval = newOP(yypvt[-0].ival, 0); } break;
+case 129:
+# line 501 "perly.y"
+{ yyval.opval = newOP(yypvt[-2].ival, 0); } break;
+case 130:
+# line 503 "perly.y"
+{ yyval.opval = newOP(yypvt[-2].ival, OPf_SPECIAL); } break;
+case 131:
+# line 505 "perly.y"
+{ yyval.opval = newUNOP(yypvt[-3].ival, 0, yypvt[-1].opval); } break;
+case 132:
+# line 507 "perly.y"
+{ yyval.opval = pmruntime(yypvt[-3].opval, yypvt[-1].opval, Nullop); } break;
+case 133:
+# line 509 "perly.y"
+{ yyval.opval = pmruntime(yypvt[-5].opval, yypvt[-3].opval, yypvt[-1].opval); } break;
+case 136:
+# line 515 "perly.y"
+{ yyval.opval = newNULLLIST(); } break;
+case 137:
+# line 517 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 138:
+# line 521 "perly.y"
+{ yyval.opval = newCVREF(yypvt[-0].opval); } break;
+case 139:
+# line 525 "perly.y"
+{ yyval.opval = newSVREF(yypvt[-0].opval); } break;
+case 140:
+# line 529 "perly.y"
+{ yyval.opval = newAVREF(yypvt[-0].opval); } break;
+case 141:
+# line 533 "perly.y"
+{ yyval.opval = newHVREF(yypvt[-0].opval); } break;
+case 142:
+# line 537 "perly.y"
+{ yyval.opval = newAVREF(yypvt[-0].opval); } break;
+case 143:
+# line 541 "perly.y"
+{ yyval.opval = newGVREF(yypvt[-0].opval); } break;
+case 144:
+# line 545 "perly.y"
+{ yyval.opval = scalar(yypvt[-0].opval); } break;
+case 145:
+# line 547 "perly.y"
+{ yyval.opval = scalar(yypvt[-0].opval); } break;
+case 146:
+# line 549 "perly.y"
+{ yyval.opval = scalar(scope(yypvt[-0].opval)); } break;
+case 147:
+# line 552 "perly.y"
+{ yyval.opval = yypvt[-0].opval; } break;
+case 148:
+# line 556 "perly.y"
+{ yyval.ival = 1; } break;
+case 149:
+# line 558 "perly.y"
+{ yyval.ival = 0; } break;
+case 150:
+# line 562 "perly.y"
+{ yyval.ival = 1; } break;
+case 151:
+# line 564 "perly.y"
+{ yyval.ival = 0; } break;
+case 152:
+# line 568 "perly.y"
+{ yyval.ival = 1; } break;
+case 153:
+# line 570 "perly.y"
+{ yyval.ival = 0; } break;
+ }
+ goto yystack; /* reset registers in driver code */
+}