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
68e022d3cSDag-Erling Smørgrav #define YYMAJOR 2
78e022d3cSDag-Erling Smørgrav #define YYMINOR 0
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
133c5b5d71aSJung-uk Kim #line 32 "varsyntax_calc1.y"
134*822ca327SBaptiste Daroussin typedef union YYSTYPE
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
327b53bb29fSJung-uk Kim #if YYDEBUG
3280c8de5b0SBaptiste Daroussin int yydebug;
329b53bb29fSJung-uk Kim #endif
3300c8de5b0SBaptiste Daroussin
3310c8de5b0SBaptiste Daroussin int yyerrflag;
3320c8de5b0SBaptiste Daroussin int yychar;
3330c8de5b0SBaptiste Daroussin YYSTYPE yyval;
3340c8de5b0SBaptiste Daroussin YYSTYPE yylval;
335b53bb29fSJung-uk Kim int yynerrs;
3360c8de5b0SBaptiste Daroussin
3370c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
3380c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
3390c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
3400c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE
3410c8de5b0SBaptiste Daroussin #else
3420c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
3430c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
3440c8de5b0SBaptiste Daroussin #else
3450c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
3460c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000
3470c8de5b0SBaptiste Daroussin #endif
3480c8de5b0SBaptiste Daroussin #endif
3490c8de5b0SBaptiste Daroussin
3500c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
3510c8de5b0SBaptiste Daroussin
3520c8de5b0SBaptiste Daroussin typedef struct {
3530c8de5b0SBaptiste Daroussin unsigned stacksize;
3540c8de5b0SBaptiste Daroussin YYINT *s_base;
3550c8de5b0SBaptiste Daroussin YYINT *s_mark;
3560c8de5b0SBaptiste Daroussin YYINT *s_last;
3570c8de5b0SBaptiste Daroussin YYSTYPE *l_base;
3580c8de5b0SBaptiste Daroussin YYSTYPE *l_mark;
3590c8de5b0SBaptiste Daroussin } YYSTACKDATA;
3600c8de5b0SBaptiste Daroussin /* variables for the parser stack */
3610c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
3620c8de5b0SBaptiste Daroussin #line 178 "varsyntax_calc1.y"
3630c8de5b0SBaptiste Daroussin /* beginning of subroutines section */
3640c8de5b0SBaptiste Daroussin
3650c8de5b0SBaptiste Daroussin #define BSZ 50 /* buffer size for floating point numbers */
3660c8de5b0SBaptiste Daroussin
3670c8de5b0SBaptiste Daroussin /* lexical analysis */
3680c8de5b0SBaptiste Daroussin
3690c8de5b0SBaptiste Daroussin static void
yyerror(const char * s)3700c8de5b0SBaptiste Daroussin yyerror(const char *s)
3710c8de5b0SBaptiste Daroussin {
3720c8de5b0SBaptiste Daroussin fprintf(stderr, "%s\n", s);
3730c8de5b0SBaptiste Daroussin }
3740c8de5b0SBaptiste Daroussin
3750c8de5b0SBaptiste Daroussin int
yylex(void)3760c8de5b0SBaptiste Daroussin yylex(void)
3770c8de5b0SBaptiste Daroussin {
3780c8de5b0SBaptiste Daroussin int c;
3790c8de5b0SBaptiste Daroussin
3800c8de5b0SBaptiste Daroussin while ((c = getchar()) == ' ')
3810c8de5b0SBaptiste Daroussin { /* skip over blanks */
3820c8de5b0SBaptiste Daroussin }
3830c8de5b0SBaptiste Daroussin
3840c8de5b0SBaptiste Daroussin if (isupper(c))
3850c8de5b0SBaptiste Daroussin {
3860c8de5b0SBaptiste Daroussin yylval.ival = c - 'A';
3870c8de5b0SBaptiste Daroussin return (VREG);
3880c8de5b0SBaptiste Daroussin }
3890c8de5b0SBaptiste Daroussin if (islower(c))
3900c8de5b0SBaptiste Daroussin {
3910c8de5b0SBaptiste Daroussin yylval.ival = c - 'a';
3920c8de5b0SBaptiste Daroussin return (DREG);
3930c8de5b0SBaptiste Daroussin }
3940c8de5b0SBaptiste Daroussin
3950c8de5b0SBaptiste Daroussin if (isdigit(c) || c == '.')
3960c8de5b0SBaptiste Daroussin {
3970c8de5b0SBaptiste Daroussin /* gobble up digits, points, exponents */
3980c8de5b0SBaptiste Daroussin char buf[BSZ + 1], *cp = buf;
3990c8de5b0SBaptiste Daroussin int dot = 0, expr = 0;
4000c8de5b0SBaptiste Daroussin
4010c8de5b0SBaptiste Daroussin for (; (cp - buf) < BSZ; ++cp, c = getchar())
4020c8de5b0SBaptiste Daroussin {
4030c8de5b0SBaptiste Daroussin
4040c8de5b0SBaptiste Daroussin *cp = (char) c;
4050c8de5b0SBaptiste Daroussin if (isdigit(c))
4060c8de5b0SBaptiste Daroussin continue;
4070c8de5b0SBaptiste Daroussin if (c == '.')
4080c8de5b0SBaptiste Daroussin {
4090c8de5b0SBaptiste Daroussin if (dot++ || expr)
4100c8de5b0SBaptiste Daroussin return ('.'); /* will cause syntax error */
4110c8de5b0SBaptiste Daroussin continue;
4120c8de5b0SBaptiste Daroussin }
4130c8de5b0SBaptiste Daroussin
4140c8de5b0SBaptiste Daroussin if (c == 'e')
4150c8de5b0SBaptiste Daroussin {
4160c8de5b0SBaptiste Daroussin if (expr++)
4170c8de5b0SBaptiste Daroussin return ('e'); /* will cause syntax error */
4180c8de5b0SBaptiste Daroussin continue;
4190c8de5b0SBaptiste Daroussin }
4200c8de5b0SBaptiste Daroussin
4210c8de5b0SBaptiste Daroussin /* end of number */
4220c8de5b0SBaptiste Daroussin break;
4230c8de5b0SBaptiste Daroussin }
4240c8de5b0SBaptiste Daroussin *cp = '\0';
4250c8de5b0SBaptiste Daroussin
4260c8de5b0SBaptiste Daroussin if ((cp - buf) >= BSZ)
4270c8de5b0SBaptiste Daroussin printf("constant too long: truncated\n");
4280c8de5b0SBaptiste Daroussin else
4290c8de5b0SBaptiste Daroussin ungetc(c, stdin); /* push back last char read */
4300c8de5b0SBaptiste Daroussin yylval.dval = atof(buf);
4310c8de5b0SBaptiste Daroussin return (CONST);
4320c8de5b0SBaptiste Daroussin }
4330c8de5b0SBaptiste Daroussin return (c);
4340c8de5b0SBaptiste Daroussin }
4350c8de5b0SBaptiste Daroussin
4360c8de5b0SBaptiste Daroussin static INTERVAL
hilo(double a,double b,double c,double d)4370c8de5b0SBaptiste Daroussin hilo(double a, double b, double c, double d)
4380c8de5b0SBaptiste Daroussin {
4390c8de5b0SBaptiste Daroussin /* returns the smallest interval containing a, b, c, and d */
4400c8de5b0SBaptiste Daroussin /* used by *, / routines */
4410c8de5b0SBaptiste Daroussin INTERVAL v;
4420c8de5b0SBaptiste Daroussin
4430c8de5b0SBaptiste Daroussin if (a > b)
4440c8de5b0SBaptiste Daroussin {
4450c8de5b0SBaptiste Daroussin v.hi = a;
4460c8de5b0SBaptiste Daroussin v.lo = b;
4470c8de5b0SBaptiste Daroussin }
4480c8de5b0SBaptiste Daroussin else
4490c8de5b0SBaptiste Daroussin {
4500c8de5b0SBaptiste Daroussin v.hi = b;
4510c8de5b0SBaptiste Daroussin v.lo = a;
4520c8de5b0SBaptiste Daroussin }
4530c8de5b0SBaptiste Daroussin
4540c8de5b0SBaptiste Daroussin if (c > d)
4550c8de5b0SBaptiste Daroussin {
4560c8de5b0SBaptiste Daroussin if (c > v.hi)
4570c8de5b0SBaptiste Daroussin v.hi = c;
4580c8de5b0SBaptiste Daroussin if (d < v.lo)
4590c8de5b0SBaptiste Daroussin v.lo = d;
4600c8de5b0SBaptiste Daroussin }
4610c8de5b0SBaptiste Daroussin else
4620c8de5b0SBaptiste Daroussin {
4630c8de5b0SBaptiste Daroussin if (d > v.hi)
4640c8de5b0SBaptiste Daroussin v.hi = d;
4650c8de5b0SBaptiste Daroussin if (c < v.lo)
4660c8de5b0SBaptiste Daroussin v.lo = c;
4670c8de5b0SBaptiste Daroussin }
4680c8de5b0SBaptiste Daroussin return (v);
4690c8de5b0SBaptiste Daroussin }
4700c8de5b0SBaptiste Daroussin
4710c8de5b0SBaptiste Daroussin INTERVAL
vmul(double a,double b,INTERVAL v)4720c8de5b0SBaptiste Daroussin vmul(double a, double b, INTERVAL v)
4730c8de5b0SBaptiste Daroussin {
4740c8de5b0SBaptiste Daroussin return (hilo(a * v.hi, a * v.lo, b * v.hi, b * v.lo));
4750c8de5b0SBaptiste Daroussin }
4760c8de5b0SBaptiste Daroussin
4770c8de5b0SBaptiste Daroussin int
dcheck(INTERVAL v)4780c8de5b0SBaptiste Daroussin dcheck(INTERVAL v)
4790c8de5b0SBaptiste Daroussin {
4800c8de5b0SBaptiste Daroussin if (v.hi >= 0. && v.lo <= 0.)
4810c8de5b0SBaptiste Daroussin {
4820c8de5b0SBaptiste Daroussin printf("divisor interval contains 0.\n");
4830c8de5b0SBaptiste Daroussin return (1);
4840c8de5b0SBaptiste Daroussin }
4850c8de5b0SBaptiste Daroussin return (0);
4860c8de5b0SBaptiste Daroussin }
4870c8de5b0SBaptiste Daroussin
4880c8de5b0SBaptiste Daroussin INTERVAL
vdiv(double a,double b,INTERVAL v)4890c8de5b0SBaptiste Daroussin vdiv(double a, double b, INTERVAL v)
4900c8de5b0SBaptiste Daroussin {
4910c8de5b0SBaptiste Daroussin return (hilo(a / v.hi, a / v.lo, b / v.hi, b / v.lo));
4920c8de5b0SBaptiste Daroussin }
493b53bb29fSJung-uk Kim #line 494 "varsyntax_calc1.tab.c"
4940c8de5b0SBaptiste Daroussin
4950c8de5b0SBaptiste Daroussin #if YYDEBUG
4960c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */
4970c8de5b0SBaptiste Daroussin #endif
4980c8de5b0SBaptiste Daroussin
4990c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */
5000c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */
5010c8de5b0SBaptiste Daroussin
5020c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
yygrowstack(YYSTACKDATA * data)5030c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
5040c8de5b0SBaptiste Daroussin {
5050c8de5b0SBaptiste Daroussin int i;
5060c8de5b0SBaptiste Daroussin unsigned newsize;
5070c8de5b0SBaptiste Daroussin YYINT *newss;
5080c8de5b0SBaptiste Daroussin YYSTYPE *newvs;
5090c8de5b0SBaptiste Daroussin
5100c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0)
5110c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE;
5120c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH)
5130c8de5b0SBaptiste Daroussin return YYENOMEM;
5140c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH)
5150c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH;
5160c8de5b0SBaptiste Daroussin
5170c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base);
5180c8de5b0SBaptiste Daroussin newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
519bf80e08eSJung-uk Kim if (newss == NULL)
5200c8de5b0SBaptiste Daroussin return YYENOMEM;
5210c8de5b0SBaptiste Daroussin
5220c8de5b0SBaptiste Daroussin data->s_base = newss;
5230c8de5b0SBaptiste Daroussin data->s_mark = newss + i;
5240c8de5b0SBaptiste Daroussin
5250c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
526bf80e08eSJung-uk Kim if (newvs == NULL)
5270c8de5b0SBaptiste Daroussin return YYENOMEM;
5280c8de5b0SBaptiste Daroussin
5290c8de5b0SBaptiste Daroussin data->l_base = newvs;
5300c8de5b0SBaptiste Daroussin data->l_mark = newvs + i;
5310c8de5b0SBaptiste Daroussin
5320c8de5b0SBaptiste Daroussin data->stacksize = newsize;
5330c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1;
5340c8de5b0SBaptiste Daroussin return 0;
5350c8de5b0SBaptiste Daroussin }
5360c8de5b0SBaptiste Daroussin
5370c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
yyfreestack(YYSTACKDATA * data)5380c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
5390c8de5b0SBaptiste Daroussin {
5400c8de5b0SBaptiste Daroussin free(data->s_base);
5410c8de5b0SBaptiste Daroussin free(data->l_base);
5420c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data));
5430c8de5b0SBaptiste Daroussin }
5440c8de5b0SBaptiste Daroussin #else
5450c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
5460c8de5b0SBaptiste Daroussin #endif
5470c8de5b0SBaptiste Daroussin
5480c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort
5490c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
5500c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
5510c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab
5520c8de5b0SBaptiste Daroussin
5530c8de5b0SBaptiste Daroussin int
YYPARSE_DECL()5540c8de5b0SBaptiste Daroussin YYPARSE_DECL()
5550c8de5b0SBaptiste Daroussin {
5560c8de5b0SBaptiste Daroussin int yym, yyn, yystate;
5570c8de5b0SBaptiste Daroussin #if YYDEBUG
5580c8de5b0SBaptiste Daroussin const char *yys;
5590c8de5b0SBaptiste Daroussin
560bf80e08eSJung-uk Kim if ((yys = getenv("YYDEBUG")) != NULL)
5610c8de5b0SBaptiste Daroussin {
5620c8de5b0SBaptiste Daroussin yyn = *yys;
5630c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9')
5640c8de5b0SBaptiste Daroussin yydebug = yyn - '0';
5650c8de5b0SBaptiste Daroussin }
5660c8de5b0SBaptiste Daroussin #endif
5670c8de5b0SBaptiste Daroussin
5688e022d3cSDag-Erling Smørgrav /* yym is set below */
5698e022d3cSDag-Erling Smørgrav /* yyn is set below */
5700c8de5b0SBaptiste Daroussin yynerrs = 0;
5710c8de5b0SBaptiste Daroussin yyerrflag = 0;
5720c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
5730c8de5b0SBaptiste Daroussin yystate = 0;
5740c8de5b0SBaptiste Daroussin
5750c8de5b0SBaptiste Daroussin #if YYPURE
5760c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack));
5770c8de5b0SBaptiste Daroussin #endif
5780c8de5b0SBaptiste Daroussin
5790c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
5800c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base;
5810c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base;
5820c8de5b0SBaptiste Daroussin yystate = 0;
5830c8de5b0SBaptiste Daroussin *yystack.s_mark = 0;
5840c8de5b0SBaptiste Daroussin
5850c8de5b0SBaptiste Daroussin yyloop:
5860c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
5870c8de5b0SBaptiste Daroussin if (yychar < 0)
5880c8de5b0SBaptiste Daroussin {
589c5b5d71aSJung-uk Kim yychar = YYLEX;
590c5b5d71aSJung-uk Kim if (yychar < 0) yychar = YYEOF;
5910c8de5b0SBaptiste Daroussin #if YYDEBUG
5920c8de5b0SBaptiste Daroussin if (yydebug)
5930c8de5b0SBaptiste Daroussin {
594c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
5950c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, reading %d (%s)\n",
5960c8de5b0SBaptiste Daroussin YYPREFIX, yystate, yychar, yys);
5970c8de5b0SBaptiste Daroussin }
5980c8de5b0SBaptiste Daroussin #endif
5990c8de5b0SBaptiste Daroussin }
600c5b5d71aSJung-uk Kim if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
601c5b5d71aSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
6020c8de5b0SBaptiste Daroussin {
6030c8de5b0SBaptiste Daroussin #if YYDEBUG
6040c8de5b0SBaptiste Daroussin if (yydebug)
6050c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, shifting to state %d\n",
6060c8de5b0SBaptiste Daroussin YYPREFIX, yystate, yytable[yyn]);
6070c8de5b0SBaptiste Daroussin #endif
608c5b5d71aSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
6090c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
6100c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
6110c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
6120c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
6130c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag;
6140c8de5b0SBaptiste Daroussin goto yyloop;
6150c8de5b0SBaptiste Daroussin }
616c5b5d71aSJung-uk Kim if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
617c5b5d71aSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
6180c8de5b0SBaptiste Daroussin {
6190c8de5b0SBaptiste Daroussin yyn = yytable[yyn];
6200c8de5b0SBaptiste Daroussin goto yyreduce;
6210c8de5b0SBaptiste Daroussin }
622c5b5d71aSJung-uk Kim if (yyerrflag != 0) goto yyinrecovery;
6230c8de5b0SBaptiste Daroussin
6240c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error");
6250c8de5b0SBaptiste Daroussin
626c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
6270c8de5b0SBaptiste Daroussin yyerrlab:
6280c8de5b0SBaptiste Daroussin ++yynerrs;
6290c8de5b0SBaptiste Daroussin
6300c8de5b0SBaptiste Daroussin yyinrecovery:
6310c8de5b0SBaptiste Daroussin if (yyerrflag < 3)
6320c8de5b0SBaptiste Daroussin {
6330c8de5b0SBaptiste Daroussin yyerrflag = 3;
6340c8de5b0SBaptiste Daroussin for (;;)
6350c8de5b0SBaptiste Daroussin {
636c5b5d71aSJung-uk Kim if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
637c5b5d71aSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
6380c8de5b0SBaptiste Daroussin {
6390c8de5b0SBaptiste Daroussin #if YYDEBUG
6400c8de5b0SBaptiste Daroussin if (yydebug)
6410c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, error recovery shifting\
6420c8de5b0SBaptiste Daroussin to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
6430c8de5b0SBaptiste Daroussin #endif
644c5b5d71aSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
6450c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
6460c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
6470c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
6480c8de5b0SBaptiste Daroussin goto yyloop;
6490c8de5b0SBaptiste Daroussin }
6500c8de5b0SBaptiste Daroussin else
6510c8de5b0SBaptiste Daroussin {
6520c8de5b0SBaptiste Daroussin #if YYDEBUG
6530c8de5b0SBaptiste Daroussin if (yydebug)
6540c8de5b0SBaptiste Daroussin printf("%sdebug: error recovery discarding state %d\n",
6550c8de5b0SBaptiste Daroussin YYPREFIX, *yystack.s_mark);
6560c8de5b0SBaptiste Daroussin #endif
6570c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort;
6580c8de5b0SBaptiste Daroussin --yystack.s_mark;
6590c8de5b0SBaptiste Daroussin --yystack.l_mark;
6600c8de5b0SBaptiste Daroussin }
6610c8de5b0SBaptiste Daroussin }
6620c8de5b0SBaptiste Daroussin }
6630c8de5b0SBaptiste Daroussin else
6640c8de5b0SBaptiste Daroussin {
6650c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort;
6660c8de5b0SBaptiste Daroussin #if YYDEBUG
6670c8de5b0SBaptiste Daroussin if (yydebug)
6680c8de5b0SBaptiste Daroussin {
669c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
6700c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
6710c8de5b0SBaptiste Daroussin YYPREFIX, yystate, yychar, yys);
6720c8de5b0SBaptiste Daroussin }
6730c8de5b0SBaptiste Daroussin #endif
6740c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
6750c8de5b0SBaptiste Daroussin goto yyloop;
6760c8de5b0SBaptiste Daroussin }
6770c8de5b0SBaptiste Daroussin
6780c8de5b0SBaptiste Daroussin yyreduce:
6790c8de5b0SBaptiste Daroussin #if YYDEBUG
6800c8de5b0SBaptiste Daroussin if (yydebug)
6810c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, reducing by rule %d (%s)\n",
6820c8de5b0SBaptiste Daroussin YYPREFIX, yystate, yyn, yyrule[yyn]);
6830c8de5b0SBaptiste Daroussin #endif
6840c8de5b0SBaptiste Daroussin yym = yylen[yyn];
685c5b5d71aSJung-uk Kim if (yym > 0)
6860c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym];
6870c8de5b0SBaptiste Daroussin else
6880c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval);
689c5b5d71aSJung-uk Kim
6900c8de5b0SBaptiste Daroussin switch (yyn)
6910c8de5b0SBaptiste Daroussin {
6920c8de5b0SBaptiste Daroussin case 3:
6930c8de5b0SBaptiste Daroussin #line 59 "varsyntax_calc1.y"
6940c8de5b0SBaptiste Daroussin {
6950c8de5b0SBaptiste Daroussin (void) printf("%15.8f\n", yystack.l_mark[-1].dval);
6960c8de5b0SBaptiste Daroussin }
6978e022d3cSDag-Erling Smørgrav #line 698 "varsyntax_calc1.tab.c"
6980c8de5b0SBaptiste Daroussin break;
6990c8de5b0SBaptiste Daroussin case 4:
7000c8de5b0SBaptiste Daroussin #line 63 "varsyntax_calc1.y"
7010c8de5b0SBaptiste Daroussin {
7020c8de5b0SBaptiste Daroussin (void) printf("(%15.8f, %15.8f)\n", yystack.l_mark[-1].vval.lo, yystack.l_mark[-1].vval.hi);
7030c8de5b0SBaptiste Daroussin }
7048e022d3cSDag-Erling Smørgrav #line 705 "varsyntax_calc1.tab.c"
7050c8de5b0SBaptiste Daroussin break;
7060c8de5b0SBaptiste Daroussin case 5:
7070c8de5b0SBaptiste Daroussin #line 67 "varsyntax_calc1.y"
7080c8de5b0SBaptiste Daroussin {
7090c8de5b0SBaptiste Daroussin dreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].dval;
7100c8de5b0SBaptiste Daroussin }
7118e022d3cSDag-Erling Smørgrav #line 712 "varsyntax_calc1.tab.c"
7120c8de5b0SBaptiste Daroussin break;
7130c8de5b0SBaptiste Daroussin case 6:
7140c8de5b0SBaptiste Daroussin #line 71 "varsyntax_calc1.y"
7150c8de5b0SBaptiste Daroussin {
7160c8de5b0SBaptiste Daroussin vreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].vval;
7170c8de5b0SBaptiste Daroussin }
7188e022d3cSDag-Erling Smørgrav #line 719 "varsyntax_calc1.tab.c"
7190c8de5b0SBaptiste Daroussin break;
7200c8de5b0SBaptiste Daroussin case 7:
7210c8de5b0SBaptiste Daroussin #line 75 "varsyntax_calc1.y"
7220c8de5b0SBaptiste Daroussin {
7230c8de5b0SBaptiste Daroussin yyerrok;
7240c8de5b0SBaptiste Daroussin }
7258e022d3cSDag-Erling Smørgrav #line 726 "varsyntax_calc1.tab.c"
7260c8de5b0SBaptiste Daroussin break;
7270c8de5b0SBaptiste Daroussin case 9:
7280c8de5b0SBaptiste Daroussin #line 82 "varsyntax_calc1.y"
7290c8de5b0SBaptiste Daroussin {
7300c8de5b0SBaptiste Daroussin yyval.dval = dreg[yystack.l_mark[0].ival]; /* $$ & $1 are sufficient here*/
7310c8de5b0SBaptiste Daroussin }
7328e022d3cSDag-Erling Smørgrav #line 733 "varsyntax_calc1.tab.c"
7330c8de5b0SBaptiste Daroussin break;
7340c8de5b0SBaptiste Daroussin case 10:
7350c8de5b0SBaptiste Daroussin #line 86 "varsyntax_calc1.y"
7360c8de5b0SBaptiste Daroussin {
7370c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval + yystack.l_mark[0].dval;
7380c8de5b0SBaptiste Daroussin }
7398e022d3cSDag-Erling Smørgrav #line 740 "varsyntax_calc1.tab.c"
7400c8de5b0SBaptiste Daroussin break;
7410c8de5b0SBaptiste Daroussin case 11:
7420c8de5b0SBaptiste Daroussin #line 90 "varsyntax_calc1.y"
7430c8de5b0SBaptiste Daroussin {
7440c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval - yystack.l_mark[0].dval;
7450c8de5b0SBaptiste Daroussin }
7468e022d3cSDag-Erling Smørgrav #line 747 "varsyntax_calc1.tab.c"
7470c8de5b0SBaptiste Daroussin break;
7480c8de5b0SBaptiste Daroussin case 12:
7490c8de5b0SBaptiste Daroussin #line 94 "varsyntax_calc1.y"
7500c8de5b0SBaptiste Daroussin {
7510c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval * yystack.l_mark[0].dval;
7520c8de5b0SBaptiste Daroussin }
7538e022d3cSDag-Erling Smørgrav #line 754 "varsyntax_calc1.tab.c"
7540c8de5b0SBaptiste Daroussin break;
7550c8de5b0SBaptiste Daroussin case 13:
7560c8de5b0SBaptiste Daroussin #line 98 "varsyntax_calc1.y"
7570c8de5b0SBaptiste Daroussin {
7580c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval / yystack.l_mark[0].dval;
7590c8de5b0SBaptiste Daroussin }
7608e022d3cSDag-Erling Smørgrav #line 761 "varsyntax_calc1.tab.c"
7610c8de5b0SBaptiste Daroussin break;
7620c8de5b0SBaptiste Daroussin case 14:
7630c8de5b0SBaptiste Daroussin #line 102 "varsyntax_calc1.y"
7640c8de5b0SBaptiste Daroussin {
7650c8de5b0SBaptiste Daroussin yyval.dval = -yystack.l_mark[0].dval;
7660c8de5b0SBaptiste Daroussin }
7678e022d3cSDag-Erling Smørgrav #line 768 "varsyntax_calc1.tab.c"
7680c8de5b0SBaptiste Daroussin break;
7690c8de5b0SBaptiste Daroussin case 15:
7700c8de5b0SBaptiste Daroussin #line 106 "varsyntax_calc1.y"
7710c8de5b0SBaptiste Daroussin {
7720c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-1].dval;
7730c8de5b0SBaptiste Daroussin }
7748e022d3cSDag-Erling Smørgrav #line 775 "varsyntax_calc1.tab.c"
7750c8de5b0SBaptiste Daroussin break;
7760c8de5b0SBaptiste Daroussin case 16:
7770c8de5b0SBaptiste Daroussin #line 112 "varsyntax_calc1.y"
7780c8de5b0SBaptiste Daroussin {
7790c8de5b0SBaptiste Daroussin yyval.vval.hi = yyval.vval.lo = yystack.l_mark[0].dval;
7800c8de5b0SBaptiste Daroussin }
7818e022d3cSDag-Erling Smørgrav #line 782 "varsyntax_calc1.tab.c"
7820c8de5b0SBaptiste Daroussin break;
7830c8de5b0SBaptiste Daroussin case 17:
7840c8de5b0SBaptiste Daroussin #line 116 "varsyntax_calc1.y"
7850c8de5b0SBaptiste Daroussin {
7860c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-3].dval;
7870c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-1].dval;
7880c8de5b0SBaptiste Daroussin if ( yyval.vval.lo > yyval.vval.hi )
7890c8de5b0SBaptiste Daroussin {
7900c8de5b0SBaptiste Daroussin (void) printf("interval out of order\n");
7910c8de5b0SBaptiste Daroussin YYERROR;
7920c8de5b0SBaptiste Daroussin }
7930c8de5b0SBaptiste Daroussin }
7948e022d3cSDag-Erling Smørgrav #line 795 "varsyntax_calc1.tab.c"
7950c8de5b0SBaptiste Daroussin break;
7960c8de5b0SBaptiste Daroussin case 18:
7970c8de5b0SBaptiste Daroussin #line 126 "varsyntax_calc1.y"
7980c8de5b0SBaptiste Daroussin {
7990c8de5b0SBaptiste Daroussin yyval.vval = vreg[yystack.l_mark[0].ival];
8000c8de5b0SBaptiste Daroussin }
8018e022d3cSDag-Erling Smørgrav #line 802 "varsyntax_calc1.tab.c"
8020c8de5b0SBaptiste Daroussin break;
8030c8de5b0SBaptiste Daroussin case 19:
8040c8de5b0SBaptiste Daroussin #line 130 "varsyntax_calc1.y"
8050c8de5b0SBaptiste Daroussin {
8060c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi + yystack.l_mark[0].vval.hi;
8070c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo + yystack.l_mark[0].vval.lo;
8080c8de5b0SBaptiste Daroussin }
8098e022d3cSDag-Erling Smørgrav #line 810 "varsyntax_calc1.tab.c"
8100c8de5b0SBaptiste Daroussin break;
8110c8de5b0SBaptiste Daroussin case 20:
8120c8de5b0SBaptiste Daroussin #line 135 "varsyntax_calc1.y"
8130c8de5b0SBaptiste Daroussin {
8140c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.hi;
8150c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.lo;
8160c8de5b0SBaptiste Daroussin }
8178e022d3cSDag-Erling Smørgrav #line 818 "varsyntax_calc1.tab.c"
8180c8de5b0SBaptiste Daroussin break;
8190c8de5b0SBaptiste Daroussin case 21:
8200c8de5b0SBaptiste Daroussin #line 140 "varsyntax_calc1.y"
8210c8de5b0SBaptiste Daroussin {
8220c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi - yystack.l_mark[0].vval.lo;
8230c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo - yystack.l_mark[0].vval.hi;
8240c8de5b0SBaptiste Daroussin }
8258e022d3cSDag-Erling Smørgrav #line 826 "varsyntax_calc1.tab.c"
8260c8de5b0SBaptiste Daroussin break;
8270c8de5b0SBaptiste Daroussin case 22:
8280c8de5b0SBaptiste Daroussin #line 145 "varsyntax_calc1.y"
8290c8de5b0SBaptiste Daroussin {
8300c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.lo;
8310c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.hi;
8320c8de5b0SBaptiste Daroussin }
8338e022d3cSDag-Erling Smørgrav #line 834 "varsyntax_calc1.tab.c"
8340c8de5b0SBaptiste Daroussin break;
8350c8de5b0SBaptiste Daroussin case 23:
8360c8de5b0SBaptiste Daroussin #line 150 "varsyntax_calc1.y"
8370c8de5b0SBaptiste Daroussin {
8380c8de5b0SBaptiste Daroussin yyval.vval = vmul( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
8390c8de5b0SBaptiste Daroussin }
8408e022d3cSDag-Erling Smørgrav #line 841 "varsyntax_calc1.tab.c"
8410c8de5b0SBaptiste Daroussin break;
8420c8de5b0SBaptiste Daroussin case 24:
8430c8de5b0SBaptiste Daroussin #line 154 "varsyntax_calc1.y"
8440c8de5b0SBaptiste Daroussin {
8450c8de5b0SBaptiste Daroussin yyval.vval = vmul (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
8460c8de5b0SBaptiste Daroussin }
8478e022d3cSDag-Erling Smørgrav #line 848 "varsyntax_calc1.tab.c"
8480c8de5b0SBaptiste Daroussin break;
8490c8de5b0SBaptiste Daroussin case 25:
8500c8de5b0SBaptiste Daroussin #line 158 "varsyntax_calc1.y"
8510c8de5b0SBaptiste Daroussin {
8520c8de5b0SBaptiste Daroussin if (dcheck(yystack.l_mark[0].vval)) YYERROR;
8530c8de5b0SBaptiste Daroussin yyval.vval = vdiv ( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
8540c8de5b0SBaptiste Daroussin }
8558e022d3cSDag-Erling Smørgrav #line 856 "varsyntax_calc1.tab.c"
8560c8de5b0SBaptiste Daroussin break;
8570c8de5b0SBaptiste Daroussin case 26:
8580c8de5b0SBaptiste Daroussin #line 163 "varsyntax_calc1.y"
8590c8de5b0SBaptiste Daroussin {
8600c8de5b0SBaptiste Daroussin if (dcheck ( yystack.l_mark[0].vval )) YYERROR;
8610c8de5b0SBaptiste Daroussin yyval.vval = vdiv (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
8620c8de5b0SBaptiste Daroussin }
8638e022d3cSDag-Erling Smørgrav #line 864 "varsyntax_calc1.tab.c"
8640c8de5b0SBaptiste Daroussin break;
8650c8de5b0SBaptiste Daroussin case 27:
8660c8de5b0SBaptiste Daroussin #line 168 "varsyntax_calc1.y"
8670c8de5b0SBaptiste Daroussin {
8680c8de5b0SBaptiste Daroussin yyval.vval.hi = -yystack.l_mark[0].vval.lo;
8690c8de5b0SBaptiste Daroussin yyval.vval.lo = -yystack.l_mark[0].vval.hi;
8700c8de5b0SBaptiste Daroussin }
8718e022d3cSDag-Erling Smørgrav #line 872 "varsyntax_calc1.tab.c"
8720c8de5b0SBaptiste Daroussin break;
8730c8de5b0SBaptiste Daroussin case 28:
8740c8de5b0SBaptiste Daroussin #line 173 "varsyntax_calc1.y"
8750c8de5b0SBaptiste Daroussin {
8760c8de5b0SBaptiste Daroussin yyval.vval = yystack.l_mark[-1].vval;
8770c8de5b0SBaptiste Daroussin }
8788e022d3cSDag-Erling Smørgrav #line 879 "varsyntax_calc1.tab.c"
8790c8de5b0SBaptiste Daroussin break;
8808e022d3cSDag-Erling Smørgrav #line 881 "varsyntax_calc1.tab.c"
8810c8de5b0SBaptiste Daroussin }
8820c8de5b0SBaptiste Daroussin yystack.s_mark -= yym;
8830c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark;
8840c8de5b0SBaptiste Daroussin yystack.l_mark -= yym;
8850c8de5b0SBaptiste Daroussin yym = yylhs[yyn];
8860c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0)
8870c8de5b0SBaptiste Daroussin {
8880c8de5b0SBaptiste Daroussin #if YYDEBUG
8890c8de5b0SBaptiste Daroussin if (yydebug)
8900c8de5b0SBaptiste Daroussin printf("%sdebug: after reduction, shifting from state 0 to\
8910c8de5b0SBaptiste Daroussin state %d\n", YYPREFIX, YYFINAL);
8920c8de5b0SBaptiste Daroussin #endif
8930c8de5b0SBaptiste Daroussin yystate = YYFINAL;
8940c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL;
8950c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
8960c8de5b0SBaptiste Daroussin if (yychar < 0)
8970c8de5b0SBaptiste Daroussin {
898c5b5d71aSJung-uk Kim yychar = YYLEX;
899c5b5d71aSJung-uk Kim if (yychar < 0) yychar = YYEOF;
9000c8de5b0SBaptiste Daroussin #if YYDEBUG
9010c8de5b0SBaptiste Daroussin if (yydebug)
9020c8de5b0SBaptiste Daroussin {
903c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
9040c8de5b0SBaptiste Daroussin printf("%sdebug: state %d, reading %d (%s)\n",
9050c8de5b0SBaptiste Daroussin YYPREFIX, YYFINAL, yychar, yys);
9060c8de5b0SBaptiste Daroussin }
9070c8de5b0SBaptiste Daroussin #endif
9080c8de5b0SBaptiste Daroussin }
9090c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept;
9100c8de5b0SBaptiste Daroussin goto yyloop;
9110c8de5b0SBaptiste Daroussin }
912c5b5d71aSJung-uk Kim if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
913c5b5d71aSJung-uk Kim yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
9140c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
9150c8de5b0SBaptiste Daroussin else
9160c8de5b0SBaptiste Daroussin yystate = yydgoto[yym];
9170c8de5b0SBaptiste Daroussin #if YYDEBUG
9180c8de5b0SBaptiste Daroussin if (yydebug)
9190c8de5b0SBaptiste Daroussin printf("%sdebug: after reduction, shifting from state %d \
9200c8de5b0SBaptiste Daroussin to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
9210c8de5b0SBaptiste Daroussin #endif
922c5b5d71aSJung-uk Kim if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
9230c8de5b0SBaptiste Daroussin *++yystack.s_mark = (YYINT) yystate;
9240c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
9250c8de5b0SBaptiste Daroussin goto yyloop;
9260c8de5b0SBaptiste Daroussin
9270c8de5b0SBaptiste Daroussin yyoverflow:
9280c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow");
9290c8de5b0SBaptiste Daroussin
9300c8de5b0SBaptiste Daroussin yyabort:
9310c8de5b0SBaptiste Daroussin yyfreestack(&yystack);
9320c8de5b0SBaptiste Daroussin return (1);
9330c8de5b0SBaptiste Daroussin
9340c8de5b0SBaptiste Daroussin yyaccept:
9350c8de5b0SBaptiste Daroussin yyfreestack(&yystack);
9360c8de5b0SBaptiste Daroussin return (0);
9370c8de5b0SBaptiste Daroussin }
938