1373 lines
43 KiB
C
1373 lines
43 KiB
C
#ifndef lint
|
|
static char yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93";
|
|
#endif
|
|
#define YYBYACC 1
|
|
#define YYMAJOR 1
|
|
#define YYMINOR 9
|
|
#define yyclearin (yychar=(-1))
|
|
#define yyerrok (yyerrflag=0)
|
|
#define YYRECOVERING (yyerrflag!=0)
|
|
#define YYPREFIX "yy"
|
|
#line 2 "bc.y"
|
|
/* bc.y: The grammar for a POSIX compatable bc processor with some
|
|
extensions to the language. */
|
|
|
|
/* This file is part of bc written for MINIX.
|
|
Copyright (C) 1991, 1992 Free Software Foundation, Inc.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License , or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; see the file COPYING. If not, write to
|
|
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
You may contact the author by:
|
|
e-mail: phil@cs.wwu.edu
|
|
us-mail: Philip A. Nelson
|
|
Computer Science Department, 9062
|
|
Western Washington University
|
|
Bellingham, WA 98226-9062
|
|
|
|
*************************************************************************/
|
|
|
|
#include "bcdefs.h"
|
|
#include "global.h"
|
|
#include "proto.h"
|
|
#line 38 "bc.y"
|
|
typedef union {
|
|
char *s_value;
|
|
char c_value;
|
|
int i_value;
|
|
arg_list *a_value;
|
|
} YYSTYPE;
|
|
#line 52 "y.tab.c"
|
|
#define NEWLINE 257
|
|
#define AND 258
|
|
#define OR 259
|
|
#define NOT 260
|
|
#define STRING 261
|
|
#define NAME 262
|
|
#define NUMBER 263
|
|
#define MUL_OP 264
|
|
#define ASSIGN_OP 265
|
|
#define REL_OP 266
|
|
#define INCR_DECR 267
|
|
#define Define 268
|
|
#define Break 269
|
|
#define Quit 270
|
|
#define Length 271
|
|
#define Return 272
|
|
#define For 273
|
|
#define If 274
|
|
#define While 275
|
|
#define Sqrt 276
|
|
#define Else 277
|
|
#define Scale 278
|
|
#define Ibase 279
|
|
#define Obase 280
|
|
#define Auto 281
|
|
#define Read 282
|
|
#define Warranty 283
|
|
#define Halt 284
|
|
#define Last 285
|
|
#define Continue 286
|
|
#define Print 287
|
|
#define Limits 288
|
|
#define UNARY_MINUS 289
|
|
#define YYERRCODE 256
|
|
short yylhs[] = { -1,
|
|
0, 0, 10, 10, 10, 11, 11, 11, 11, 12,
|
|
12, 12, 12, 12, 12, 15, 15, 13, 13, 13,
|
|
13, 13, 13, 13, 13, 13, 13, 16, 17, 18,
|
|
19, 13, 20, 13, 22, 23, 13, 13, 25, 13,
|
|
24, 24, 26, 26, 21, 27, 21, 28, 14, 5,
|
|
5, 6, 6, 6, 7, 7, 7, 7, 8, 8,
|
|
9, 9, 9, 9, 4, 4, 2, 2, 29, 1,
|
|
30, 1, 31, 1, 1, 1, 1, 1, 1, 1,
|
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
|
1, 3, 3, 3, 3, 3, 3,
|
|
};
|
|
short yylen[] = { 2,
|
|
0, 2, 2, 1, 2, 0, 1, 3, 2, 0,
|
|
1, 2, 3, 2, 3, 1, 2, 1, 1, 1,
|
|
1, 1, 1, 1, 1, 1, 4, 0, 0, 0,
|
|
0, 13, 0, 7, 0, 0, 7, 3, 0, 3,
|
|
1, 3, 1, 1, 0, 0, 3, 0, 12, 0,
|
|
1, 0, 3, 3, 1, 3, 3, 5, 0, 1,
|
|
1, 3, 3, 5, 0, 1, 0, 1, 0, 4,
|
|
0, 4, 0, 4, 2, 3, 3, 3, 3, 3,
|
|
2, 1, 1, 3, 4, 2, 2, 4, 4, 4,
|
|
3, 1, 4, 1, 1, 1, 1,
|
|
};
|
|
short yydefred[] = { 1,
|
|
0, 0, 0, 21, 0, 83, 0, 0, 22, 24,
|
|
0, 0, 28, 0, 35, 0, 0, 94, 95, 0,
|
|
18, 25, 97, 23, 39, 19, 0, 0, 0, 0,
|
|
0, 2, 0, 16, 4, 7, 5, 17, 0, 0,
|
|
0, 0, 96, 86, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 81, 0, 0, 0, 11, 71,
|
|
73, 0, 0, 0, 0, 0, 69, 87, 3, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 91, 43, 0, 40, 0, 84,
|
|
0, 0, 38, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 8, 0, 85, 0, 93, 0, 0, 0, 88,
|
|
27, 0, 0, 33, 0, 89, 90, 0, 13, 15,
|
|
0, 0, 0, 62, 0, 0, 0, 0, 0, 29,
|
|
0, 0, 42, 0, 56, 0, 0, 0, 0, 0,
|
|
64, 0, 0, 0, 46, 34, 37, 0, 48, 58,
|
|
30, 0, 0, 0, 0, 47, 53, 54, 0, 0,
|
|
0, 31, 49, 0, 32,
|
|
};
|
|
short yydgoto[] = { 1,
|
|
30, 79, 31, 113, 108, 149, 109, 73, 74, 32,
|
|
33, 58, 34, 35, 59, 48, 138, 155, 164, 131,
|
|
146, 50, 132, 88, 54, 89, 152, 154, 101, 94,
|
|
95,
|
|
};
|
|
short yysindex[] = { 0,
|
|
-7, 58, 212, 0, -22, 0, -233, -241, 0, 0,
|
|
-8, -5, 0, -4, 0, 2, 4, 0, 0, 9,
|
|
0, 0, 0, 0, 0, 0, 212, 212, 91, 725,
|
|
-240, 0, -29, 0, 0, 0, 0, 0, 84, 245,
|
|
212, -57, 0, 0, 10, 212, 212, 14, 212, 16,
|
|
212, 212, 23, 156, 0, 549, 127, -52, 0, 0,
|
|
0, 212, 212, 212, 212, 212, 0, 0, 0, 91,
|
|
-17, 725, 24, -3, 578, -205, 562, 725, 27, 212,
|
|
606, 212, 669, 716, 0, 0, 725, 0, 19, 0,
|
|
91, 127, 0, 212, 212, -36, -39, -91, -91, -36,
|
|
212, 0, 166, 0, 277, 0, -21, 36, 40, 0,
|
|
0, 725, 28, 0, 725, 0, 0, 156, 0, 0,
|
|
84, 540, -39, 0, -9, 725, -2, -37, -174, 0,
|
|
127, 48, 0, 346, 0, -167, 3, 212, -185, 127,
|
|
0, -188, 6, 37, 0, 0, 0, -205, 0, 0,
|
|
0, 127, -42, 91, 212, 0, 0, 0, -20, 54,
|
|
26, 0, 0, 127, 0,
|
|
};
|
|
short yyrindex[] = { 0,
|
|
-16, 0, 0, 0, 409, 0, 0, 0, 0, 0,
|
|
0, -58, 0, 0, 0, 0, 426, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, -50, 46,
|
|
470, 0, 0, 0, 0, 0, 0, 0, 661, 56,
|
|
0, 525, 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, 0, -6,
|
|
705, 7, 0, 60, 0, 61, 0, 63, 0, 49,
|
|
0, 0, 0, 0, 0, 0, 17, 0, 78, 0,
|
|
-47, -45, 0, 0, 0, 537, 440, 620, 637, 594,
|
|
0, 0, 0, 0, 0, 0, -33, 0, 66, 0,
|
|
0, -19, 0, 0, 68, 0, 0, 0, 0, 0,
|
|
667, 680, 508, 0, 705, 18, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, -31, 49, -44, 0,
|
|
0, -40, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 1, 69, 0, 0, 0, 0, 0,
|
|
13, 0, 0, 0, 0,
|
|
};
|
|
short yygindex[] = { 0,
|
|
958, 0, 104, -118, 0, 0, -35, 0, 0, 0,
|
|
0, -34, 22, 0, 15, 0, 0, 0, 0, 0,
|
|
0, 0, 0, -1, 0, 0, 0, 0, 0, 0,
|
|
0,
|
|
};
|
|
#define YYTABLESIZE 1113
|
|
short yytable[] = { 52,
|
|
26, 129, 66, 64, 52, 65, 92, 55, 10, 57,
|
|
55, 12, 57, 14, 45, 36, 158, 40, 52, 144,
|
|
45, 66, 40, 38, 67, 55, 68, 57, 42, 70,
|
|
40, 46, 28, 41, 47, 49, 160, 27, 92, 66,
|
|
105, 51, 6, 52, 43, 18, 19, 61, 53, 76,
|
|
61, 23, 9, 80, 66, 82, 107, 66, 63, 10,
|
|
44, 63, 118, 85, 104, 28, 26, 111, 41, 127,
|
|
27, 12, 93, 103, 10, 44, 128, 12, 38, 14,
|
|
45, 134, 52, 129, 102, 136, 130, 137, 140, 142,
|
|
135, 145, 148, 143, 162, 151, 59, 28, 150, 67,
|
|
60, 50, 27, 68, 20, 119, 51, 65, 36, 65,
|
|
44, 0, 153, 120, 0, 29, 133, 0, 0, 159,
|
|
0, 0, 0, 0, 0, 0, 64, 0, 65, 0,
|
|
28, 0, 0, 0, 0, 27, 41, 0, 0, 0,
|
|
0, 44, 0, 0, 0, 0, 0, 0, 29, 0,
|
|
163, 0, 139, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 147, 0, 0, 0, 0, 28, 0, 0, 0,
|
|
20, 27, 62, 156, 0, 119, 0, 66, 0, 0,
|
|
29, 0, 0, 0, 0, 165, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 28, 0, 0, 26, 0,
|
|
27, 0, 41, 0, 91, 28, 10, 0, 0, 12,
|
|
27, 14, 45, 29, 157, 52, 52, 0, 26, 52,
|
|
52, 52, 52, 55, 62, 57, 52, 69, 52, 52,
|
|
52, 52, 52, 52, 52, 52, 161, 52, 52, 52,
|
|
6, 52, 52, 52, 52, 52, 52, 52, 2, 29,
|
|
9, 28, 3, 4, 5, 6, 27, 10, 124, 7,
|
|
8, 9, 10, 11, 12, 13, 14, 15, 16, 12,
|
|
17, 18, 19, 44, 20, 21, 22, 23, 24, 25,
|
|
26, 57, 0, 0, 28, 3, 4, 5, 6, 27,
|
|
0, 0, 7, 44, 9, 10, 11, 12, 13, 14,
|
|
15, 16, 20, 17, 18, 19, 0, 20, 21, 22,
|
|
23, 24, 25, 26, 37, 0, 28, 3, 4, 5,
|
|
6, 27, 20, 0, 7, 0, 9, 10, 11, 12,
|
|
13, 14, 15, 16, 41, 17, 18, 19, 0, 20,
|
|
21, 22, 23, 24, 25, 26, 57, 62, 0, 63,
|
|
3, 4, 5, 6, 41, 0, 0, 7, 0, 9,
|
|
10, 11, 12, 13, 14, 15, 16, 0, 17, 18,
|
|
19, 0, 20, 21, 22, 23, 24, 25, 26, 0,
|
|
0, 0, 0, 0, 0, 28, 3, 4, 5, 6,
|
|
27, 0, 0, 7, 0, 9, 10, 11, 12, 13,
|
|
14, 15, 16, 0, 17, 18, 19, 0, 20, 21,
|
|
22, 23, 24, 25, 26, 3, 86, 5, 6, 0,
|
|
0, 0, 7, 0, 0, 3, 11, 5, 6, 0,
|
|
0, 16, 7, 17, 18, 19, 11, 20, 141, 0,
|
|
23, 16, 0, 17, 18, 19, 0, 20, 0, 92,
|
|
23, 92, 92, 92, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 96, 92, 96, 96,
|
|
96, 3, 0, 5, 6, 0, 0, 0, 7, 0,
|
|
76, 0, 11, 76, 96, 0, 0, 16, 0, 17,
|
|
18, 19, 0, 20, 0, 0, 23, 0, 76, 0,
|
|
0, 92, 92, 0, 3, 0, 71, 6, 0, 0,
|
|
82, 7, 82, 82, 82, 11, 0, 0, 96, 96,
|
|
16, 0, 17, 18, 19, 0, 20, 0, 82, 23,
|
|
0, 0, 76, 92, 0, 0, 3, 0, 125, 6,
|
|
0, 0, 0, 7, 0, 0, 0, 11, 70, 0,
|
|
96, 70, 16, 0, 17, 18, 19, 0, 20, 0,
|
|
0, 23, 82, 82, 76, 92, 70, 92, 92, 92,
|
|
0, 0, 0, 0, 0, 0, 0, 79, 0, 79,
|
|
79, 79, 64, 92, 65, 0, 0, 0, 0, 90,
|
|
0, 64, 0, 65, 82, 79, 0, 0, 0, 0,
|
|
70, 0, 110, 0, 64, 3, 65, 5, 6, 0,
|
|
0, 0, 7, 0, 0, 0, 11, 92, 92, 0,
|
|
64, 16, 65, 17, 18, 19, 0, 20, 0, 79,
|
|
23, 0, 70, 66, 80, 0, 80, 80, 80, 0,
|
|
0, 0, 66, 0, 0, 0, 114, 0, 64, 92,
|
|
65, 0, 80, 0, 0, 66, 0, 0, 0, 0,
|
|
77, 79, 77, 77, 77, 92, 92, 92, 0, 0,
|
|
106, 66, 92, 92, 92, 92, 0, 78, 77, 78,
|
|
78, 78, 96, 96, 96, 92, 80, 0, 0, 96,
|
|
96, 96, 96, 0, 0, 78, 76, 76, 76, 66,
|
|
0, 75, 96, 0, 75, 76, 0, 72, 0, 116,
|
|
72, 64, 77, 65, 0, 0, 76, 0, 80, 75,
|
|
74, 0, 0, 74, 0, 72, 82, 82, 82, 78,
|
|
0, 0, 0, 82, 0, 82, 0, 0, 74, 0,
|
|
0, 0, 0, 0, 77, 92, 82, 92, 92, 92,
|
|
0, 0, 0, 75, 0, 0, 117, 0, 64, 72,
|
|
65, 78, 66, 0, 70, 70, 70, 64, 0, 65,
|
|
0, 0, 74, 70, 0, 0, 0, 0, 0, 0,
|
|
0, 92, 92, 92, 70, 75, 0, 0, 92, 0,
|
|
92, 72, 0, 79, 79, 79, 0, 60, 92, 0,
|
|
79, 92, 79, 62, 74, 63, 60, 61, 0, 66,
|
|
0, 0, 62, 79, 63, 0, 0, 0, 66, 60,
|
|
61, 0, 0, 0, 0, 62, 0, 63, 0, 0,
|
|
0, 0, 0, 0, 0, 60, 61, 0, 0, 0,
|
|
0, 62, 0, 63, 0, 0, 0, 0, 0, 0,
|
|
80, 80, 80, 0, 0, 0, 0, 80, 0, 80,
|
|
0, 0, 0, 60, 61, 0, 0, 0, 0, 62,
|
|
80, 63, 0, 0, 0, 0, 77, 77, 77, 0,
|
|
0, 0, 0, 0, 0, 77, 0, 0, 0, 0,
|
|
0, 0, 0, 78, 78, 78, 77, 0, 0, 0,
|
|
0, 0, 78, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 78, 0, 0, 0, 75, 75, 75,
|
|
0, 0, 0, 72, 72, 72, 60, 61, 0, 0,
|
|
0, 0, 62, 0, 63, 0, 74, 75, 74, 0,
|
|
0, 0, 0, 72, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 74, 0, 0, 0,
|
|
39, 0, 92, 92, 0, 0, 0, 0, 92, 92,
|
|
92, 92, 0, 60, 61, 0, 0, 0, 0, 62,
|
|
0, 63, 60, 61, 55, 56, 0, 0, 62, 0,
|
|
63, 0, 0, 0, 0, 0, 0, 72, 75, 0,
|
|
0, 0, 0, 77, 78, 0, 81, 0, 83, 84,
|
|
0, 87, 0, 0, 0, 0, 0, 0, 0, 96,
|
|
97, 98, 99, 100, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 112, 0, 115,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 121, 122, 0, 0, 0, 0, 0, 123, 0,
|
|
75, 0, 126, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 87, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 75, 0, 0, 0, 112, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 112,
|
|
};
|
|
short yycheck[] = { 40,
|
|
59, 44, 94, 43, 45, 45, 59, 41, 59, 41,
|
|
44, 59, 44, 59, 59, 1, 59, 40, 59, 138,
|
|
262, 41, 40, 2, 265, 59, 267, 59, 262, 59,
|
|
40, 40, 40, 91, 40, 40, 155, 45, 59, 59,
|
|
44, 40, 59, 40, 278, 279, 280, 41, 40, 40,
|
|
44, 285, 59, 40, 94, 40, 262, 94, 41, 59,
|
|
44, 44, 44, 41, 41, 40, 125, 41, 91, 91,
|
|
45, 59, 125, 91, 125, 59, 41, 125, 57, 125,
|
|
125, 91, 123, 44, 70, 123, 59, 262, 41, 257,
|
|
93, 277, 281, 91, 41, 59, 41, 40, 93, 41,
|
|
41, 41, 45, 41, 59, 91, 41, 59, 41, 41,
|
|
7, -1, 148, 92, -1, 123, 118, -1, -1, 154,
|
|
-1, -1, -1, -1, -1, -1, 43, -1, 45, -1,
|
|
40, -1, -1, -1, -1, 45, 59, -1, -1, -1,
|
|
-1, 125, -1, -1, -1, -1, -1, -1, 123, -1,
|
|
125, -1, 131, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, 140, -1, -1, -1, -1, 40, -1, -1, -1,
|
|
125, 45, 264, 152, -1, 161, -1, 94, -1, -1,
|
|
123, -1, -1, -1, -1, 164, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, 40, -1, -1, 257, -1,
|
|
45, -1, 125, -1, 257, 40, 257, -1, -1, 257,
|
|
45, 257, 257, 123, 257, 256, 257, -1, 277, 260,
|
|
261, 262, 263, 257, 264, 257, 267, 257, 269, 270,
|
|
271, 272, 273, 274, 275, 276, 257, 278, 279, 280,
|
|
257, 282, 283, 284, 285, 286, 287, 288, 256, 123,
|
|
257, 40, 260, 261, 262, 263, 45, 257, 93, 267,
|
|
268, 269, 270, 271, 272, 273, 274, 275, 276, 257,
|
|
278, 279, 280, 257, 282, 283, 284, 285, 286, 287,
|
|
288, 256, -1, -1, 40, 260, 261, 262, 263, 45,
|
|
-1, -1, 267, 277, 269, 270, 271, 272, 273, 274,
|
|
275, 276, 257, 278, 279, 280, -1, 282, 283, 284,
|
|
285, 286, 287, 288, 257, -1, 40, 260, 261, 262,
|
|
263, 45, 277, -1, 267, -1, 269, 270, 271, 272,
|
|
273, 274, 275, 276, 257, 278, 279, 280, -1, 282,
|
|
283, 284, 285, 286, 287, 288, 256, 264, -1, 266,
|
|
260, 261, 262, 263, 277, -1, -1, 267, -1, 269,
|
|
270, 271, 272, 273, 274, 275, 276, -1, 278, 279,
|
|
280, -1, 282, 283, 284, 285, 286, 287, 288, -1,
|
|
-1, -1, -1, -1, -1, 40, 260, 261, 262, 263,
|
|
45, -1, -1, 267, -1, 269, 270, 271, 272, 273,
|
|
274, 275, 276, -1, 278, 279, 280, -1, 282, 283,
|
|
284, 285, 286, 287, 288, 260, 261, 262, 263, -1,
|
|
-1, -1, 267, -1, -1, 260, 271, 262, 263, -1,
|
|
-1, 276, 267, 278, 279, 280, 271, 282, 93, -1,
|
|
285, 276, -1, 278, 279, 280, -1, 282, -1, 41,
|
|
285, 43, 44, 45, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, -1, 41, 59, 43, 44,
|
|
45, 260, -1, 262, 263, -1, -1, -1, 267, -1,
|
|
41, -1, 271, 44, 59, -1, -1, 276, -1, 278,
|
|
279, 280, -1, 282, -1, -1, 285, -1, 59, -1,
|
|
-1, 93, 94, -1, 260, -1, 262, 263, -1, -1,
|
|
41, 267, 43, 44, 45, 271, -1, -1, 93, 94,
|
|
276, -1, 278, 279, 280, -1, 282, -1, 59, 285,
|
|
-1, -1, 93, 125, -1, -1, 260, -1, 262, 263,
|
|
-1, -1, -1, 267, -1, -1, -1, 271, 41, -1,
|
|
125, 44, 276, -1, 278, 279, 280, -1, 282, -1,
|
|
-1, 285, 93, 94, 125, 41, 59, 43, 44, 45,
|
|
-1, -1, -1, -1, -1, -1, -1, 41, -1, 43,
|
|
44, 45, 43, 59, 45, -1, -1, -1, -1, 41,
|
|
-1, 43, -1, 45, 125, 59, -1, -1, -1, -1,
|
|
93, -1, 41, -1, 43, 260, 45, 262, 263, -1,
|
|
-1, -1, 267, -1, -1, -1, 271, 93, 94, -1,
|
|
43, 276, 45, 278, 279, 280, -1, 282, -1, 93,
|
|
285, -1, 125, 94, 41, -1, 43, 44, 45, -1,
|
|
-1, -1, 94, -1, -1, -1, 41, -1, 43, 125,
|
|
45, -1, 59, -1, -1, 94, -1, -1, -1, -1,
|
|
41, 125, 43, 44, 45, 257, 258, 259, -1, -1,
|
|
93, 94, 264, 265, 266, 267, -1, 41, 59, 43,
|
|
44, 45, 257, 258, 259, 277, 93, -1, -1, 264,
|
|
265, 266, 267, -1, -1, 59, 257, 258, 259, 94,
|
|
-1, 41, 277, -1, 44, 266, -1, 41, -1, 41,
|
|
44, 43, 93, 45, -1, -1, 277, -1, 125, 59,
|
|
41, -1, -1, 44, -1, 59, 257, 258, 259, 93,
|
|
-1, -1, -1, 264, -1, 266, -1, -1, 59, -1,
|
|
-1, -1, -1, -1, 125, 41, 277, 43, 44, 45,
|
|
-1, -1, -1, 93, -1, -1, 41, -1, 43, 93,
|
|
45, 125, 94, -1, 257, 258, 259, 43, -1, 45,
|
|
-1, -1, 93, 266, -1, -1, -1, -1, -1, -1,
|
|
-1, 257, 258, 259, 277, 125, -1, -1, 264, -1,
|
|
266, 125, -1, 257, 258, 259, -1, 258, 94, -1,
|
|
264, 277, 266, 264, 125, 266, 258, 259, -1, 94,
|
|
-1, -1, 264, 277, 266, -1, -1, -1, 94, 258,
|
|
259, -1, -1, -1, -1, 264, -1, 266, -1, -1,
|
|
-1, -1, -1, -1, -1, 258, 259, -1, -1, -1,
|
|
-1, 264, -1, 266, -1, -1, -1, -1, -1, -1,
|
|
257, 258, 259, -1, -1, -1, -1, 264, -1, 266,
|
|
-1, -1, -1, 258, 259, -1, -1, -1, -1, 264,
|
|
277, 266, -1, -1, -1, -1, 257, 258, 259, -1,
|
|
-1, -1, -1, -1, -1, 266, -1, -1, -1, -1,
|
|
-1, -1, -1, 257, 258, 259, 277, -1, -1, -1,
|
|
-1, -1, 266, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, -1, 277, -1, -1, -1, 257, 258, 259,
|
|
-1, -1, -1, 257, 258, 259, 258, 259, -1, -1,
|
|
-1, -1, 264, -1, 266, -1, 257, 277, 259, -1,
|
|
-1, -1, -1, 277, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, -1, 277, -1, -1, -1,
|
|
3, -1, 258, 259, -1, -1, -1, -1, 264, 265,
|
|
266, 267, -1, 258, 259, -1, -1, -1, -1, 264,
|
|
-1, 266, 258, 259, 27, 28, -1, -1, 264, -1,
|
|
266, -1, -1, -1, -1, -1, -1, 40, 41, -1,
|
|
-1, -1, -1, 46, 47, -1, 49, -1, 51, 52,
|
|
-1, 54, -1, -1, -1, -1, -1, -1, -1, 62,
|
|
63, 64, 65, 66, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, -1, -1, 80, -1, 82,
|
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, 94, 95, -1, -1, -1, -1, -1, 101, -1,
|
|
103, -1, 105, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, 118, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, 134, -1, -1, -1, 138, -1, -1, -1, -1,
|
|
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
|
|
-1, -1, 155,
|
|
};
|
|
#define YYFINAL 1
|
|
#ifndef YYDEBUG
|
|
#define YYDEBUG 0
|
|
#endif
|
|
#define YYMAXTOKEN 289
|
|
#if YYDEBUG
|
|
char *yyname[] = {
|
|
"end-of-file",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,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,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,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,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
|
0,0,0,0,0,"NEWLINE","AND","OR","NOT","STRING","NAME","NUMBER","MUL_OP",
|
|
"ASSIGN_OP","REL_OP","INCR_DECR","Define","Break","Quit","Length","Return",
|
|
"For","If","While","Sqrt","Else","Scale","Ibase","Obase","Auto","Read",
|
|
"Warranty","Halt","Last","Continue","Print","Limits","UNARY_MINUS",
|
|
};
|
|
char *yyrule[] = {
|
|
"$accept : program",
|
|
"program :",
|
|
"program : program input_item",
|
|
"input_item : semicolon_list NEWLINE",
|
|
"input_item : function",
|
|
"input_item : error NEWLINE",
|
|
"semicolon_list :",
|
|
"semicolon_list : statement_or_error",
|
|
"semicolon_list : semicolon_list ';' statement_or_error",
|
|
"semicolon_list : semicolon_list ';'",
|
|
"statement_list :",
|
|
"statement_list : statement_or_error",
|
|
"statement_list : statement_list NEWLINE",
|
|
"statement_list : statement_list NEWLINE statement_or_error",
|
|
"statement_list : statement_list ';'",
|
|
"statement_list : statement_list ';' statement",
|
|
"statement_or_error : statement",
|
|
"statement_or_error : error statement",
|
|
"statement : Warranty",
|
|
"statement : Limits",
|
|
"statement : expression",
|
|
"statement : STRING",
|
|
"statement : Break",
|
|
"statement : Continue",
|
|
"statement : Quit",
|
|
"statement : Halt",
|
|
"statement : Return",
|
|
"statement : Return '(' return_expression ')'",
|
|
"$$1 :",
|
|
"$$2 :",
|
|
"$$3 :",
|
|
"$$4 :",
|
|
"statement : For $$1 '(' opt_expression ';' $$2 opt_expression ';' $$3 opt_expression ')' $$4 statement",
|
|
"$$5 :",
|
|
"statement : If '(' expression ')' $$5 statement opt_else",
|
|
"$$6 :",
|
|
"$$7 :",
|
|
"statement : While $$6 '(' expression $$7 ')' statement",
|
|
"statement : '{' statement_list '}'",
|
|
"$$8 :",
|
|
"statement : Print $$8 print_list",
|
|
"print_list : print_element",
|
|
"print_list : print_element ',' print_list",
|
|
"print_element : STRING",
|
|
"print_element : expression",
|
|
"opt_else :",
|
|
"$$9 :",
|
|
"opt_else : Else $$9 statement",
|
|
"$$10 :",
|
|
"function : Define NAME '(' opt_parameter_list ')' '{' NEWLINE opt_auto_define_list $$10 statement_list NEWLINE '}'",
|
|
"opt_parameter_list :",
|
|
"opt_parameter_list : define_list",
|
|
"opt_auto_define_list :",
|
|
"opt_auto_define_list : Auto define_list NEWLINE",
|
|
"opt_auto_define_list : Auto define_list ';'",
|
|
"define_list : NAME",
|
|
"define_list : NAME '[' ']'",
|
|
"define_list : define_list ',' NAME",
|
|
"define_list : define_list ',' NAME '[' ']'",
|
|
"opt_argument_list :",
|
|
"opt_argument_list : argument_list",
|
|
"argument_list : expression",
|
|
"argument_list : NAME '[' ']'",
|
|
"argument_list : argument_list ',' expression",
|
|
"argument_list : argument_list ',' NAME '[' ']'",
|
|
"opt_expression :",
|
|
"opt_expression : expression",
|
|
"return_expression :",
|
|
"return_expression : expression",
|
|
"$$11 :",
|
|
"expression : named_expression ASSIGN_OP $$11 expression",
|
|
"$$12 :",
|
|
"expression : expression AND $$12 expression",
|
|
"$$13 :",
|
|
"expression : expression OR $$13 expression",
|
|
"expression : NOT expression",
|
|
"expression : expression REL_OP expression",
|
|
"expression : expression '+' expression",
|
|
"expression : expression '-' expression",
|
|
"expression : expression MUL_OP expression",
|
|
"expression : expression '^' expression",
|
|
"expression : '-' expression",
|
|
"expression : named_expression",
|
|
"expression : NUMBER",
|
|
"expression : '(' expression ')'",
|
|
"expression : NAME '(' opt_argument_list ')'",
|
|
"expression : INCR_DECR named_expression",
|
|
"expression : named_expression INCR_DECR",
|
|
"expression : Length '(' expression ')'",
|
|
"expression : Sqrt '(' expression ')'",
|
|
"expression : Scale '(' expression ')'",
|
|
"expression : Read '(' ')'",
|
|
"named_expression : NAME",
|
|
"named_expression : NAME '[' expression ']'",
|
|
"named_expression : Ibase",
|
|
"named_expression : Obase",
|
|
"named_expression : Scale",
|
|
"named_expression : Last",
|
|
};
|
|
#endif
|
|
#ifdef YYSTACKSIZE
|
|
#undef YYMAXDEPTH
|
|
#define YYMAXDEPTH YYSTACKSIZE
|
|
#else
|
|
#ifdef YYMAXDEPTH
|
|
#define YYSTACKSIZE YYMAXDEPTH
|
|
#else
|
|
#define YYSTACKSIZE 500
|
|
#define YYMAXDEPTH 500
|
|
#endif
|
|
#endif
|
|
int yydebug;
|
|
int yynerrs;
|
|
int yyerrflag;
|
|
int yychar;
|
|
short *yyssp;
|
|
YYSTYPE *yyvsp;
|
|
YYSTYPE yyval;
|
|
YYSTYPE yylval;
|
|
short yyss[YYSTACKSIZE];
|
|
YYSTYPE yyvs[YYSTACKSIZE];
|
|
#define yystacksize YYSTACKSIZE
|
|
#define YYABORT goto yyabort
|
|
#define YYREJECT goto yyabort
|
|
#define YYACCEPT goto yyaccept
|
|
#define YYERROR goto yyerrlab
|
|
int
|
|
yyparse()
|
|
{
|
|
register int yym, yyn, yystate;
|
|
#if YYDEBUG
|
|
register char *yys;
|
|
extern char *getenv();
|
|
|
|
if (yys = getenv("YYDEBUG"))
|
|
{
|
|
yyn = *yys;
|
|
if (yyn >= '0' && yyn <= '9')
|
|
yydebug = yyn - '0';
|
|
}
|
|
#endif
|
|
|
|
yynerrs = 0;
|
|
yyerrflag = 0;
|
|
yychar = (-1);
|
|
|
|
yyssp = yyss;
|
|
yyvsp = yyvs;
|
|
*yyssp = yystate = 0;
|
|
|
|
yyloop:
|
|
if (yyn = yydefred[yystate]) goto yyreduce;
|
|
if (yychar < 0)
|
|
{
|
|
if ((yychar = yylex()) < 0) yychar = 0;
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
{
|
|
yys = 0;
|
|
if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
|
|
if (!yys) yys = "illegal-symbol";
|
|
printf("%sdebug: state %d, reading %d (%s)\n",
|
|
YYPREFIX, yystate, yychar, yys);
|
|
}
|
|
#endif
|
|
}
|
|
if ((yyn = yysindex[yystate]) && (yyn += yychar) >= 0 &&
|
|
yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
|
|
{
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: state %d, shifting to state %d\n",
|
|
YYPREFIX, yystate, yytable[yyn]);
|
|
#endif
|
|
if (yyssp >= yyss + yystacksize - 1)
|
|
{
|
|
goto yyoverflow;
|
|
}
|
|
*++yyssp = yystate = yytable[yyn];
|
|
*++yyvsp = yylval;
|
|
yychar = (-1);
|
|
if (yyerrflag > 0) --yyerrflag;
|
|
goto yyloop;
|
|
}
|
|
if ((yyn = yyrindex[yystate]) && (yyn += yychar) >= 0 &&
|
|
yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
|
|
{
|
|
yyn = yytable[yyn];
|
|
goto yyreduce;
|
|
}
|
|
if (yyerrflag) goto yyinrecovery;
|
|
#ifdef lint
|
|
goto yynewerror;
|
|
#endif
|
|
yynewerror:
|
|
yyerror("syntax error");
|
|
#ifdef lint
|
|
goto yyerrlab;
|
|
#endif
|
|
yyerrlab:
|
|
++yynerrs;
|
|
yyinrecovery:
|
|
if (yyerrflag < 3)
|
|
{
|
|
yyerrflag = 3;
|
|
for (;;)
|
|
{
|
|
if ((yyn = yysindex[*yyssp]) && (yyn += YYERRCODE) >= 0 &&
|
|
yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE)
|
|
{
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: state %d, error recovery shifting\
|
|
to state %d\n", YYPREFIX, *yyssp, yytable[yyn]);
|
|
#endif
|
|
if (yyssp >= yyss + yystacksize - 1)
|
|
{
|
|
goto yyoverflow;
|
|
}
|
|
*++yyssp = yystate = yytable[yyn];
|
|
*++yyvsp = yylval;
|
|
goto yyloop;
|
|
}
|
|
else
|
|
{
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: error recovery discarding state %d\n",
|
|
YYPREFIX, *yyssp);
|
|
#endif
|
|
if (yyssp <= yyss) goto yyabort;
|
|
--yyssp;
|
|
--yyvsp;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (yychar == 0) goto yyabort;
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
{
|
|
yys = 0;
|
|
if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
|
|
if (!yys) yys = "illegal-symbol";
|
|
printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
|
|
YYPREFIX, yystate, yychar, yys);
|
|
}
|
|
#endif
|
|
yychar = (-1);
|
|
goto yyloop;
|
|
}
|
|
yyreduce:
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: state %d, reducing by rule %d (%s)\n",
|
|
YYPREFIX, yystate, yyn, yyrule[yyn]);
|
|
#endif
|
|
yym = yylen[yyn];
|
|
yyval = yyvsp[1-yym];
|
|
switch (yyn)
|
|
{
|
|
case 1:
|
|
#line 106 "bc.y"
|
|
{
|
|
yyval.i_value = 0;
|
|
if (interactive)
|
|
{
|
|
printf ("%s\n", BC_VERSION);
|
|
welcome ();
|
|
}
|
|
}
|
|
break;
|
|
case 3:
|
|
#line 117 "bc.y"
|
|
{ run_code (); }
|
|
break;
|
|
case 4:
|
|
#line 119 "bc.y"
|
|
{ run_code (); }
|
|
break;
|
|
case 5:
|
|
#line 121 "bc.y"
|
|
{
|
|
yyerrok;
|
|
init_gen ();
|
|
}
|
|
break;
|
|
case 6:
|
|
#line 127 "bc.y"
|
|
{ yyval.i_value = 0; }
|
|
break;
|
|
case 10:
|
|
#line 133 "bc.y"
|
|
{ yyval.i_value = 0; }
|
|
break;
|
|
case 17:
|
|
#line 142 "bc.y"
|
|
{ yyval.i_value = yyvsp[0].i_value; }
|
|
break;
|
|
case 18:
|
|
#line 145 "bc.y"
|
|
{ warranty (""); }
|
|
break;
|
|
case 19:
|
|
#line 147 "bc.y"
|
|
{ limits (); }
|
|
break;
|
|
case 20:
|
|
#line 149 "bc.y"
|
|
{
|
|
if (yyvsp[0].i_value & 2)
|
|
warn ("comparison in expression");
|
|
if (yyvsp[0].i_value & 1)
|
|
generate ("W");
|
|
else
|
|
generate ("p");
|
|
}
|
|
break;
|
|
case 21:
|
|
#line 158 "bc.y"
|
|
{
|
|
yyval.i_value = 0;
|
|
generate ("w");
|
|
generate (yyvsp[0].s_value);
|
|
free (yyvsp[0].s_value);
|
|
}
|
|
break;
|
|
case 22:
|
|
#line 165 "bc.y"
|
|
{
|
|
if (break_label == 0)
|
|
yyerror ("Break outside a for/while");
|
|
else
|
|
{
|
|
sprintf (genstr, "J%1d:", break_label);
|
|
generate (genstr);
|
|
}
|
|
}
|
|
break;
|
|
case 23:
|
|
#line 175 "bc.y"
|
|
{
|
|
warn ("Continue statement");
|
|
if (continue_label == 0)
|
|
yyerror ("Continue outside a for");
|
|
else
|
|
{
|
|
sprintf (genstr, "J%1d:", continue_label);
|
|
generate (genstr);
|
|
}
|
|
}
|
|
break;
|
|
case 24:
|
|
#line 186 "bc.y"
|
|
{ exit (0); }
|
|
break;
|
|
case 25:
|
|
#line 188 "bc.y"
|
|
{ generate ("h"); }
|
|
break;
|
|
case 26:
|
|
#line 190 "bc.y"
|
|
{ generate ("0R"); }
|
|
break;
|
|
case 27:
|
|
#line 192 "bc.y"
|
|
{ generate ("R"); }
|
|
break;
|
|
case 28:
|
|
#line 194 "bc.y"
|
|
{
|
|
yyvsp[0].i_value = break_label;
|
|
break_label = next_label++;
|
|
}
|
|
break;
|
|
case 29:
|
|
#line 199 "bc.y"
|
|
{
|
|
if (yyvsp[-1].i_value > 1)
|
|
warn ("Comparison in first for expression");
|
|
yyvsp[-1].i_value = next_label++;
|
|
if (yyvsp[-1].i_value < 0)
|
|
sprintf (genstr, "N%1d:", yyvsp[-1].i_value);
|
|
else
|
|
sprintf (genstr, "pN%1d:", yyvsp[-1].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 30:
|
|
#line 210 "bc.y"
|
|
{
|
|
if (yyvsp[-1].i_value < 0) generate ("1");
|
|
yyvsp[-1].i_value = next_label++;
|
|
sprintf (genstr, "B%1d:J%1d:", yyvsp[-1].i_value, break_label);
|
|
generate (genstr);
|
|
yyval.i_value = continue_label;
|
|
continue_label = next_label++;
|
|
sprintf (genstr, "N%1d:", continue_label);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 31:
|
|
#line 221 "bc.y"
|
|
{
|
|
if (yyvsp[-1].i_value > 1)
|
|
warn ("Comparison in third for expression");
|
|
if (yyvsp[-1].i_value < 0)
|
|
sprintf (genstr, "J%1d:N%1d:", yyvsp[-7].i_value, yyvsp[-4].i_value);
|
|
else
|
|
sprintf (genstr, "pJ%1d:N%1d:", yyvsp[-7].i_value, yyvsp[-4].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 32:
|
|
#line 231 "bc.y"
|
|
{
|
|
sprintf (genstr, "J%1d:N%1d:",
|
|
continue_label, break_label);
|
|
generate (genstr);
|
|
break_label = yyvsp[-12].i_value;
|
|
continue_label = yyvsp[-4].i_value;
|
|
}
|
|
break;
|
|
case 33:
|
|
#line 239 "bc.y"
|
|
{
|
|
yyvsp[-1].i_value = if_label;
|
|
if_label = next_label++;
|
|
sprintf (genstr, "Z%1d:", if_label);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 34:
|
|
#line 246 "bc.y"
|
|
{
|
|
sprintf (genstr, "N%1d:", if_label);
|
|
generate (genstr);
|
|
if_label = yyvsp[-4].i_value;
|
|
}
|
|
break;
|
|
case 35:
|
|
#line 252 "bc.y"
|
|
{
|
|
yyvsp[0].i_value = next_label++;
|
|
sprintf (genstr, "N%1d:", yyvsp[0].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 36:
|
|
#line 258 "bc.y"
|
|
{
|
|
yyvsp[0].i_value = break_label;
|
|
break_label = next_label++;
|
|
sprintf (genstr, "Z%1d:", break_label);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 37:
|
|
#line 265 "bc.y"
|
|
{
|
|
sprintf (genstr, "J%1d:N%1d:", yyvsp[-6].i_value, break_label);
|
|
generate (genstr);
|
|
break_label = yyvsp[-3].i_value;
|
|
}
|
|
break;
|
|
case 38:
|
|
#line 271 "bc.y"
|
|
{ yyval.i_value = 0; }
|
|
break;
|
|
case 39:
|
|
#line 273 "bc.y"
|
|
{ warn ("print statement"); }
|
|
break;
|
|
case 43:
|
|
#line 280 "bc.y"
|
|
{
|
|
generate ("O");
|
|
generate (yyvsp[0].s_value);
|
|
free (yyvsp[0].s_value);
|
|
}
|
|
break;
|
|
case 44:
|
|
#line 286 "bc.y"
|
|
{ generate ("P"); }
|
|
break;
|
|
case 46:
|
|
#line 290 "bc.y"
|
|
{
|
|
warn ("else clause in if statement");
|
|
yyvsp[0].i_value = next_label++;
|
|
sprintf (genstr, "J%d:N%1d:", yyvsp[0].i_value, if_label);
|
|
generate (genstr);
|
|
if_label = yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 48:
|
|
#line 300 "bc.y"
|
|
{
|
|
/* Check auto list against parameter list? */
|
|
check_params (yyvsp[-4].a_value,yyvsp[0].a_value);
|
|
sprintf (genstr, "F%d,%s.%s[", lookup(yyvsp[-6].s_value,FUNCT),
|
|
arg_str (yyvsp[-4].a_value,TRUE), arg_str (yyvsp[0].a_value,TRUE));
|
|
generate (genstr);
|
|
free_args (yyvsp[-4].a_value);
|
|
free_args (yyvsp[0].a_value);
|
|
yyvsp[-7].i_value = next_label;
|
|
next_label = 0;
|
|
}
|
|
break;
|
|
case 49:
|
|
#line 312 "bc.y"
|
|
{
|
|
generate ("0R]");
|
|
next_label = yyvsp[-11].i_value;
|
|
}
|
|
break;
|
|
case 50:
|
|
#line 318 "bc.y"
|
|
{ yyval.a_value = NULL; }
|
|
break;
|
|
case 52:
|
|
#line 322 "bc.y"
|
|
{ yyval.a_value = NULL; }
|
|
break;
|
|
case 53:
|
|
#line 324 "bc.y"
|
|
{ yyval.a_value = yyvsp[-1].a_value; }
|
|
break;
|
|
case 54:
|
|
#line 326 "bc.y"
|
|
{ yyval.a_value = yyvsp[-1].a_value; }
|
|
break;
|
|
case 55:
|
|
#line 329 "bc.y"
|
|
{ yyval.a_value = nextarg (NULL, lookup (yyvsp[0].s_value,SIMPLE)); }
|
|
break;
|
|
case 56:
|
|
#line 331 "bc.y"
|
|
{ yyval.a_value = nextarg (NULL, lookup (yyvsp[-2].s_value,ARRAY)); }
|
|
break;
|
|
case 57:
|
|
#line 333 "bc.y"
|
|
{ yyval.a_value = nextarg (yyvsp[-2].a_value, lookup (yyvsp[0].s_value,SIMPLE)); }
|
|
break;
|
|
case 58:
|
|
#line 335 "bc.y"
|
|
{ yyval.a_value = nextarg (yyvsp[-4].a_value, lookup (yyvsp[-2].s_value,ARRAY)); }
|
|
break;
|
|
case 59:
|
|
#line 338 "bc.y"
|
|
{ yyval.a_value = NULL; }
|
|
break;
|
|
case 61:
|
|
#line 342 "bc.y"
|
|
{
|
|
if (yyvsp[0].i_value > 1) warn ("comparison in argument");
|
|
yyval.a_value = nextarg (NULL,0);
|
|
}
|
|
break;
|
|
case 62:
|
|
#line 347 "bc.y"
|
|
{
|
|
sprintf (genstr, "K%d:", -lookup (yyvsp[-2].s_value,ARRAY));
|
|
generate (genstr);
|
|
yyval.a_value = nextarg (NULL,1);
|
|
}
|
|
break;
|
|
case 63:
|
|
#line 353 "bc.y"
|
|
{
|
|
if (yyvsp[0].i_value > 1) warn ("comparison in argument");
|
|
yyval.a_value = nextarg (yyvsp[-2].a_value,0);
|
|
}
|
|
break;
|
|
case 64:
|
|
#line 358 "bc.y"
|
|
{
|
|
sprintf (genstr, "K%d:", -lookup (yyvsp[-2].s_value,ARRAY));
|
|
generate (genstr);
|
|
yyval.a_value = nextarg (yyvsp[-4].a_value,1);
|
|
}
|
|
break;
|
|
case 65:
|
|
#line 365 "bc.y"
|
|
{
|
|
yyval.i_value = -1;
|
|
warn ("Missing expression in for statement");
|
|
}
|
|
break;
|
|
case 67:
|
|
#line 372 "bc.y"
|
|
{
|
|
yyval.i_value = 0;
|
|
generate ("0");
|
|
}
|
|
break;
|
|
case 68:
|
|
#line 377 "bc.y"
|
|
{
|
|
if (yyvsp[0].i_value > 1)
|
|
warn ("comparison in return expresion");
|
|
}
|
|
break;
|
|
case 69:
|
|
#line 383 "bc.y"
|
|
{
|
|
if (yyvsp[0].c_value != '=')
|
|
{
|
|
if (yyvsp[-1].i_value < 0)
|
|
sprintf (genstr, "DL%d:", -yyvsp[-1].i_value);
|
|
else
|
|
sprintf (genstr, "l%d:", yyvsp[-1].i_value);
|
|
generate (genstr);
|
|
}
|
|
}
|
|
break;
|
|
case 70:
|
|
#line 394 "bc.y"
|
|
{
|
|
if (yyvsp[0].i_value > 1) warn("comparison in assignment");
|
|
if (yyvsp[-2].c_value != '=')
|
|
{
|
|
sprintf (genstr, "%c", yyvsp[-2].c_value);
|
|
generate (genstr);
|
|
}
|
|
if (yyvsp[-3].i_value < 0)
|
|
sprintf (genstr, "S%d:", -yyvsp[-3].i_value);
|
|
else
|
|
sprintf (genstr, "s%d:", yyvsp[-3].i_value);
|
|
generate (genstr);
|
|
yyval.i_value = 0;
|
|
}
|
|
break;
|
|
case 71:
|
|
#line 410 "bc.y"
|
|
{
|
|
warn("&& operator");
|
|
yyvsp[0].i_value = next_label++;
|
|
sprintf (genstr, "DZ%d:p", yyvsp[0].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 72:
|
|
#line 417 "bc.y"
|
|
{
|
|
sprintf (genstr, "DZ%d:p1N%d:", yyvsp[-2].i_value, yyvsp[-2].i_value);
|
|
generate (genstr);
|
|
yyval.i_value = yyvsp[-3].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 73:
|
|
#line 423 "bc.y"
|
|
{
|
|
warn("|| operator");
|
|
yyvsp[0].i_value = next_label++;
|
|
sprintf (genstr, "B%d:", yyvsp[0].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 74:
|
|
#line 430 "bc.y"
|
|
{
|
|
int tmplab;
|
|
tmplab = next_label++;
|
|
sprintf (genstr, "B%d:0J%d:N%d:1N%d:",
|
|
yyvsp[-2].i_value, tmplab, yyvsp[-2].i_value, tmplab);
|
|
generate (genstr);
|
|
yyval.i_value = yyvsp[-3].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 75:
|
|
#line 439 "bc.y"
|
|
{
|
|
yyval.i_value = yyvsp[0].i_value;
|
|
warn("! operator");
|
|
generate ("!");
|
|
}
|
|
break;
|
|
case 76:
|
|
#line 445 "bc.y"
|
|
{
|
|
yyval.i_value = 3;
|
|
switch (*(yyvsp[-1].s_value))
|
|
{
|
|
case '=':
|
|
generate ("=");
|
|
break;
|
|
|
|
case '!':
|
|
generate ("#");
|
|
break;
|
|
|
|
case '<':
|
|
if (yyvsp[-1].s_value[1] == '=')
|
|
generate ("{");
|
|
else
|
|
generate ("<");
|
|
break;
|
|
|
|
case '>':
|
|
if (yyvsp[-1].s_value[1] == '=')
|
|
generate ("}");
|
|
else
|
|
generate (">");
|
|
break;
|
|
}
|
|
}
|
|
break;
|
|
case 77:
|
|
#line 473 "bc.y"
|
|
{
|
|
generate ("+");
|
|
yyval.i_value = yyvsp[-2].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 78:
|
|
#line 478 "bc.y"
|
|
{
|
|
generate ("-");
|
|
yyval.i_value = yyvsp[-2].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 79:
|
|
#line 483 "bc.y"
|
|
{
|
|
genstr[0] = yyvsp[-1].c_value;
|
|
genstr[1] = 0;
|
|
generate (genstr);
|
|
yyval.i_value = yyvsp[-2].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 80:
|
|
#line 490 "bc.y"
|
|
{
|
|
generate ("^");
|
|
yyval.i_value = yyvsp[-2].i_value | yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 81:
|
|
#line 495 "bc.y"
|
|
{
|
|
generate ("n");
|
|
yyval.i_value = yyvsp[0].i_value;
|
|
}
|
|
break;
|
|
case 82:
|
|
#line 500 "bc.y"
|
|
{
|
|
yyval.i_value = 1;
|
|
if (yyvsp[0].i_value < 0)
|
|
sprintf (genstr, "L%d:", -yyvsp[0].i_value);
|
|
else
|
|
sprintf (genstr, "l%d:", yyvsp[0].i_value);
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 83:
|
|
#line 509 "bc.y"
|
|
{
|
|
int len = strlen(yyvsp[0].s_value);
|
|
yyval.i_value = 1;
|
|
if (len == 1 && *yyvsp[0].s_value == '0')
|
|
generate ("0");
|
|
else if (len == 1 && *yyvsp[0].s_value == '1')
|
|
generate ("1");
|
|
else
|
|
{
|
|
generate ("K");
|
|
generate (yyvsp[0].s_value);
|
|
generate (":");
|
|
}
|
|
free (yyvsp[0].s_value);
|
|
}
|
|
break;
|
|
case 84:
|
|
#line 525 "bc.y"
|
|
{ yyval.i_value = yyvsp[-1].i_value | 1; }
|
|
break;
|
|
case 85:
|
|
#line 527 "bc.y"
|
|
{
|
|
yyval.i_value = 1;
|
|
if (yyvsp[-1].a_value != NULL)
|
|
{
|
|
sprintf (genstr, "C%d,%s:",
|
|
lookup (yyvsp[-3].s_value,FUNCT),
|
|
arg_str (yyvsp[-1].a_value,FALSE));
|
|
free_args (yyvsp[-1].a_value);
|
|
}
|
|
else
|
|
{
|
|
sprintf (genstr, "C%d:", lookup (yyvsp[-3].s_value,FUNCT));
|
|
}
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 86:
|
|
#line 543 "bc.y"
|
|
{
|
|
yyval.i_value = 1;
|
|
if (yyvsp[0].i_value < 0)
|
|
{
|
|
if (yyvsp[-1].c_value == '+')
|
|
sprintf (genstr, "DA%d:L%d:", -yyvsp[0].i_value, -yyvsp[0].i_value);
|
|
else
|
|
sprintf (genstr, "DM%d:L%d:", -yyvsp[0].i_value, -yyvsp[0].i_value);
|
|
}
|
|
else
|
|
{
|
|
if (yyvsp[-1].c_value == '+')
|
|
sprintf (genstr, "i%d:l%d:", yyvsp[0].i_value, yyvsp[0].i_value);
|
|
else
|
|
sprintf (genstr, "d%d:l%d:", yyvsp[0].i_value, yyvsp[0].i_value);
|
|
}
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 87:
|
|
#line 562 "bc.y"
|
|
{
|
|
yyval.i_value = 1;
|
|
if (yyvsp[-1].i_value < 0)
|
|
{
|
|
sprintf (genstr, "DL%d:x", -yyvsp[-1].i_value);
|
|
generate (genstr);
|
|
if (yyvsp[0].c_value == '+')
|
|
sprintf (genstr, "A%d:", -yyvsp[-1].i_value);
|
|
else
|
|
sprintf (genstr, "M%d:", -yyvsp[-1].i_value);
|
|
}
|
|
else
|
|
{
|
|
sprintf (genstr, "l%d:", yyvsp[-1].i_value);
|
|
generate (genstr);
|
|
if (yyvsp[0].c_value == '+')
|
|
sprintf (genstr, "i%d:", yyvsp[-1].i_value);
|
|
else
|
|
sprintf (genstr, "d%d:", yyvsp[-1].i_value);
|
|
}
|
|
generate (genstr);
|
|
}
|
|
break;
|
|
case 88:
|
|
#line 585 "bc.y"
|
|
{ generate ("cL"); yyval.i_value = 1;}
|
|
break;
|
|
case 89:
|
|
#line 587 "bc.y"
|
|
{ generate ("cR"); yyval.i_value = 1;}
|
|
break;
|
|
case 90:
|
|
#line 589 "bc.y"
|
|
{ generate ("cS"); yyval.i_value = 1;}
|
|
break;
|
|
case 91:
|
|
#line 591 "bc.y"
|
|
{
|
|
warn ("read function");
|
|
generate ("cI"); yyval.i_value = 1;
|
|
}
|
|
break;
|
|
case 92:
|
|
#line 597 "bc.y"
|
|
{ yyval.i_value = lookup(yyvsp[0].s_value,SIMPLE); }
|
|
break;
|
|
case 93:
|
|
#line 599 "bc.y"
|
|
{
|
|
if (yyvsp[-1].i_value > 1) warn("comparison in subscript");
|
|
yyval.i_value = lookup(yyvsp[-3].s_value,ARRAY);
|
|
}
|
|
break;
|
|
case 94:
|
|
#line 604 "bc.y"
|
|
{ yyval.i_value = 0; }
|
|
break;
|
|
case 95:
|
|
#line 606 "bc.y"
|
|
{ yyval.i_value = 1; }
|
|
break;
|
|
case 96:
|
|
#line 608 "bc.y"
|
|
{ yyval.i_value = 2; }
|
|
break;
|
|
case 97:
|
|
#line 610 "bc.y"
|
|
{ yyval.i_value = 3; }
|
|
break;
|
|
#line 1318 "y.tab.c"
|
|
}
|
|
yyssp -= yym;
|
|
yystate = *yyssp;
|
|
yyvsp -= yym;
|
|
yym = yylhs[yyn];
|
|
if (yystate == 0 && yym == 0)
|
|
{
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: after reduction, shifting from state 0 to\
|
|
state %d\n", YYPREFIX, YYFINAL);
|
|
#endif
|
|
yystate = YYFINAL;
|
|
*++yyssp = YYFINAL;
|
|
*++yyvsp = yyval;
|
|
if (yychar < 0)
|
|
{
|
|
if ((yychar = yylex()) < 0) yychar = 0;
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
{
|
|
yys = 0;
|
|
if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
|
|
if (!yys) yys = "illegal-symbol";
|
|
printf("%sdebug: state %d, reading %d (%s)\n",
|
|
YYPREFIX, YYFINAL, yychar, yys);
|
|
}
|
|
#endif
|
|
}
|
|
if (yychar == 0) goto yyaccept;
|
|
goto yyloop;
|
|
}
|
|
if ((yyn = yygindex[yym]) && (yyn += yystate) >= 0 &&
|
|
yyn <= YYTABLESIZE && yycheck[yyn] == yystate)
|
|
yystate = yytable[yyn];
|
|
else
|
|
yystate = yydgoto[yym];
|
|
#if YYDEBUG
|
|
if (yydebug)
|
|
printf("%sdebug: after reduction, shifting from state %d \
|
|
to state %d\n", YYPREFIX, *yyssp, yystate);
|
|
#endif
|
|
if (yyssp >= yyss + yystacksize - 1)
|
|
{
|
|
goto yyoverflow;
|
|
}
|
|
*++yyssp = yystate;
|
|
*++yyvsp = yyval;
|
|
goto yyloop;
|
|
yyoverflow:
|
|
yyerror("yacc stack overflow");
|
|
yyabort:
|
|
return (1);
|
|
yyaccept:
|
|
return (0);
|
|
}
|