xref: /freebsd/contrib/byacc/test/yacc/varsyntax_calc1.tab.c (revision c5b5d71ad3977f66e7a9c8f5193f10bfd6ac15d8)
10c8de5b0SBaptiste Daroussin /* original parser id follows */
20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar	1.9 (Berkeley) 02/21/93" */
30c8de5b0SBaptiste Daroussin /* (use YYMAJOR/YYMINOR for ifdefs dependent on parser version) */
40c8de5b0SBaptiste Daroussin 
50c8de5b0SBaptiste Daroussin #define YYBYACC 1
60c8de5b0SBaptiste Daroussin #define YYMAJOR 1
70c8de5b0SBaptiste Daroussin #define YYMINOR 9
80c8de5b0SBaptiste Daroussin #define YYCHECK "yyyymmdd"
90c8de5b0SBaptiste Daroussin 
100c8de5b0SBaptiste Daroussin #define YYEMPTY        (-1)
110c8de5b0SBaptiste Daroussin #define yyclearin      (yychar = YYEMPTY)
120c8de5b0SBaptiste Daroussin #define yyerrok        (yyerrflag = 0)
130c8de5b0SBaptiste Daroussin #define YYRECOVERING() (yyerrflag != 0)
140c8de5b0SBaptiste Daroussin #define YYENOMEM       (-2)
150c8de5b0SBaptiste Daroussin #define YYEOF          0
160c8de5b0SBaptiste Daroussin #ident "check variant syntax features"
170c8de5b0SBaptiste Daroussin 
180c8de5b0SBaptiste Daroussin #ifndef yyparse
190c8de5b0SBaptiste Daroussin #define yyparse    varsyntax_calc1_parse
200c8de5b0SBaptiste Daroussin #endif /* yyparse */
210c8de5b0SBaptiste Daroussin 
220c8de5b0SBaptiste Daroussin #ifndef yylex
230c8de5b0SBaptiste Daroussin #define yylex      varsyntax_calc1_lex
240c8de5b0SBaptiste Daroussin #endif /* yylex */
250c8de5b0SBaptiste Daroussin 
260c8de5b0SBaptiste Daroussin #ifndef yyerror
270c8de5b0SBaptiste Daroussin #define yyerror    varsyntax_calc1_error
280c8de5b0SBaptiste Daroussin #endif /* yyerror */
290c8de5b0SBaptiste Daroussin 
300c8de5b0SBaptiste Daroussin #ifndef yychar
310c8de5b0SBaptiste Daroussin #define yychar     varsyntax_calc1_char
320c8de5b0SBaptiste Daroussin #endif /* yychar */
330c8de5b0SBaptiste Daroussin 
340c8de5b0SBaptiste Daroussin #ifndef yyval
350c8de5b0SBaptiste Daroussin #define yyval      varsyntax_calc1_val
360c8de5b0SBaptiste Daroussin #endif /* yyval */
370c8de5b0SBaptiste Daroussin 
380c8de5b0SBaptiste Daroussin #ifndef yylval
390c8de5b0SBaptiste Daroussin #define yylval     varsyntax_calc1_lval
400c8de5b0SBaptiste Daroussin #endif /* yylval */
410c8de5b0SBaptiste Daroussin 
420c8de5b0SBaptiste Daroussin #ifndef yydebug
430c8de5b0SBaptiste Daroussin #define yydebug    varsyntax_calc1_debug
440c8de5b0SBaptiste Daroussin #endif /* yydebug */
450c8de5b0SBaptiste Daroussin 
460c8de5b0SBaptiste Daroussin #ifndef yynerrs
470c8de5b0SBaptiste Daroussin #define yynerrs    varsyntax_calc1_nerrs
480c8de5b0SBaptiste Daroussin #endif /* yynerrs */
490c8de5b0SBaptiste Daroussin 
500c8de5b0SBaptiste Daroussin #ifndef yyerrflag
510c8de5b0SBaptiste Daroussin #define yyerrflag  varsyntax_calc1_errflag
520c8de5b0SBaptiste Daroussin #endif /* yyerrflag */
530c8de5b0SBaptiste Daroussin 
540c8de5b0SBaptiste Daroussin #ifndef yylhs
550c8de5b0SBaptiste Daroussin #define yylhs      varsyntax_calc1_lhs
560c8de5b0SBaptiste Daroussin #endif /* yylhs */
570c8de5b0SBaptiste Daroussin 
580c8de5b0SBaptiste Daroussin #ifndef yylen
590c8de5b0SBaptiste Daroussin #define yylen      varsyntax_calc1_len
600c8de5b0SBaptiste Daroussin #endif /* yylen */
610c8de5b0SBaptiste Daroussin 
620c8de5b0SBaptiste Daroussin #ifndef yydefred
630c8de5b0SBaptiste Daroussin #define yydefred   varsyntax_calc1_defred
640c8de5b0SBaptiste Daroussin #endif /* yydefred */
650c8de5b0SBaptiste Daroussin 
660c8de5b0SBaptiste Daroussin #ifndef yydgoto
670c8de5b0SBaptiste Daroussin #define yydgoto    varsyntax_calc1_dgoto
680c8de5b0SBaptiste Daroussin #endif /* yydgoto */
690c8de5b0SBaptiste Daroussin 
700c8de5b0SBaptiste Daroussin #ifndef yysindex
710c8de5b0SBaptiste Daroussin #define yysindex   varsyntax_calc1_sindex
720c8de5b0SBaptiste Daroussin #endif /* yysindex */
730c8de5b0SBaptiste Daroussin 
740c8de5b0SBaptiste Daroussin #ifndef yyrindex
750c8de5b0SBaptiste Daroussin #define yyrindex   varsyntax_calc1_rindex
760c8de5b0SBaptiste Daroussin #endif /* yyrindex */
770c8de5b0SBaptiste Daroussin 
780c8de5b0SBaptiste Daroussin #ifndef yygindex
790c8de5b0SBaptiste Daroussin #define yygindex   varsyntax_calc1_gindex
800c8de5b0SBaptiste Daroussin #endif /* yygindex */
810c8de5b0SBaptiste Daroussin 
820c8de5b0SBaptiste Daroussin #ifndef yytable
830c8de5b0SBaptiste Daroussin #define yytable    varsyntax_calc1_table
840c8de5b0SBaptiste Daroussin #endif /* yytable */
850c8de5b0SBaptiste Daroussin 
860c8de5b0SBaptiste Daroussin #ifndef yycheck
870c8de5b0SBaptiste Daroussin #define yycheck    varsyntax_calc1_check
880c8de5b0SBaptiste Daroussin #endif /* yycheck */
890c8de5b0SBaptiste Daroussin 
900c8de5b0SBaptiste Daroussin #ifndef yyname
910c8de5b0SBaptiste Daroussin #define yyname     varsyntax_calc1_name
920c8de5b0SBaptiste Daroussin #endif /* yyname */
930c8de5b0SBaptiste Daroussin 
940c8de5b0SBaptiste Daroussin #ifndef yyrule
950c8de5b0SBaptiste Daroussin #define yyrule     varsyntax_calc1_rule
960c8de5b0SBaptiste Daroussin #endif /* yyrule */
970c8de5b0SBaptiste Daroussin #define YYPREFIX "varsyntax_calc1_"
980c8de5b0SBaptiste Daroussin 
990c8de5b0SBaptiste Daroussin #define YYPURE 0
1000c8de5b0SBaptiste Daroussin 
1010c8de5b0SBaptiste Daroussin #line 3 "varsyntax_calc1.y"
1020c8de5b0SBaptiste Daroussin 
1030c8de5b0SBaptiste Daroussin /* http://dinosaur.compilertools.net/yacc/index.html * /*/
1040c8de5b0SBaptiste Daroussin 
1050c8de5b0SBaptiste Daroussin #include <stdlib.h>
1060c8de5b0SBaptiste Daroussin #include <stdio.h>
1070c8de5b0SBaptiste Daroussin #include <ctype.h>
1080c8de5b0SBaptiste Daroussin #include <math.h>
1090c8de5b0SBaptiste Daroussin 
1100c8de5b0SBaptiste Daroussin typedef struct interval
1110c8de5b0SBaptiste Daroussin {
1120c8de5b0SBaptiste Daroussin     double lo, hi;
1130c8de5b0SBaptiste Daroussin }
1140c8de5b0SBaptiste Daroussin INTERVAL;
1150c8de5b0SBaptiste Daroussin 
1160c8de5b0SBaptiste Daroussin INTERVAL vmul(double, double, INTERVAL);
1170c8de5b0SBaptiste Daroussin INTERVAL vdiv(double, double, INTERVAL);
1180c8de5b0SBaptiste Daroussin 
1190c8de5b0SBaptiste Daroussin extern int yylex(void);
1200c8de5b0SBaptiste Daroussin static void yyerror(const char *s);
1210c8de5b0SBaptiste Daroussin 
1220c8de5b0SBaptiste Daroussin int dcheck(INTERVAL);
1230c8de5b0SBaptiste Daroussin 
1240c8de5b0SBaptiste Daroussin double dreg[26];
1250c8de5b0SBaptiste Daroussin INTERVAL vreg[26];
1260c8de5b0SBaptiste Daroussin 
1270c8de5b0SBaptiste Daroussin #ifdef YYSTYPE
1280c8de5b0SBaptiste Daroussin #undef  YYSTYPE_IS_DECLARED
1290c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
1300c8de5b0SBaptiste Daroussin #endif
1310c8de5b0SBaptiste Daroussin #ifndef YYSTYPE_IS_DECLARED
1320c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
133*c5b5d71aSJung-uk Kim #line 32 "varsyntax_calc1.y"
1340c8de5b0SBaptiste Daroussin typedef union
1350c8de5b0SBaptiste Daroussin {
1360c8de5b0SBaptiste Daroussin 	int ival;	/* dreg & vreg array index values*/
1370c8de5b0SBaptiste Daroussin 	double dval;	/* floating point values*/
1380c8de5b0SBaptiste Daroussin 	INTERVAL vval;	/* interval values*/
1390c8de5b0SBaptiste Daroussin } YYSTYPE;
1400c8de5b0SBaptiste Daroussin #endif /* !YYSTYPE_IS_DECLARED */
1410c8de5b0SBaptiste Daroussin #line 142 "varsyntax_calc1.tab.c"
1420c8de5b0SBaptiste Daroussin 
1430c8de5b0SBaptiste Daroussin /* compatibility with bison */
1440c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM
1450c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */
1460c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE
1470c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
1480c8de5b0SBaptiste Daroussin # else
1490c8de5b0SBaptiste Daroussin #  define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
1500c8de5b0SBaptiste Daroussin # endif
1510c8de5b0SBaptiste Daroussin #else
1520c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void)
1530c8de5b0SBaptiste Daroussin #endif
1540c8de5b0SBaptiste Daroussin 
1550c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */
1560c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM
1570c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
1580c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM)
1590c8de5b0SBaptiste Daroussin #else
1600c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void)
1610c8de5b0SBaptiste Daroussin # define YYLEX yylex()
1620c8de5b0SBaptiste Daroussin #endif
1630c8de5b0SBaptiste Daroussin 
1640c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */
1650c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL
1660c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s)
1670c8de5b0SBaptiste Daroussin #endif
1680c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL
1690c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg)
1700c8de5b0SBaptiste Daroussin #endif
1710c8de5b0SBaptiste Daroussin 
1720c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL();
1730c8de5b0SBaptiste Daroussin 
1740c8de5b0SBaptiste Daroussin #define DREG 257
1750c8de5b0SBaptiste Daroussin #define VREG 258
1760c8de5b0SBaptiste Daroussin #define CONST 259
1770c8de5b0SBaptiste Daroussin #define UMINUS 260
1780c8de5b0SBaptiste Daroussin #define YYERRCODE 256
179ea2af5c8SJung-uk Kim typedef int YYINT;
1800c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_lhs[] = {             -1,
1810c8de5b0SBaptiste Daroussin     3,    3,    0,    0,    0,    0,    0,    1,    1,    1,
1820c8de5b0SBaptiste Daroussin     1,    1,    1,    1,    1,    2,    2,    2,    2,    2,
1830c8de5b0SBaptiste Daroussin     2,    2,    2,    2,    2,    2,    2,    2,
1840c8de5b0SBaptiste Daroussin };
1850c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_len[] = {              2,
1860c8de5b0SBaptiste Daroussin     0,    2,    2,    2,    4,    4,    2,    1,    1,    3,
1870c8de5b0SBaptiste Daroussin     3,    3,    3,    2,    3,    1,    5,    1,    3,    3,
1880c8de5b0SBaptiste Daroussin     3,    3,    3,    3,    3,    3,    2,    3,
1890c8de5b0SBaptiste Daroussin };
1900c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_defred[] = {           0,
1910c8de5b0SBaptiste Daroussin     0,    0,    0,    8,    0,    0,    0,    0,    0,    7,
1920c8de5b0SBaptiste Daroussin     0,    0,    9,   18,   14,   27,    0,    0,    0,    0,
1930c8de5b0SBaptiste Daroussin     0,    0,    3,    0,    0,    0,    0,    4,    0,    0,
1940c8de5b0SBaptiste Daroussin     0,    0,    0,   15,    0,   28,    0,    0,    0,    0,
1950c8de5b0SBaptiste Daroussin    12,   24,   13,   26,    0,    0,   23,   25,   14,    0,
1960c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    5,    6,    0,    0,    0,   12,
1970c8de5b0SBaptiste Daroussin    13,   17,
1980c8de5b0SBaptiste Daroussin };
1990c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_dgoto[] = {            7,
2000c8de5b0SBaptiste Daroussin    32,    9,    0,
2010c8de5b0SBaptiste Daroussin };
2020c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_sindex[] = {         -40,
2030c8de5b0SBaptiste Daroussin    -8,  -48,  -47,    0,  -37,  -37,    0,    2,   17,    0,
2040c8de5b0SBaptiste Daroussin   -34,  -37,    0,    0,    0,    0,  -25,   90,  -37,  -37,
2050c8de5b0SBaptiste Daroussin   -37,  -37,    0,  -37,  -37,  -37,  -37,    0,  -34,  -34,
2060c8de5b0SBaptiste Daroussin    25,  125,   31,    0,  -34,    0,  -11,   37,  -11,   37,
2070c8de5b0SBaptiste Daroussin     0,    0,    0,    0,   37,   37,    0,    0,    0,  111,
2080c8de5b0SBaptiste Daroussin   -34,  -34,  -34,  -34,    0,    0,  118,   69,   69,    0,
2090c8de5b0SBaptiste Daroussin     0,    0,
2100c8de5b0SBaptiste Daroussin };
2110c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_rindex[] = {           0,
2120c8de5b0SBaptiste Daroussin     0,   38,   44,    0,    0,    0,    0,    0,    0,    0,
2130c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
2140c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
2150c8de5b0SBaptiste Daroussin     0,   -9,    0,    0,    0,    0,   51,   -3,   56,   61,
2160c8de5b0SBaptiste Daroussin     0,    0,    0,    0,   67,   72,    0,    0,    0,    0,
2170c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,   78,   83,    0,
2180c8de5b0SBaptiste Daroussin     0,    0,
2190c8de5b0SBaptiste Daroussin };
2200c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_gindex[] = {           0,
2210c8de5b0SBaptiste Daroussin     4,  124,    0,
2220c8de5b0SBaptiste Daroussin };
2230c8de5b0SBaptiste Daroussin #define YYTABLESIZE 225
2240c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_table[] = {            6,
2250c8de5b0SBaptiste Daroussin    16,   10,    6,    8,    5,   30,   20,    5,   15,   17,
2260c8de5b0SBaptiste Daroussin    29,   23,   11,   12,   31,   34,   21,   19,   35,   20,
2270c8de5b0SBaptiste Daroussin     0,   22,   37,   39,   41,   43,   28,    0,    0,    0,
2280c8de5b0SBaptiste Daroussin    21,   16,   49,   50,   55,   22,    0,   20,   57,   20,
2290c8de5b0SBaptiste Daroussin    56,   20,    0,   21,   19,    0,   20,    9,   22,    0,
2300c8de5b0SBaptiste Daroussin     0,    0,    0,   18,   58,   59,   60,   61,   26,   24,
2310c8de5b0SBaptiste Daroussin    10,   25,    0,   27,    0,   11,   53,   51,    0,   52,
2320c8de5b0SBaptiste Daroussin    22,   54,   26,   24,    0,   25,   19,   27,   26,    9,
2330c8de5b0SBaptiste Daroussin     9,   21,    9,   27,    9,   18,   18,   10,   18,    0,
2340c8de5b0SBaptiste Daroussin    18,   10,   11,   10,   10,   10,   11,    0,   11,   11,
2350c8de5b0SBaptiste Daroussin    11,   22,    0,   22,    0,   22,    0,   19,    0,   19,
2360c8de5b0SBaptiste Daroussin    53,   19,   21,    0,   21,   54,   21,    0,   10,    0,
2370c8de5b0SBaptiste Daroussin    10,    0,   10,   11,    0,   11,    0,   11,   16,   18,
2380c8de5b0SBaptiste Daroussin    36,   26,   24,    0,   25,   33,   27,    0,    0,    0,
2390c8de5b0SBaptiste Daroussin     0,    0,   38,   40,   42,   44,    0,   45,   46,   47,
2400c8de5b0SBaptiste Daroussin    48,   34,   53,   51,    0,   52,    0,   54,   62,   53,
2410c8de5b0SBaptiste Daroussin    51,    0,   52,    0,   54,    0,   21,   19,    0,   20,
2420c8de5b0SBaptiste Daroussin     0,   22,    0,    0,    0,    0,    0,    0,    0,    0,
2430c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
2440c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
2450c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
2460c8de5b0SBaptiste Daroussin     0,    0,    0,    0,    0,    1,    2,    3,    4,   13,
2470c8de5b0SBaptiste Daroussin    14,    4,   13,    0,    4,
2480c8de5b0SBaptiste Daroussin };
2490c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_check[] = {           40,
2500c8de5b0SBaptiste Daroussin    10,   10,   40,    0,   45,   40,   10,   45,    5,    6,
2510c8de5b0SBaptiste Daroussin    45,   10,   61,   61,   11,   41,   42,   43,   44,   45,
2520c8de5b0SBaptiste Daroussin    -1,   47,   19,   20,   21,   22,   10,   -1,   -1,   -1,
2530c8de5b0SBaptiste Daroussin    42,   41,   29,   30,   10,   47,   -1,   41,   35,   43,
2540c8de5b0SBaptiste Daroussin    10,   45,   -1,   42,   43,   -1,   45,   10,   47,   -1,
2550c8de5b0SBaptiste Daroussin    -1,   -1,   -1,   10,   51,   52,   53,   54,   42,   43,
2560c8de5b0SBaptiste Daroussin    10,   45,   -1,   47,   -1,   10,   42,   43,   -1,   45,
2570c8de5b0SBaptiste Daroussin    10,   47,   42,   43,   -1,   45,   10,   47,   42,   42,
2580c8de5b0SBaptiste Daroussin    43,   10,   45,   47,   47,   42,   43,   10,   45,   -1,
2590c8de5b0SBaptiste Daroussin    47,   41,   10,   43,   44,   45,   41,   -1,   43,   44,
2600c8de5b0SBaptiste Daroussin    45,   41,   -1,   43,   -1,   45,   -1,   41,   -1,   43,
2610c8de5b0SBaptiste Daroussin    42,   45,   41,   -1,   43,   47,   45,   -1,   41,   -1,
2620c8de5b0SBaptiste Daroussin    43,   -1,   45,   41,   -1,   43,   -1,   45,    5,    6,
2630c8de5b0SBaptiste Daroussin    41,   42,   43,   -1,   45,   12,   47,   -1,   -1,   -1,
2640c8de5b0SBaptiste Daroussin    -1,   -1,   19,   20,   21,   22,   -1,   24,   25,   26,
2650c8de5b0SBaptiste Daroussin    27,   41,   42,   43,   -1,   45,   -1,   47,   41,   42,
2660c8de5b0SBaptiste Daroussin    43,   -1,   45,   -1,   47,   -1,   42,   43,   -1,   45,
2670c8de5b0SBaptiste Daroussin    -1,   47,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
2680c8de5b0SBaptiste Daroussin    -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
2690c8de5b0SBaptiste Daroussin    -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
2700c8de5b0SBaptiste Daroussin    -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
2710c8de5b0SBaptiste Daroussin    -1,   -1,   -1,   -1,   -1,  256,  257,  258,  259,  257,
2720c8de5b0SBaptiste Daroussin   258,  259,  257,   -1,  259,
2730c8de5b0SBaptiste Daroussin };
2740c8de5b0SBaptiste Daroussin #define YYFINAL 7
2750c8de5b0SBaptiste Daroussin #ifndef YYDEBUG
2760c8de5b0SBaptiste Daroussin #define YYDEBUG 0
2770c8de5b0SBaptiste Daroussin #endif
2780c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 260
2790c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 266
2800c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
2810c8de5b0SBaptiste Daroussin #if YYDEBUG
2820c8de5b0SBaptiste Daroussin static const char *const varsyntax_calc1_name[] = {
2830c8de5b0SBaptiste Daroussin 
2840c8de5b0SBaptiste Daroussin "end-of-file",0,0,0,0,0,0,0,0,0,"'\\n'",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
2850c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,0,0,0,"'('","')'","'*'","'+'","','","'-'",0,"'/'",0,0,0,0,0,0,0,0,0,
2860c8de5b0SBaptiste Daroussin 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,
2870c8de5b0SBaptiste Daroussin 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,
2880c8de5b0SBaptiste Daroussin 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,
2890c8de5b0SBaptiste Daroussin 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,
2900c8de5b0SBaptiste Daroussin 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,
2910c8de5b0SBaptiste Daroussin 0,0,"DREG","VREG","CONST","UMINUS",0,0,0,0,0,"illegal-symbol",
2920c8de5b0SBaptiste Daroussin };
2930c8de5b0SBaptiste Daroussin static const char *const varsyntax_calc1_rule[] = {
2940c8de5b0SBaptiste Daroussin "$accept : line",
2950c8de5b0SBaptiste Daroussin "lines :",
2960c8de5b0SBaptiste Daroussin "lines : lines line",
2970c8de5b0SBaptiste Daroussin "line : dexp '\\n'",
2980c8de5b0SBaptiste Daroussin "line : vexp '\\n'",
2990c8de5b0SBaptiste Daroussin "line : DREG '=' dexp '\\n'",
3000c8de5b0SBaptiste Daroussin "line : VREG '=' vexp '\\n'",
3010c8de5b0SBaptiste Daroussin "line : error '\\n'",
3020c8de5b0SBaptiste Daroussin "dexp : CONST",
3030c8de5b0SBaptiste Daroussin "dexp : DREG",
3040c8de5b0SBaptiste Daroussin "dexp : dexp '+' dexp",
3050c8de5b0SBaptiste Daroussin "dexp : dexp '-' dexp",
3060c8de5b0SBaptiste Daroussin "dexp : dexp '*' dexp",
3070c8de5b0SBaptiste Daroussin "dexp : dexp '/' dexp",
3080c8de5b0SBaptiste Daroussin "dexp : '-' dexp",
3090c8de5b0SBaptiste Daroussin "dexp : '(' dexp ')'",
3100c8de5b0SBaptiste Daroussin "vexp : dexp",
3110c8de5b0SBaptiste Daroussin "vexp : '(' dexp ',' dexp ')'",
3120c8de5b0SBaptiste Daroussin "vexp : VREG",
3130c8de5b0SBaptiste Daroussin "vexp : vexp '+' vexp",
3140c8de5b0SBaptiste Daroussin "vexp : dexp '+' vexp",
3150c8de5b0SBaptiste Daroussin "vexp : vexp '-' vexp",
3160c8de5b0SBaptiste Daroussin "vexp : dexp '-' vexp",
3170c8de5b0SBaptiste Daroussin "vexp : vexp '*' vexp",
3180c8de5b0SBaptiste Daroussin "vexp : dexp '*' vexp",
3190c8de5b0SBaptiste Daroussin "vexp : vexp '/' vexp",
3200c8de5b0SBaptiste Daroussin "vexp : dexp '/' vexp",
3210c8de5b0SBaptiste Daroussin "vexp : '-' vexp",
3220c8de5b0SBaptiste Daroussin "vexp : '(' vexp ')'",
3230c8de5b0SBaptiste Daroussin 
3240c8de5b0SBaptiste Daroussin };
3250c8de5b0SBaptiste Daroussin #endif
3260c8de5b0SBaptiste Daroussin 
3270c8de5b0SBaptiste Daroussin int      yydebug;
3280c8de5b0SBaptiste Daroussin int      yynerrs;
3290c8de5b0SBaptiste Daroussin 
3300c8de5b0SBaptiste Daroussin int      yyerrflag;
3310c8de5b0SBaptiste Daroussin int      yychar;
3320c8de5b0SBaptiste Daroussin YYSTYPE  yyval;
3330c8de5b0SBaptiste Daroussin YYSTYPE  yylval;
3340c8de5b0SBaptiste Daroussin 
3350c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
3360c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
3370c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
3380c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  YYSTACKSIZE
3390c8de5b0SBaptiste Daroussin #else
3400c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
3410c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
3420c8de5b0SBaptiste Daroussin #else
3430c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
3440c8de5b0SBaptiste Daroussin #define YYMAXDEPTH  10000
3450c8de5b0SBaptiste Daroussin #endif
3460c8de5b0SBaptiste Daroussin #endif
3470c8de5b0SBaptiste Daroussin 
3480c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
3490c8de5b0SBaptiste Daroussin 
3500c8de5b0SBaptiste Daroussin typedef struct {
3510c8de5b0SBaptiste Daroussin     unsigned stacksize;
3520c8de5b0SBaptiste Daroussin     YYINT    *s_base;
3530c8de5b0SBaptiste Daroussin     YYINT    *s_mark;
3540c8de5b0SBaptiste Daroussin     YYINT    *s_last;
3550c8de5b0SBaptiste Daroussin     YYSTYPE  *l_base;
3560c8de5b0SBaptiste Daroussin     YYSTYPE  *l_mark;
3570c8de5b0SBaptiste Daroussin } YYSTACKDATA;
3580c8de5b0SBaptiste Daroussin /* variables for the parser stack */
3590c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
3600c8de5b0SBaptiste Daroussin #line 178 "varsyntax_calc1.y"
3610c8de5b0SBaptiste Daroussin 	/* beginning of subroutines section */
3620c8de5b0SBaptiste Daroussin 
3630c8de5b0SBaptiste Daroussin #define BSZ 50			/* buffer size for floating point numbers */
3640c8de5b0SBaptiste Daroussin 
3650c8de5b0SBaptiste Daroussin 	/* lexical analysis */
3660c8de5b0SBaptiste Daroussin 
3670c8de5b0SBaptiste Daroussin static void
3680c8de5b0SBaptiste Daroussin yyerror(const char *s)
3690c8de5b0SBaptiste Daroussin {
3700c8de5b0SBaptiste Daroussin     fprintf(stderr, "%s\n", s);
3710c8de5b0SBaptiste Daroussin }
3720c8de5b0SBaptiste Daroussin 
3730c8de5b0SBaptiste Daroussin int
3740c8de5b0SBaptiste Daroussin yylex(void)
3750c8de5b0SBaptiste Daroussin {
3760c8de5b0SBaptiste Daroussin     int c;
3770c8de5b0SBaptiste Daroussin 
3780c8de5b0SBaptiste Daroussin     while ((c = getchar()) == ' ')
3790c8de5b0SBaptiste Daroussin     {				/* skip over blanks */
3800c8de5b0SBaptiste Daroussin     }
3810c8de5b0SBaptiste Daroussin 
3820c8de5b0SBaptiste Daroussin     if (isupper(c))
3830c8de5b0SBaptiste Daroussin     {
3840c8de5b0SBaptiste Daroussin 	yylval.ival = c - 'A';
3850c8de5b0SBaptiste Daroussin 	return (VREG);
3860c8de5b0SBaptiste Daroussin     }
3870c8de5b0SBaptiste Daroussin     if (islower(c))
3880c8de5b0SBaptiste Daroussin     {
3890c8de5b0SBaptiste Daroussin 	yylval.ival = c - 'a';
3900c8de5b0SBaptiste Daroussin 	return (DREG);
3910c8de5b0SBaptiste Daroussin     }
3920c8de5b0SBaptiste Daroussin 
3930c8de5b0SBaptiste Daroussin     if (isdigit(c) || c == '.')
3940c8de5b0SBaptiste Daroussin     {
3950c8de5b0SBaptiste Daroussin 	/* gobble up digits, points, exponents */
3960c8de5b0SBaptiste Daroussin 	char buf[BSZ + 1], *cp = buf;
3970c8de5b0SBaptiste Daroussin 	int dot = 0, expr = 0;
3980c8de5b0SBaptiste Daroussin 
3990c8de5b0SBaptiste Daroussin 	for (; (cp - buf) < BSZ; ++cp, c = getchar())
4000c8de5b0SBaptiste Daroussin 	{
4010c8de5b0SBaptiste Daroussin 
4020c8de5b0SBaptiste Daroussin 	    *cp = (char) c;
4030c8de5b0SBaptiste Daroussin 	    if (isdigit(c))
4040c8de5b0SBaptiste Daroussin 		continue;
4050c8de5b0SBaptiste Daroussin 	    if (c == '.')
4060c8de5b0SBaptiste Daroussin 	    {
4070c8de5b0SBaptiste Daroussin 		if (dot++ || expr)
4080c8de5b0SBaptiste Daroussin 		    return ('.');	/* will cause syntax error */
4090c8de5b0SBaptiste Daroussin 		continue;
4100c8de5b0SBaptiste Daroussin 	    }
4110c8de5b0SBaptiste Daroussin 
4120c8de5b0SBaptiste Daroussin 	    if (c == 'e')
4130c8de5b0SBaptiste Daroussin 	    {
4140c8de5b0SBaptiste Daroussin 		if (expr++)
4150c8de5b0SBaptiste Daroussin 		    return ('e');	/*  will  cause  syntax  error  */
4160c8de5b0SBaptiste Daroussin 		continue;
4170c8de5b0SBaptiste Daroussin 	    }
4180c8de5b0SBaptiste Daroussin 
4190c8de5b0SBaptiste Daroussin 	    /*  end  of  number  */
4200c8de5b0SBaptiste Daroussin 	    break;
4210c8de5b0SBaptiste Daroussin 	}
4220c8de5b0SBaptiste Daroussin 	*cp = '\0';
4230c8de5b0SBaptiste Daroussin 
4240c8de5b0SBaptiste Daroussin 	if ((cp - buf) >= BSZ)
4250c8de5b0SBaptiste Daroussin 	    printf("constant  too  long:  truncated\n");
4260c8de5b0SBaptiste Daroussin 	else
4270c8de5b0SBaptiste Daroussin 	    ungetc(c, stdin);	/*  push  back  last  char  read  */
4280c8de5b0SBaptiste Daroussin 	yylval.dval = atof(buf);
4290c8de5b0SBaptiste Daroussin 	return (CONST);
4300c8de5b0SBaptiste Daroussin     }
4310c8de5b0SBaptiste Daroussin     return (c);
4320c8de5b0SBaptiste Daroussin }
4330c8de5b0SBaptiste Daroussin 
4340c8de5b0SBaptiste Daroussin static INTERVAL
4350c8de5b0SBaptiste Daroussin hilo(double a, double b, double c, double d)
4360c8de5b0SBaptiste Daroussin {
4370c8de5b0SBaptiste Daroussin     /*  returns  the  smallest  interval  containing  a,  b,  c,  and  d  */
4380c8de5b0SBaptiste Daroussin     /*  used  by  *,  /  routines  */
4390c8de5b0SBaptiste Daroussin     INTERVAL v;
4400c8de5b0SBaptiste Daroussin 
4410c8de5b0SBaptiste Daroussin     if (a > b)
4420c8de5b0SBaptiste Daroussin     {
4430c8de5b0SBaptiste Daroussin 	v.hi = a;
4440c8de5b0SBaptiste Daroussin 	v.lo = b;
4450c8de5b0SBaptiste Daroussin     }
4460c8de5b0SBaptiste Daroussin     else
4470c8de5b0SBaptiste Daroussin     {
4480c8de5b0SBaptiste Daroussin 	v.hi = b;
4490c8de5b0SBaptiste Daroussin 	v.lo = a;
4500c8de5b0SBaptiste Daroussin     }
4510c8de5b0SBaptiste Daroussin 
4520c8de5b0SBaptiste Daroussin     if (c > d)
4530c8de5b0SBaptiste Daroussin     {
4540c8de5b0SBaptiste Daroussin 	if (c > v.hi)
4550c8de5b0SBaptiste Daroussin 	    v.hi = c;
4560c8de5b0SBaptiste Daroussin 	if (d < v.lo)
4570c8de5b0SBaptiste Daroussin 	    v.lo = d;
4580c8de5b0SBaptiste Daroussin     }
4590c8de5b0SBaptiste Daroussin     else
4600c8de5b0SBaptiste Daroussin     {
4610c8de5b0SBaptiste Daroussin 	if (d > v.hi)
4620c8de5b0SBaptiste Daroussin 	    v.hi = d;
4630c8de5b0SBaptiste Daroussin 	if (c < v.lo)
4640c8de5b0SBaptiste Daroussin 	    v.lo = c;
4650c8de5b0SBaptiste Daroussin     }
4660c8de5b0SBaptiste Daroussin     return (v);
4670c8de5b0SBaptiste Daroussin }
4680c8de5b0SBaptiste Daroussin 
4690c8de5b0SBaptiste Daroussin INTERVAL
4700c8de5b0SBaptiste Daroussin vmul(double a, double b, INTERVAL v)
4710c8de5b0SBaptiste Daroussin {
4720c8de5b0SBaptiste Daroussin     return (hilo(a * v.hi, a * v.lo, b * v.hi, b * v.lo));
4730c8de5b0SBaptiste Daroussin }
4740c8de5b0SBaptiste Daroussin 
4750c8de5b0SBaptiste Daroussin int
4760c8de5b0SBaptiste Daroussin dcheck(INTERVAL v)
4770c8de5b0SBaptiste Daroussin {
4780c8de5b0SBaptiste Daroussin     if (v.hi >= 0. && v.lo <= 0.)
4790c8de5b0SBaptiste Daroussin     {
4800c8de5b0SBaptiste Daroussin 	printf("divisor  interval  contains  0.\n");
4810c8de5b0SBaptiste Daroussin 	return (1);
4820c8de5b0SBaptiste Daroussin     }
4830c8de5b0SBaptiste Daroussin     return (0);
4840c8de5b0SBaptiste Daroussin }
4850c8de5b0SBaptiste Daroussin 
4860c8de5b0SBaptiste Daroussin INTERVAL
4870c8de5b0SBaptiste Daroussin vdiv(double a, double b, INTERVAL v)
4880c8de5b0SBaptiste Daroussin {
4890c8de5b0SBaptiste Daroussin     return (hilo(a / v.hi, a / v.lo, b / v.hi, b / v.lo));
4900c8de5b0SBaptiste Daroussin }
4910c8de5b0SBaptiste Daroussin #line 492 "varsyntax_calc1.tab.c"
4920c8de5b0SBaptiste Daroussin 
4930c8de5b0SBaptiste Daroussin #if YYDEBUG
4940c8de5b0SBaptiste Daroussin #include <stdio.h>	/* needed for printf */
4950c8de5b0SBaptiste Daroussin #endif
4960c8de5b0SBaptiste Daroussin 
4970c8de5b0SBaptiste Daroussin #include <stdlib.h>	/* needed for malloc, etc */
4980c8de5b0SBaptiste Daroussin #include <string.h>	/* needed for memset */
4990c8de5b0SBaptiste Daroussin 
5000c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
5010c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
5020c8de5b0SBaptiste Daroussin {
5030c8de5b0SBaptiste Daroussin     int i;
5040c8de5b0SBaptiste Daroussin     unsigned newsize;
5050c8de5b0SBaptiste Daroussin     YYINT *newss;
5060c8de5b0SBaptiste Daroussin     YYSTYPE *newvs;
5070c8de5b0SBaptiste Daroussin 
5080c8de5b0SBaptiste Daroussin     if ((newsize = data->stacksize) == 0)
5090c8de5b0SBaptiste Daroussin         newsize = YYINITSTACKSIZE;
5100c8de5b0SBaptiste Daroussin     else if (newsize >= YYMAXDEPTH)
5110c8de5b0SBaptiste Daroussin         return YYENOMEM;
5120c8de5b0SBaptiste Daroussin     else if ((newsize *= 2) > YYMAXDEPTH)
5130c8de5b0SBaptiste Daroussin         newsize = YYMAXDEPTH;
5140c8de5b0SBaptiste Daroussin 
5150c8de5b0SBaptiste Daroussin     i = (int) (data->s_mark - data->s_base);
5160c8de5b0SBaptiste Daroussin     newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
5170c8de5b0SBaptiste Daroussin     if (newss == 0)
5180c8de5b0SBaptiste Daroussin         return YYENOMEM;
5190c8de5b0SBaptiste Daroussin 
5200c8de5b0SBaptiste Daroussin     data->s_base = newss;
5210c8de5b0SBaptiste Daroussin     data->s_mark = newss + i;
5220c8de5b0SBaptiste Daroussin 
5230c8de5b0SBaptiste Daroussin     newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
5240c8de5b0SBaptiste Daroussin     if (newvs == 0)
5250c8de5b0SBaptiste Daroussin         return YYENOMEM;
5260c8de5b0SBaptiste Daroussin 
5270c8de5b0SBaptiste Daroussin     data->l_base = newvs;
5280c8de5b0SBaptiste Daroussin     data->l_mark = newvs + i;
5290c8de5b0SBaptiste Daroussin 
5300c8de5b0SBaptiste Daroussin     data->stacksize = newsize;
5310c8de5b0SBaptiste Daroussin     data->s_last = data->s_base + newsize - 1;
5320c8de5b0SBaptiste Daroussin     return 0;
5330c8de5b0SBaptiste Daroussin }
5340c8de5b0SBaptiste Daroussin 
5350c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
5360c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
5370c8de5b0SBaptiste Daroussin {
5380c8de5b0SBaptiste Daroussin     free(data->s_base);
5390c8de5b0SBaptiste Daroussin     free(data->l_base);
5400c8de5b0SBaptiste Daroussin     memset(data, 0, sizeof(*data));
5410c8de5b0SBaptiste Daroussin }
5420c8de5b0SBaptiste Daroussin #else
5430c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
5440c8de5b0SBaptiste Daroussin #endif
5450c8de5b0SBaptiste Daroussin 
5460c8de5b0SBaptiste Daroussin #define YYABORT  goto yyabort
5470c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
5480c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
5490c8de5b0SBaptiste Daroussin #define YYERROR  goto yyerrlab
5500c8de5b0SBaptiste Daroussin 
5510c8de5b0SBaptiste Daroussin int
5520c8de5b0SBaptiste Daroussin YYPARSE_DECL()
5530c8de5b0SBaptiste Daroussin {
5540c8de5b0SBaptiste Daroussin     int yym, yyn, yystate;
5550c8de5b0SBaptiste Daroussin #if YYDEBUG
5560c8de5b0SBaptiste Daroussin     const char *yys;
5570c8de5b0SBaptiste Daroussin 
5580c8de5b0SBaptiste Daroussin     if ((yys = getenv("YYDEBUG")) != 0)
5590c8de5b0SBaptiste Daroussin     {
5600c8de5b0SBaptiste Daroussin         yyn = *yys;
5610c8de5b0SBaptiste Daroussin         if (yyn >= '0' && yyn <= '9')
5620c8de5b0SBaptiste Daroussin             yydebug = yyn - '0';
5630c8de5b0SBaptiste Daroussin     }
5640c8de5b0SBaptiste Daroussin #endif
5650c8de5b0SBaptiste Daroussin 
566*c5b5d71aSJung-uk Kim     yym = 0;
567*c5b5d71aSJung-uk Kim     yyn = 0;
5680c8de5b0SBaptiste Daroussin     yynerrs = 0;
5690c8de5b0SBaptiste Daroussin     yyerrflag = 0;
5700c8de5b0SBaptiste Daroussin     yychar = YYEMPTY;
5710c8de5b0SBaptiste Daroussin     yystate = 0;
5720c8de5b0SBaptiste Daroussin 
5730c8de5b0SBaptiste Daroussin #if YYPURE
5740c8de5b0SBaptiste Daroussin     memset(&yystack, 0, sizeof(yystack));
5750c8de5b0SBaptiste Daroussin #endif
5760c8de5b0SBaptiste Daroussin 
5770c8de5b0SBaptiste Daroussin     if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
5780c8de5b0SBaptiste Daroussin     yystack.s_mark = yystack.s_base;
5790c8de5b0SBaptiste Daroussin     yystack.l_mark = yystack.l_base;
5800c8de5b0SBaptiste Daroussin     yystate = 0;
5810c8de5b0SBaptiste Daroussin     *yystack.s_mark = 0;
5820c8de5b0SBaptiste Daroussin 
5830c8de5b0SBaptiste Daroussin yyloop:
5840c8de5b0SBaptiste Daroussin     if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
5850c8de5b0SBaptiste Daroussin     if (yychar < 0)
5860c8de5b0SBaptiste Daroussin     {
587*c5b5d71aSJung-uk Kim         yychar = YYLEX;
588*c5b5d71aSJung-uk Kim         if (yychar < 0) yychar = YYEOF;
5890c8de5b0SBaptiste Daroussin #if YYDEBUG
5900c8de5b0SBaptiste Daroussin         if (yydebug)
5910c8de5b0SBaptiste Daroussin         {
592*c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
5930c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, reading %d (%s)\n",
5940c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yychar, yys);
5950c8de5b0SBaptiste Daroussin         }
5960c8de5b0SBaptiste Daroussin #endif
5970c8de5b0SBaptiste Daroussin     }
598*c5b5d71aSJung-uk Kim     if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
599*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
6000c8de5b0SBaptiste Daroussin     {
6010c8de5b0SBaptiste Daroussin #if YYDEBUG
6020c8de5b0SBaptiste Daroussin         if (yydebug)
6030c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, shifting to state %d\n",
6040c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yytable[yyn]);
6050c8de5b0SBaptiste Daroussin #endif
606*c5b5d71aSJung-uk Kim         if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
6070c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
6080c8de5b0SBaptiste Daroussin         *++yystack.s_mark = yytable[yyn];
6090c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yylval;
6100c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
6110c8de5b0SBaptiste Daroussin         if (yyerrflag > 0)  --yyerrflag;
6120c8de5b0SBaptiste Daroussin         goto yyloop;
6130c8de5b0SBaptiste Daroussin     }
614*c5b5d71aSJung-uk Kim     if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
615*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
6160c8de5b0SBaptiste Daroussin     {
6170c8de5b0SBaptiste Daroussin         yyn = yytable[yyn];
6180c8de5b0SBaptiste Daroussin         goto yyreduce;
6190c8de5b0SBaptiste Daroussin     }
620*c5b5d71aSJung-uk Kim     if (yyerrflag != 0) goto yyinrecovery;
6210c8de5b0SBaptiste Daroussin 
6220c8de5b0SBaptiste Daroussin     YYERROR_CALL("syntax error");
6230c8de5b0SBaptiste Daroussin 
624*c5b5d71aSJung-uk Kim     goto yyerrlab; /* redundant goto avoids 'unused label' warning */
6250c8de5b0SBaptiste Daroussin yyerrlab:
6260c8de5b0SBaptiste Daroussin     ++yynerrs;
6270c8de5b0SBaptiste Daroussin 
6280c8de5b0SBaptiste Daroussin yyinrecovery:
6290c8de5b0SBaptiste Daroussin     if (yyerrflag < 3)
6300c8de5b0SBaptiste Daroussin     {
6310c8de5b0SBaptiste Daroussin         yyerrflag = 3;
6320c8de5b0SBaptiste Daroussin         for (;;)
6330c8de5b0SBaptiste Daroussin         {
634*c5b5d71aSJung-uk Kim             if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
635*c5b5d71aSJung-uk Kim                     yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
6360c8de5b0SBaptiste Daroussin             {
6370c8de5b0SBaptiste Daroussin #if YYDEBUG
6380c8de5b0SBaptiste Daroussin                 if (yydebug)
6390c8de5b0SBaptiste Daroussin                     printf("%sdebug: state %d, error recovery shifting\
6400c8de5b0SBaptiste Daroussin  to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
6410c8de5b0SBaptiste Daroussin #endif
642*c5b5d71aSJung-uk Kim                 if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
6430c8de5b0SBaptiste Daroussin                 yystate = yytable[yyn];
6440c8de5b0SBaptiste Daroussin                 *++yystack.s_mark = yytable[yyn];
6450c8de5b0SBaptiste Daroussin                 *++yystack.l_mark = yylval;
6460c8de5b0SBaptiste Daroussin                 goto yyloop;
6470c8de5b0SBaptiste Daroussin             }
6480c8de5b0SBaptiste Daroussin             else
6490c8de5b0SBaptiste Daroussin             {
6500c8de5b0SBaptiste Daroussin #if YYDEBUG
6510c8de5b0SBaptiste Daroussin                 if (yydebug)
6520c8de5b0SBaptiste Daroussin                     printf("%sdebug: error recovery discarding state %d\n",
6530c8de5b0SBaptiste Daroussin                             YYPREFIX, *yystack.s_mark);
6540c8de5b0SBaptiste Daroussin #endif
6550c8de5b0SBaptiste Daroussin                 if (yystack.s_mark <= yystack.s_base) goto yyabort;
6560c8de5b0SBaptiste Daroussin                 --yystack.s_mark;
6570c8de5b0SBaptiste Daroussin                 --yystack.l_mark;
6580c8de5b0SBaptiste Daroussin             }
6590c8de5b0SBaptiste Daroussin         }
6600c8de5b0SBaptiste Daroussin     }
6610c8de5b0SBaptiste Daroussin     else
6620c8de5b0SBaptiste Daroussin     {
6630c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyabort;
6640c8de5b0SBaptiste Daroussin #if YYDEBUG
6650c8de5b0SBaptiste Daroussin         if (yydebug)
6660c8de5b0SBaptiste Daroussin         {
667*c5b5d71aSJung-uk Kim             if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
6680c8de5b0SBaptiste Daroussin             printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
6690c8de5b0SBaptiste Daroussin                     YYPREFIX, yystate, yychar, yys);
6700c8de5b0SBaptiste Daroussin         }
6710c8de5b0SBaptiste Daroussin #endif
6720c8de5b0SBaptiste Daroussin         yychar = YYEMPTY;
6730c8de5b0SBaptiste Daroussin         goto yyloop;
6740c8de5b0SBaptiste Daroussin     }
6750c8de5b0SBaptiste Daroussin 
6760c8de5b0SBaptiste Daroussin yyreduce:
6770c8de5b0SBaptiste Daroussin #if YYDEBUG
6780c8de5b0SBaptiste Daroussin     if (yydebug)
6790c8de5b0SBaptiste Daroussin         printf("%sdebug: state %d, reducing by rule %d (%s)\n",
6800c8de5b0SBaptiste Daroussin                 YYPREFIX, yystate, yyn, yyrule[yyn]);
6810c8de5b0SBaptiste Daroussin #endif
6820c8de5b0SBaptiste Daroussin     yym = yylen[yyn];
683*c5b5d71aSJung-uk Kim     if (yym > 0)
6840c8de5b0SBaptiste Daroussin         yyval = yystack.l_mark[1-yym];
6850c8de5b0SBaptiste Daroussin     else
6860c8de5b0SBaptiste Daroussin         memset(&yyval, 0, sizeof yyval);
687*c5b5d71aSJung-uk Kim 
6880c8de5b0SBaptiste Daroussin     switch (yyn)
6890c8de5b0SBaptiste Daroussin     {
6900c8de5b0SBaptiste Daroussin case 3:
6910c8de5b0SBaptiste Daroussin #line 59 "varsyntax_calc1.y"
6920c8de5b0SBaptiste Daroussin 	{
6930c8de5b0SBaptiste Daroussin 		(void) printf("%15.8f\n", yystack.l_mark[-1].dval);
6940c8de5b0SBaptiste Daroussin 	}
6950c8de5b0SBaptiste Daroussin break;
6960c8de5b0SBaptiste Daroussin case 4:
6970c8de5b0SBaptiste Daroussin #line 63 "varsyntax_calc1.y"
6980c8de5b0SBaptiste Daroussin 	{
6990c8de5b0SBaptiste Daroussin 		(void) printf("(%15.8f, %15.8f)\n", yystack.l_mark[-1].vval.lo, yystack.l_mark[-1].vval.hi);
7000c8de5b0SBaptiste Daroussin 	}
7010c8de5b0SBaptiste Daroussin break;
7020c8de5b0SBaptiste Daroussin case 5:
7030c8de5b0SBaptiste Daroussin #line 67 "varsyntax_calc1.y"
7040c8de5b0SBaptiste Daroussin 	{
7050c8de5b0SBaptiste Daroussin 		dreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].dval;
7060c8de5b0SBaptiste Daroussin 	}
7070c8de5b0SBaptiste Daroussin break;
7080c8de5b0SBaptiste Daroussin case 6:
7090c8de5b0SBaptiste Daroussin #line 71 "varsyntax_calc1.y"
7100c8de5b0SBaptiste Daroussin 	{
7110c8de5b0SBaptiste Daroussin 		vreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].vval;
7120c8de5b0SBaptiste Daroussin 	}
7130c8de5b0SBaptiste Daroussin break;
7140c8de5b0SBaptiste Daroussin case 7:
7150c8de5b0SBaptiste Daroussin #line 75 "varsyntax_calc1.y"
7160c8de5b0SBaptiste Daroussin 	{
7170c8de5b0SBaptiste Daroussin 		yyerrok;
7180c8de5b0SBaptiste Daroussin 	}
7190c8de5b0SBaptiste Daroussin break;
7200c8de5b0SBaptiste Daroussin case 9:
7210c8de5b0SBaptiste Daroussin #line 82 "varsyntax_calc1.y"
7220c8de5b0SBaptiste Daroussin 	{
7230c8de5b0SBaptiste Daroussin 		yyval.dval = dreg[yystack.l_mark[0].ival]; /* $$ & $1 are sufficient here*/
7240c8de5b0SBaptiste Daroussin 	}
7250c8de5b0SBaptiste Daroussin break;
7260c8de5b0SBaptiste Daroussin case 10:
7270c8de5b0SBaptiste Daroussin #line 86 "varsyntax_calc1.y"
7280c8de5b0SBaptiste Daroussin 	{
7290c8de5b0SBaptiste Daroussin 		yyval.dval = yystack.l_mark[-2].dval + yystack.l_mark[0].dval;
7300c8de5b0SBaptiste Daroussin 	}
7310c8de5b0SBaptiste Daroussin break;
7320c8de5b0SBaptiste Daroussin case 11:
7330c8de5b0SBaptiste Daroussin #line 90 "varsyntax_calc1.y"
7340c8de5b0SBaptiste Daroussin 	{
7350c8de5b0SBaptiste Daroussin 		yyval.dval = yystack.l_mark[-2].dval - yystack.l_mark[0].dval;
7360c8de5b0SBaptiste Daroussin 	}
7370c8de5b0SBaptiste Daroussin break;
7380c8de5b0SBaptiste Daroussin case 12:
7390c8de5b0SBaptiste Daroussin #line 94 "varsyntax_calc1.y"
7400c8de5b0SBaptiste Daroussin 	{
7410c8de5b0SBaptiste Daroussin 		yyval.dval = yystack.l_mark[-2].dval * yystack.l_mark[0].dval;
7420c8de5b0SBaptiste Daroussin 	}
7430c8de5b0SBaptiste Daroussin break;
7440c8de5b0SBaptiste Daroussin case 13:
7450c8de5b0SBaptiste Daroussin #line 98 "varsyntax_calc1.y"
7460c8de5b0SBaptiste Daroussin 	{
7470c8de5b0SBaptiste Daroussin 		yyval.dval = yystack.l_mark[-2].dval / yystack.l_mark[0].dval;
7480c8de5b0SBaptiste Daroussin 	}
7490c8de5b0SBaptiste Daroussin break;
7500c8de5b0SBaptiste Daroussin case 14:
7510c8de5b0SBaptiste Daroussin #line 102 "varsyntax_calc1.y"
7520c8de5b0SBaptiste Daroussin 	{
7530c8de5b0SBaptiste Daroussin 		yyval.dval = -yystack.l_mark[0].dval;
7540c8de5b0SBaptiste Daroussin 	}
7550c8de5b0SBaptiste Daroussin break;
7560c8de5b0SBaptiste Daroussin case 15:
7570c8de5b0SBaptiste Daroussin #line 106 "varsyntax_calc1.y"
7580c8de5b0SBaptiste Daroussin 	{
7590c8de5b0SBaptiste Daroussin 		yyval.dval = yystack.l_mark[-1].dval;
7600c8de5b0SBaptiste Daroussin 	}
7610c8de5b0SBaptiste Daroussin break;
7620c8de5b0SBaptiste Daroussin case 16:
7630c8de5b0SBaptiste Daroussin #line 112 "varsyntax_calc1.y"
7640c8de5b0SBaptiste Daroussin 	{
7650c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yyval.vval.lo = yystack.l_mark[0].dval;
7660c8de5b0SBaptiste Daroussin 	}
7670c8de5b0SBaptiste Daroussin break;
7680c8de5b0SBaptiste Daroussin case 17:
7690c8de5b0SBaptiste Daroussin #line 116 "varsyntax_calc1.y"
7700c8de5b0SBaptiste Daroussin 	{
7710c8de5b0SBaptiste Daroussin 		yyval.vval.lo = yystack.l_mark[-3].dval;
7720c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yystack.l_mark[-1].dval;
7730c8de5b0SBaptiste Daroussin 		if ( yyval.vval.lo > yyval.vval.hi )
7740c8de5b0SBaptiste Daroussin 		{
7750c8de5b0SBaptiste Daroussin 			(void) printf("interval out of order\n");
7760c8de5b0SBaptiste Daroussin 			YYERROR;
7770c8de5b0SBaptiste Daroussin 		}
7780c8de5b0SBaptiste Daroussin 	}
7790c8de5b0SBaptiste Daroussin break;
7800c8de5b0SBaptiste Daroussin case 18:
7810c8de5b0SBaptiste Daroussin #line 126 "varsyntax_calc1.y"
7820c8de5b0SBaptiste Daroussin 	{
7830c8de5b0SBaptiste Daroussin 		yyval.vval = vreg[yystack.l_mark[0].ival];
7840c8de5b0SBaptiste Daroussin 	}
7850c8de5b0SBaptiste Daroussin break;
7860c8de5b0SBaptiste Daroussin case 19:
7870c8de5b0SBaptiste Daroussin #line 130 "varsyntax_calc1.y"
7880c8de5b0SBaptiste Daroussin 	{
7890c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yystack.l_mark[-2].vval.hi + yystack.l_mark[0].vval.hi;
7900c8de5b0SBaptiste Daroussin 		yyval.vval.lo = yystack.l_mark[-2].vval.lo + yystack.l_mark[0].vval.lo;
7910c8de5b0SBaptiste Daroussin 	}
7920c8de5b0SBaptiste Daroussin break;
7930c8de5b0SBaptiste Daroussin case 20:
7940c8de5b0SBaptiste Daroussin #line 135 "varsyntax_calc1.y"
7950c8de5b0SBaptiste Daroussin 	{
7960c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.hi;
7970c8de5b0SBaptiste Daroussin 		yyval.vval.lo = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.lo;
7980c8de5b0SBaptiste Daroussin 	}
7990c8de5b0SBaptiste Daroussin break;
8000c8de5b0SBaptiste Daroussin case 21:
8010c8de5b0SBaptiste Daroussin #line 140 "varsyntax_calc1.y"
8020c8de5b0SBaptiste Daroussin 	{
8030c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yystack.l_mark[-2].vval.hi - yystack.l_mark[0].vval.lo;
8040c8de5b0SBaptiste Daroussin 		yyval.vval.lo = yystack.l_mark[-2].vval.lo - yystack.l_mark[0].vval.hi;
8050c8de5b0SBaptiste Daroussin 	}
8060c8de5b0SBaptiste Daroussin break;
8070c8de5b0SBaptiste Daroussin case 22:
8080c8de5b0SBaptiste Daroussin #line 145 "varsyntax_calc1.y"
8090c8de5b0SBaptiste Daroussin 	{
8100c8de5b0SBaptiste Daroussin 		yyval.vval.hi = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.lo;
8110c8de5b0SBaptiste Daroussin 		yyval.vval.lo = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.hi;
8120c8de5b0SBaptiste Daroussin 	}
8130c8de5b0SBaptiste Daroussin break;
8140c8de5b0SBaptiste Daroussin case 23:
8150c8de5b0SBaptiste Daroussin #line 150 "varsyntax_calc1.y"
8160c8de5b0SBaptiste Daroussin 	{
8170c8de5b0SBaptiste Daroussin 		yyval.vval = vmul( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
8180c8de5b0SBaptiste Daroussin 	}
8190c8de5b0SBaptiste Daroussin break;
8200c8de5b0SBaptiste Daroussin case 24:
8210c8de5b0SBaptiste Daroussin #line 154 "varsyntax_calc1.y"
8220c8de5b0SBaptiste Daroussin 	{
8230c8de5b0SBaptiste Daroussin 		yyval.vval = vmul (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
8240c8de5b0SBaptiste Daroussin 	}
8250c8de5b0SBaptiste Daroussin break;
8260c8de5b0SBaptiste Daroussin case 25:
8270c8de5b0SBaptiste Daroussin #line 158 "varsyntax_calc1.y"
8280c8de5b0SBaptiste Daroussin 	{
8290c8de5b0SBaptiste Daroussin 		if (dcheck(yystack.l_mark[0].vval)) YYERROR;
8300c8de5b0SBaptiste Daroussin 		yyval.vval = vdiv ( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
8310c8de5b0SBaptiste Daroussin 	}
8320c8de5b0SBaptiste Daroussin break;
8330c8de5b0SBaptiste Daroussin case 26:
8340c8de5b0SBaptiste Daroussin #line 163 "varsyntax_calc1.y"
8350c8de5b0SBaptiste Daroussin 	{
8360c8de5b0SBaptiste Daroussin 		if (dcheck ( yystack.l_mark[0].vval )) YYERROR;
8370c8de5b0SBaptiste Daroussin 		yyval.vval = vdiv (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
8380c8de5b0SBaptiste Daroussin 	}
8390c8de5b0SBaptiste Daroussin break;
8400c8de5b0SBaptiste Daroussin case 27:
8410c8de5b0SBaptiste Daroussin #line 168 "varsyntax_calc1.y"
8420c8de5b0SBaptiste Daroussin 	{
8430c8de5b0SBaptiste Daroussin 		yyval.vval.hi = -yystack.l_mark[0].vval.lo;
8440c8de5b0SBaptiste Daroussin 		yyval.vval.lo = -yystack.l_mark[0].vval.hi;
8450c8de5b0SBaptiste Daroussin 	}
8460c8de5b0SBaptiste Daroussin break;
8470c8de5b0SBaptiste Daroussin case 28:
8480c8de5b0SBaptiste Daroussin #line 173 "varsyntax_calc1.y"
8490c8de5b0SBaptiste Daroussin 	{
8500c8de5b0SBaptiste Daroussin 		yyval.vval = yystack.l_mark[-1].vval;
8510c8de5b0SBaptiste Daroussin 	}
8520c8de5b0SBaptiste Daroussin break;
853*c5b5d71aSJung-uk Kim #line 854 "varsyntax_calc1.tab.c"
8540c8de5b0SBaptiste Daroussin     }
8550c8de5b0SBaptiste Daroussin     yystack.s_mark -= yym;
8560c8de5b0SBaptiste Daroussin     yystate = *yystack.s_mark;
8570c8de5b0SBaptiste Daroussin     yystack.l_mark -= yym;
8580c8de5b0SBaptiste Daroussin     yym = yylhs[yyn];
8590c8de5b0SBaptiste Daroussin     if (yystate == 0 && yym == 0)
8600c8de5b0SBaptiste Daroussin     {
8610c8de5b0SBaptiste Daroussin #if YYDEBUG
8620c8de5b0SBaptiste Daroussin         if (yydebug)
8630c8de5b0SBaptiste Daroussin             printf("%sdebug: after reduction, shifting from state 0 to\
8640c8de5b0SBaptiste Daroussin  state %d\n", YYPREFIX, YYFINAL);
8650c8de5b0SBaptiste Daroussin #endif
8660c8de5b0SBaptiste Daroussin         yystate = YYFINAL;
8670c8de5b0SBaptiste Daroussin         *++yystack.s_mark = YYFINAL;
8680c8de5b0SBaptiste Daroussin         *++yystack.l_mark = yyval;
8690c8de5b0SBaptiste Daroussin         if (yychar < 0)
8700c8de5b0SBaptiste Daroussin         {
871*c5b5d71aSJung-uk Kim             yychar = YYLEX;
872*c5b5d71aSJung-uk Kim             if (yychar < 0) yychar = YYEOF;
8730c8de5b0SBaptiste Daroussin #if YYDEBUG
8740c8de5b0SBaptiste Daroussin             if (yydebug)
8750c8de5b0SBaptiste Daroussin             {
876*c5b5d71aSJung-uk Kim                 if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
8770c8de5b0SBaptiste Daroussin                 printf("%sdebug: state %d, reading %d (%s)\n",
8780c8de5b0SBaptiste Daroussin                         YYPREFIX, YYFINAL, yychar, yys);
8790c8de5b0SBaptiste Daroussin             }
8800c8de5b0SBaptiste Daroussin #endif
8810c8de5b0SBaptiste Daroussin         }
8820c8de5b0SBaptiste Daroussin         if (yychar == YYEOF) goto yyaccept;
8830c8de5b0SBaptiste Daroussin         goto yyloop;
8840c8de5b0SBaptiste Daroussin     }
885*c5b5d71aSJung-uk Kim     if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
886*c5b5d71aSJung-uk Kim             yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
8870c8de5b0SBaptiste Daroussin         yystate = yytable[yyn];
8880c8de5b0SBaptiste Daroussin     else
8890c8de5b0SBaptiste Daroussin         yystate = yydgoto[yym];
8900c8de5b0SBaptiste Daroussin #if YYDEBUG
8910c8de5b0SBaptiste Daroussin     if (yydebug)
8920c8de5b0SBaptiste Daroussin         printf("%sdebug: after reduction, shifting from state %d \
8930c8de5b0SBaptiste Daroussin to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
8940c8de5b0SBaptiste Daroussin #endif
895*c5b5d71aSJung-uk Kim     if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
8960c8de5b0SBaptiste Daroussin     *++yystack.s_mark = (YYINT) yystate;
8970c8de5b0SBaptiste Daroussin     *++yystack.l_mark = yyval;
8980c8de5b0SBaptiste Daroussin     goto yyloop;
8990c8de5b0SBaptiste Daroussin 
9000c8de5b0SBaptiste Daroussin yyoverflow:
9010c8de5b0SBaptiste Daroussin     YYERROR_CALL("yacc stack overflow");
9020c8de5b0SBaptiste Daroussin 
9030c8de5b0SBaptiste Daroussin yyabort:
9040c8de5b0SBaptiste Daroussin     yyfreestack(&yystack);
9050c8de5b0SBaptiste Daroussin     return (1);
9060c8de5b0SBaptiste Daroussin 
9070c8de5b0SBaptiste Daroussin yyaccept:
9080c8de5b0SBaptiste Daroussin     yyfreestack(&yystack);
9090c8de5b0SBaptiste Daroussin     return (0);
9100c8de5b0SBaptiste Daroussin }
911