10c8de5b0SBaptiste Daroussin /* original parser id follows */
20c8de5b0SBaptiste Daroussin /* yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93" */
3c5b5d71aSJung-uk Kim /* (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 #undef YYBTYACC
180c8de5b0SBaptiste Daroussin #define YYBTYACC 0
190c8de5b0SBaptiste Daroussin #define YYDEBUGSTR YYPREFIX "debug"
200c8de5b0SBaptiste Daroussin
210c8de5b0SBaptiste Daroussin #ifndef yyparse
220c8de5b0SBaptiste Daroussin #define yyparse varsyntax_calc1_parse
230c8de5b0SBaptiste Daroussin #endif /* yyparse */
240c8de5b0SBaptiste Daroussin
250c8de5b0SBaptiste Daroussin #ifndef yylex
260c8de5b0SBaptiste Daroussin #define yylex varsyntax_calc1_lex
270c8de5b0SBaptiste Daroussin #endif /* yylex */
280c8de5b0SBaptiste Daroussin
290c8de5b0SBaptiste Daroussin #ifndef yyerror
300c8de5b0SBaptiste Daroussin #define yyerror varsyntax_calc1_error
310c8de5b0SBaptiste Daroussin #endif /* yyerror */
320c8de5b0SBaptiste Daroussin
330c8de5b0SBaptiste Daroussin #ifndef yychar
340c8de5b0SBaptiste Daroussin #define yychar varsyntax_calc1_char
350c8de5b0SBaptiste Daroussin #endif /* yychar */
360c8de5b0SBaptiste Daroussin
370c8de5b0SBaptiste Daroussin #ifndef yyval
380c8de5b0SBaptiste Daroussin #define yyval varsyntax_calc1_val
390c8de5b0SBaptiste Daroussin #endif /* yyval */
400c8de5b0SBaptiste Daroussin
410c8de5b0SBaptiste Daroussin #ifndef yylval
420c8de5b0SBaptiste Daroussin #define yylval varsyntax_calc1_lval
430c8de5b0SBaptiste Daroussin #endif /* yylval */
440c8de5b0SBaptiste Daroussin
450c8de5b0SBaptiste Daroussin #ifndef yydebug
460c8de5b0SBaptiste Daroussin #define yydebug varsyntax_calc1_debug
470c8de5b0SBaptiste Daroussin #endif /* yydebug */
480c8de5b0SBaptiste Daroussin
490c8de5b0SBaptiste Daroussin #ifndef yynerrs
500c8de5b0SBaptiste Daroussin #define yynerrs varsyntax_calc1_nerrs
510c8de5b0SBaptiste Daroussin #endif /* yynerrs */
520c8de5b0SBaptiste Daroussin
530c8de5b0SBaptiste Daroussin #ifndef yyerrflag
540c8de5b0SBaptiste Daroussin #define yyerrflag varsyntax_calc1_errflag
550c8de5b0SBaptiste Daroussin #endif /* yyerrflag */
560c8de5b0SBaptiste Daroussin
570c8de5b0SBaptiste Daroussin #ifndef yylhs
580c8de5b0SBaptiste Daroussin #define yylhs varsyntax_calc1_lhs
590c8de5b0SBaptiste Daroussin #endif /* yylhs */
600c8de5b0SBaptiste Daroussin
610c8de5b0SBaptiste Daroussin #ifndef yylen
620c8de5b0SBaptiste Daroussin #define yylen varsyntax_calc1_len
630c8de5b0SBaptiste Daroussin #endif /* yylen */
640c8de5b0SBaptiste Daroussin
650c8de5b0SBaptiste Daroussin #ifndef yydefred
660c8de5b0SBaptiste Daroussin #define yydefred varsyntax_calc1_defred
670c8de5b0SBaptiste Daroussin #endif /* yydefred */
680c8de5b0SBaptiste Daroussin
690c8de5b0SBaptiste Daroussin #ifndef yystos
700c8de5b0SBaptiste Daroussin #define yystos varsyntax_calc1_stos
710c8de5b0SBaptiste Daroussin #endif /* yystos */
720c8de5b0SBaptiste Daroussin
730c8de5b0SBaptiste Daroussin #ifndef yydgoto
740c8de5b0SBaptiste Daroussin #define yydgoto varsyntax_calc1_dgoto
750c8de5b0SBaptiste Daroussin #endif /* yydgoto */
760c8de5b0SBaptiste Daroussin
770c8de5b0SBaptiste Daroussin #ifndef yysindex
780c8de5b0SBaptiste Daroussin #define yysindex varsyntax_calc1_sindex
790c8de5b0SBaptiste Daroussin #endif /* yysindex */
800c8de5b0SBaptiste Daroussin
810c8de5b0SBaptiste Daroussin #ifndef yyrindex
820c8de5b0SBaptiste Daroussin #define yyrindex varsyntax_calc1_rindex
830c8de5b0SBaptiste Daroussin #endif /* yyrindex */
840c8de5b0SBaptiste Daroussin
850c8de5b0SBaptiste Daroussin #ifndef yygindex
860c8de5b0SBaptiste Daroussin #define yygindex varsyntax_calc1_gindex
870c8de5b0SBaptiste Daroussin #endif /* yygindex */
880c8de5b0SBaptiste Daroussin
890c8de5b0SBaptiste Daroussin #ifndef yytable
900c8de5b0SBaptiste Daroussin #define yytable varsyntax_calc1_table
910c8de5b0SBaptiste Daroussin #endif /* yytable */
920c8de5b0SBaptiste Daroussin
930c8de5b0SBaptiste Daroussin #ifndef yycheck
940c8de5b0SBaptiste Daroussin #define yycheck varsyntax_calc1_check
950c8de5b0SBaptiste Daroussin #endif /* yycheck */
960c8de5b0SBaptiste Daroussin
970c8de5b0SBaptiste Daroussin #ifndef yyname
980c8de5b0SBaptiste Daroussin #define yyname varsyntax_calc1_name
990c8de5b0SBaptiste Daroussin #endif /* yyname */
1000c8de5b0SBaptiste Daroussin
1010c8de5b0SBaptiste Daroussin #ifndef yyrule
1020c8de5b0SBaptiste Daroussin #define yyrule varsyntax_calc1_rule
1030c8de5b0SBaptiste Daroussin #endif /* yyrule */
1040c8de5b0SBaptiste Daroussin
1050c8de5b0SBaptiste Daroussin #if YYBTYACC
1060c8de5b0SBaptiste Daroussin
1070c8de5b0SBaptiste Daroussin #ifndef yycindex
1080c8de5b0SBaptiste Daroussin #define yycindex varsyntax_calc1_cindex
1090c8de5b0SBaptiste Daroussin #endif /* yycindex */
1100c8de5b0SBaptiste Daroussin
1110c8de5b0SBaptiste Daroussin #ifndef yyctable
1120c8de5b0SBaptiste Daroussin #define yyctable varsyntax_calc1_ctable
1130c8de5b0SBaptiste Daroussin #endif /* yyctable */
1140c8de5b0SBaptiste Daroussin
1150c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
1160c8de5b0SBaptiste Daroussin
1170c8de5b0SBaptiste Daroussin #define YYPREFIX "varsyntax_calc1_"
1180c8de5b0SBaptiste Daroussin
1190c8de5b0SBaptiste Daroussin #define YYPURE 0
1200c8de5b0SBaptiste Daroussin
1210c8de5b0SBaptiste Daroussin #line 3 "varsyntax_calc1.y"
1220c8de5b0SBaptiste Daroussin
1230c8de5b0SBaptiste Daroussin /* http://dinosaur.compilertools.net/yacc/index.html * /*/
1240c8de5b0SBaptiste Daroussin
1250c8de5b0SBaptiste Daroussin #include <stdlib.h>
1260c8de5b0SBaptiste Daroussin #include <stdio.h>
1270c8de5b0SBaptiste Daroussin #include <ctype.h>
1280c8de5b0SBaptiste Daroussin #include <math.h>
1290c8de5b0SBaptiste Daroussin
1300c8de5b0SBaptiste Daroussin typedef struct interval
1310c8de5b0SBaptiste Daroussin {
1320c8de5b0SBaptiste Daroussin double lo, hi;
1330c8de5b0SBaptiste Daroussin }
1340c8de5b0SBaptiste Daroussin INTERVAL;
1350c8de5b0SBaptiste Daroussin
1360c8de5b0SBaptiste Daroussin INTERVAL vmul(double, double, INTERVAL);
1370c8de5b0SBaptiste Daroussin INTERVAL vdiv(double, double, INTERVAL);
1380c8de5b0SBaptiste Daroussin
1390c8de5b0SBaptiste Daroussin extern int yylex(void);
1400c8de5b0SBaptiste Daroussin static void yyerror(const char *s);
1410c8de5b0SBaptiste Daroussin
1420c8de5b0SBaptiste Daroussin int dcheck(INTERVAL);
1430c8de5b0SBaptiste Daroussin
1440c8de5b0SBaptiste Daroussin double dreg[26];
1450c8de5b0SBaptiste Daroussin INTERVAL vreg[26];
1460c8de5b0SBaptiste Daroussin
1470c8de5b0SBaptiste Daroussin #ifdef YYSTYPE
1480c8de5b0SBaptiste Daroussin #undef YYSTYPE_IS_DECLARED
1490c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
1500c8de5b0SBaptiste Daroussin #endif
1510c8de5b0SBaptiste Daroussin #ifndef YYSTYPE_IS_DECLARED
1520c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
153c5b5d71aSJung-uk Kim #line 32 "varsyntax_calc1.y"
154*822ca327SBaptiste Daroussin typedef union YYSTYPE
1550c8de5b0SBaptiste Daroussin {
1560c8de5b0SBaptiste Daroussin int ival; /* dreg & vreg array index values*/
1570c8de5b0SBaptiste Daroussin double dval; /* floating point values*/
1580c8de5b0SBaptiste Daroussin INTERVAL vval; /* interval values*/
1590c8de5b0SBaptiste Daroussin } YYSTYPE;
1600c8de5b0SBaptiste Daroussin #endif /* !YYSTYPE_IS_DECLARED */
1610c8de5b0SBaptiste Daroussin #line 162 "varsyntax_calc1.tab.c"
1620c8de5b0SBaptiste Daroussin
1630c8de5b0SBaptiste Daroussin /* compatibility with bison */
1640c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM
1650c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */
1660c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE
1670c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
1680c8de5b0SBaptiste Daroussin # else
1690c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
1700c8de5b0SBaptiste Daroussin # endif
1710c8de5b0SBaptiste Daroussin #else
1720c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void)
1730c8de5b0SBaptiste Daroussin #endif
1740c8de5b0SBaptiste Daroussin
1750c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */
1760c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM
1770c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
1780c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM)
1790c8de5b0SBaptiste Daroussin #else
1800c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void)
1810c8de5b0SBaptiste Daroussin # define YYLEX yylex()
1820c8de5b0SBaptiste Daroussin #endif
1830c8de5b0SBaptiste Daroussin
1840c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */
1850c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL
1860c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s)
1870c8de5b0SBaptiste Daroussin #endif
1880c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL
1890c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg)
1900c8de5b0SBaptiste Daroussin #endif
1910c8de5b0SBaptiste Daroussin
1920c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL();
1930c8de5b0SBaptiste Daroussin
1940c8de5b0SBaptiste Daroussin #define DREG 257
1950c8de5b0SBaptiste Daroussin #define VREG 258
1960c8de5b0SBaptiste Daroussin #define CONST 259
1970c8de5b0SBaptiste Daroussin #define UMINUS 260
1980c8de5b0SBaptiste Daroussin #define YYERRCODE 256
199b53bb29fSJung-uk Kim typedef int YYINT;
2000c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_lhs[] = { -1,
2010c8de5b0SBaptiste Daroussin 3, 3, 0, 0, 0, 0, 0, 1, 1, 1,
2020c8de5b0SBaptiste Daroussin 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
2030c8de5b0SBaptiste Daroussin 2, 2, 2, 2, 2, 2, 2, 2,
2040c8de5b0SBaptiste Daroussin };
2050c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_len[] = { 2,
2060c8de5b0SBaptiste Daroussin 0, 2, 2, 2, 4, 4, 2, 1, 1, 3,
2070c8de5b0SBaptiste Daroussin 3, 3, 3, 2, 3, 1, 5, 1, 3, 3,
2080c8de5b0SBaptiste Daroussin 3, 3, 3, 3, 3, 3, 2, 3,
2090c8de5b0SBaptiste Daroussin };
2100c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_defred[] = { 0,
2110c8de5b0SBaptiste Daroussin 0, 0, 0, 8, 0, 0, 0, 0, 0, 7,
2120c8de5b0SBaptiste Daroussin 0, 0, 9, 18, 14, 27, 0, 0, 0, 0,
2130c8de5b0SBaptiste Daroussin 0, 0, 3, 0, 0, 0, 0, 4, 0, 0,
2140c8de5b0SBaptiste Daroussin 0, 0, 0, 15, 0, 28, 0, 0, 0, 0,
2150c8de5b0SBaptiste Daroussin 12, 24, 13, 26, 0, 0, 23, 25, 14, 0,
2160c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 5, 6, 0, 0, 0, 12,
2170c8de5b0SBaptiste Daroussin 13, 17,
2180c8de5b0SBaptiste Daroussin };
2192aca18c7SJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING)
2200c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_stos[] = { 0,
2210c8de5b0SBaptiste Daroussin 256, 257, 258, 259, 45, 40, 262, 263, 264, 10,
2220c8de5b0SBaptiste Daroussin 61, 61, 257, 258, 263, 264, 263, 264, 43, 45,
2230c8de5b0SBaptiste Daroussin 42, 47, 10, 43, 45, 42, 47, 10, 45, 40,
2240c8de5b0SBaptiste Daroussin 263, 263, 264, 41, 44, 41, 263, 264, 263, 264,
2250c8de5b0SBaptiste Daroussin 263, 264, 263, 264, 264, 264, 264, 264, 263, 263,
2260c8de5b0SBaptiste Daroussin 43, 45, 42, 47, 10, 10, 263, 263, 263, 263,
2270c8de5b0SBaptiste Daroussin 263, 41,
2280c8de5b0SBaptiste Daroussin };
2292aca18c7SJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */
2300c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_dgoto[] = { 7,
2310c8de5b0SBaptiste Daroussin 32, 9, 0,
2320c8de5b0SBaptiste Daroussin };
2330c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_sindex[] = { -40,
2340c8de5b0SBaptiste Daroussin -8, -48, -47, 0, -37, -37, 0, 2, 17, 0,
2350c8de5b0SBaptiste Daroussin -34, -37, 0, 0, 0, 0, -25, 90, -37, -37,
2360c8de5b0SBaptiste Daroussin -37, -37, 0, -37, -37, -37, -37, 0, -34, -34,
2370c8de5b0SBaptiste Daroussin 25, 125, 31, 0, -34, 0, -11, 37, -11, 37,
2380c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 37, 37, 0, 0, 0, 111,
2390c8de5b0SBaptiste Daroussin -34, -34, -34, -34, 0, 0, 118, 69, 69, 0,
2400c8de5b0SBaptiste Daroussin 0, 0,
2410c8de5b0SBaptiste Daroussin };
2420c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_rindex[] = { 0,
2430c8de5b0SBaptiste Daroussin 0, 38, 44, 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, -9, 0, 0, 0, 0, 51, -3, 56, 61,
2470c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 67, 72, 0, 0, 0, 0,
2480c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 78, 83, 0,
2490c8de5b0SBaptiste Daroussin 0, 0,
2500c8de5b0SBaptiste Daroussin };
2510c8de5b0SBaptiste Daroussin #if YYBTYACC
2520c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_cindex[] = { 0,
2530c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2540c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2550c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2560c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2570c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2580c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2590c8de5b0SBaptiste Daroussin 0, 0,
2600c8de5b0SBaptiste Daroussin };
2610c8de5b0SBaptiste Daroussin #endif
2620c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_gindex[] = { 0,
2630c8de5b0SBaptiste Daroussin 4, 124, 0,
2640c8de5b0SBaptiste Daroussin };
2650c8de5b0SBaptiste Daroussin #define YYTABLESIZE 225
2660c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_table[] = { 6,
2670c8de5b0SBaptiste Daroussin 16, 10, 6, 8, 5, 30, 20, 5, 15, 17,
2680c8de5b0SBaptiste Daroussin 29, 23, 11, 12, 31, 34, 21, 19, 35, 20,
2690c8de5b0SBaptiste Daroussin 0, 22, 37, 39, 41, 43, 28, 0, 0, 0,
2700c8de5b0SBaptiste Daroussin 21, 16, 49, 50, 55, 22, 0, 20, 57, 20,
2710c8de5b0SBaptiste Daroussin 56, 20, 0, 21, 19, 0, 20, 9, 22, 0,
2720c8de5b0SBaptiste Daroussin 0, 0, 0, 18, 58, 59, 60, 61, 26, 24,
2730c8de5b0SBaptiste Daroussin 10, 25, 0, 27, 0, 11, 53, 51, 0, 52,
2740c8de5b0SBaptiste Daroussin 22, 54, 26, 24, 0, 25, 19, 27, 26, 9,
2750c8de5b0SBaptiste Daroussin 9, 21, 9, 27, 9, 18, 18, 10, 18, 0,
2760c8de5b0SBaptiste Daroussin 18, 10, 11, 10, 10, 10, 11, 0, 11, 11,
2770c8de5b0SBaptiste Daroussin 11, 22, 0, 22, 0, 22, 0, 19, 0, 19,
2780c8de5b0SBaptiste Daroussin 53, 19, 21, 0, 21, 54, 21, 0, 10, 0,
2790c8de5b0SBaptiste Daroussin 10, 0, 10, 11, 0, 11, 0, 11, 16, 18,
2800c8de5b0SBaptiste Daroussin 36, 26, 24, 0, 25, 33, 27, 0, 0, 0,
2810c8de5b0SBaptiste Daroussin 0, 0, 38, 40, 42, 44, 0, 45, 46, 47,
2820c8de5b0SBaptiste Daroussin 48, 34, 53, 51, 0, 52, 0, 54, 62, 53,
2830c8de5b0SBaptiste Daroussin 51, 0, 52, 0, 54, 0, 21, 19, 0, 20,
2840c8de5b0SBaptiste Daroussin 0, 22, 0, 0, 0, 0, 0, 0, 0, 0,
2850c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2860c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2870c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2880c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 1, 2, 3, 4, 13,
2890c8de5b0SBaptiste Daroussin 14, 4, 13, 0, 4,
2900c8de5b0SBaptiste Daroussin };
2910c8de5b0SBaptiste Daroussin static const YYINT varsyntax_calc1_check[] = { 40,
2920c8de5b0SBaptiste Daroussin 10, 10, 40, 0, 45, 40, 10, 45, 5, 6,
2930c8de5b0SBaptiste Daroussin 45, 10, 61, 61, 11, 41, 42, 43, 44, 45,
2940c8de5b0SBaptiste Daroussin -1, 47, 19, 20, 21, 22, 10, -1, -1, -1,
2950c8de5b0SBaptiste Daroussin 42, 41, 29, 30, 10, 47, -1, 41, 35, 43,
2960c8de5b0SBaptiste Daroussin 10, 45, -1, 42, 43, -1, 45, 10, 47, -1,
2970c8de5b0SBaptiste Daroussin -1, -1, -1, 10, 51, 52, 53, 54, 42, 43,
2980c8de5b0SBaptiste Daroussin 10, 45, -1, 47, -1, 10, 42, 43, -1, 45,
2990c8de5b0SBaptiste Daroussin 10, 47, 42, 43, -1, 45, 10, 47, 42, 42,
3000c8de5b0SBaptiste Daroussin 43, 10, 45, 47, 47, 42, 43, 10, 45, -1,
3010c8de5b0SBaptiste Daroussin 47, 41, 10, 43, 44, 45, 41, -1, 43, 44,
3020c8de5b0SBaptiste Daroussin 45, 41, -1, 43, -1, 45, -1, 41, -1, 43,
3030c8de5b0SBaptiste Daroussin 42, 45, 41, -1, 43, 47, 45, -1, 41, -1,
3040c8de5b0SBaptiste Daroussin 43, -1, 45, 41, -1, 43, -1, 45, 5, 6,
3050c8de5b0SBaptiste Daroussin 41, 42, 43, -1, 45, 12, 47, -1, -1, -1,
3060c8de5b0SBaptiste Daroussin -1, -1, 19, 20, 21, 22, -1, 24, 25, 26,
3070c8de5b0SBaptiste Daroussin 27, 41, 42, 43, -1, 45, -1, 47, 41, 42,
3080c8de5b0SBaptiste Daroussin 43, -1, 45, -1, 47, -1, 42, 43, -1, 45,
3090c8de5b0SBaptiste Daroussin -1, 47, -1, -1, -1, -1, -1, -1, -1, -1,
3100c8de5b0SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
3110c8de5b0SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
3120c8de5b0SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
3130c8de5b0SBaptiste Daroussin -1, -1, -1, -1, -1, 256, 257, 258, 259, 257,
3140c8de5b0SBaptiste Daroussin 258, 259, 257, -1, 259,
3150c8de5b0SBaptiste Daroussin };
31611fce282SBaptiste Daroussin #if YYBTYACC
31711fce282SBaptiste Daroussin static const YYINT varsyntax_calc1_ctable[] = { -1,
31811fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
31911fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32011fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32111fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32211fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32311fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32411fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32511fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32611fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32711fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32811fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
32911fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33011fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33111fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33211fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33311fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33411fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33511fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33611fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33711fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33811fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
33911fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
34011fce282SBaptiste Daroussin -1, -1, -1, -1,
34111fce282SBaptiste Daroussin };
34211fce282SBaptiste Daroussin #endif
3430c8de5b0SBaptiste Daroussin #define YYFINAL 7
3440c8de5b0SBaptiste Daroussin #ifndef YYDEBUG
3450c8de5b0SBaptiste Daroussin #define YYDEBUG 0
3460c8de5b0SBaptiste Daroussin #endif
3470c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 260
3480c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 266
3490c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
3500c8de5b0SBaptiste Daroussin #if YYDEBUG
3510c8de5b0SBaptiste Daroussin static const char *const varsyntax_calc1_name[] = {
3520c8de5b0SBaptiste Daroussin
3530c8de5b0SBaptiste Daroussin "$end",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,0,0,0,
3540c8de5b0SBaptiste Daroussin 0,0,0,0,0,0,"'('","')'","'*'","'+'","','","'-'",0,"'/'",0,0,0,0,0,0,0,0,0,0,0,0,
3550c8de5b0SBaptiste 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,
3560c8de5b0SBaptiste 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,
3570c8de5b0SBaptiste 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,
3580c8de5b0SBaptiste 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,
3590c8de5b0SBaptiste 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,
3600c8de5b0SBaptiste Daroussin "error","DREG","VREG","CONST","UMINUS","$accept","line","dexp","vexp","lines",
3610c8de5b0SBaptiste Daroussin "illegal-symbol",
3620c8de5b0SBaptiste Daroussin };
3630c8de5b0SBaptiste Daroussin static const char *const varsyntax_calc1_rule[] = {
3640c8de5b0SBaptiste Daroussin "$accept : line",
3650c8de5b0SBaptiste Daroussin "lines :",
3660c8de5b0SBaptiste Daroussin "lines : lines line",
3670c8de5b0SBaptiste Daroussin "line : dexp '\\n'",
3680c8de5b0SBaptiste Daroussin "line : vexp '\\n'",
3690c8de5b0SBaptiste Daroussin "line : DREG '=' dexp '\\n'",
3700c8de5b0SBaptiste Daroussin "line : VREG '=' vexp '\\n'",
3710c8de5b0SBaptiste Daroussin "line : error '\\n'",
3720c8de5b0SBaptiste Daroussin "dexp : CONST",
3730c8de5b0SBaptiste Daroussin "dexp : DREG",
3740c8de5b0SBaptiste Daroussin "dexp : dexp '+' dexp",
3750c8de5b0SBaptiste Daroussin "dexp : dexp '-' dexp",
3760c8de5b0SBaptiste Daroussin "dexp : dexp '*' dexp",
3770c8de5b0SBaptiste Daroussin "dexp : dexp '/' dexp",
3780c8de5b0SBaptiste Daroussin "dexp : '-' dexp",
3790c8de5b0SBaptiste Daroussin "dexp : '(' dexp ')'",
3800c8de5b0SBaptiste Daroussin "vexp : dexp",
3810c8de5b0SBaptiste Daroussin "vexp : '(' dexp ',' dexp ')'",
3820c8de5b0SBaptiste Daroussin "vexp : VREG",
3830c8de5b0SBaptiste Daroussin "vexp : vexp '+' vexp",
3840c8de5b0SBaptiste Daroussin "vexp : dexp '+' vexp",
3850c8de5b0SBaptiste Daroussin "vexp : vexp '-' vexp",
3860c8de5b0SBaptiste Daroussin "vexp : dexp '-' vexp",
3870c8de5b0SBaptiste Daroussin "vexp : vexp '*' vexp",
3880c8de5b0SBaptiste Daroussin "vexp : dexp '*' vexp",
3890c8de5b0SBaptiste Daroussin "vexp : vexp '/' vexp",
3900c8de5b0SBaptiste Daroussin "vexp : dexp '/' vexp",
3910c8de5b0SBaptiste Daroussin "vexp : '-' vexp",
3920c8de5b0SBaptiste Daroussin "vexp : '(' vexp ')'",
3930c8de5b0SBaptiste Daroussin
3940c8de5b0SBaptiste Daroussin };
3950c8de5b0SBaptiste Daroussin #endif
3960c8de5b0SBaptiste Daroussin
397b53bb29fSJung-uk Kim #if YYDEBUG
3980c8de5b0SBaptiste Daroussin int yydebug;
399b53bb29fSJung-uk Kim #endif
4000c8de5b0SBaptiste Daroussin
4010c8de5b0SBaptiste Daroussin int yyerrflag;
4020c8de5b0SBaptiste Daroussin int yychar;
4030c8de5b0SBaptiste Daroussin YYSTYPE yyval;
4040c8de5b0SBaptiste Daroussin YYSTYPE yylval;
405b53bb29fSJung-uk Kim int yynerrs;
406b53bb29fSJung-uk Kim
4070c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4080c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */
4090c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */
4100c8de5b0SBaptiste Daroussin #endif
4110c8de5b0SBaptiste Daroussin
4120c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4130c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT
4140c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \
4150c8de5b0SBaptiste Daroussin do \
4160c8de5b0SBaptiste Daroussin { \
4170c8de5b0SBaptiste Daroussin if (n == 0) \
4180c8de5b0SBaptiste Daroussin { \
419b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \
420b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \
421b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \
422b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \
4230c8de5b0SBaptiste Daroussin } \
4240c8de5b0SBaptiste Daroussin else \
4250c8de5b0SBaptiste Daroussin { \
426b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \
427b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \
428b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \
429b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \
4300c8de5b0SBaptiste Daroussin } \
4310c8de5b0SBaptiste Daroussin } while (0)
4320c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */
4330c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
4340c8de5b0SBaptiste Daroussin #if YYBTYACC
4350c8de5b0SBaptiste Daroussin
4360c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH
4370c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32
4380c8de5b0SBaptiste Daroussin #endif
4390c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
4400c8de5b0SBaptiste Daroussin
4410c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
4420c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
4430c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
4440c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE
4450c8de5b0SBaptiste Daroussin #else
4460c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
4470c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
4480c8de5b0SBaptiste Daroussin #else
4490c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
4500c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000
4510c8de5b0SBaptiste Daroussin #endif
4520c8de5b0SBaptiste Daroussin #endif
4530c8de5b0SBaptiste Daroussin
4540c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE
4550c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
4560c8de5b0SBaptiste Daroussin #endif
4570c8de5b0SBaptiste Daroussin
4580c8de5b0SBaptiste Daroussin typedef struct {
4590c8de5b0SBaptiste Daroussin unsigned stacksize;
460c5b5d71aSJung-uk Kim YYINT *s_base;
461c5b5d71aSJung-uk Kim YYINT *s_mark;
462c5b5d71aSJung-uk Kim YYINT *s_last;
4630c8de5b0SBaptiste Daroussin YYSTYPE *l_base;
4640c8de5b0SBaptiste Daroussin YYSTYPE *l_mark;
4650c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4660c8de5b0SBaptiste Daroussin YYLTYPE *p_base;
4670c8de5b0SBaptiste Daroussin YYLTYPE *p_mark;
4680c8de5b0SBaptiste Daroussin #endif
4690c8de5b0SBaptiste Daroussin } YYSTACKDATA;
4700c8de5b0SBaptiste Daroussin #if YYBTYACC
4710c8de5b0SBaptiste Daroussin
4720c8de5b0SBaptiste Daroussin struct YYParseState_s
4730c8de5b0SBaptiste Daroussin {
4740c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */
4750c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */
4760c8de5b0SBaptiste Daroussin int state; /* saved parser state */
4770c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */
4780c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */
4790c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */
4800c8de5b0SBaptiste Daroussin };
4810c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState;
4820c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
4830c8de5b0SBaptiste Daroussin /* variables for the parser stack */
4840c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
4850c8de5b0SBaptiste Daroussin #if YYBTYACC
4860c8de5b0SBaptiste Daroussin
4870c8de5b0SBaptiste Daroussin /* Current parser state */
4880c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0;
4890c8de5b0SBaptiste Daroussin
4900c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */
4910c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0;
4920c8de5b0SBaptiste Daroussin
4930c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */
4940c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0;
4950c8de5b0SBaptiste Daroussin
4960c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */
4970c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0;
4980c8de5b0SBaptiste Daroussin
4990c8de5b0SBaptiste Daroussin /* End position of lexical value queue */
5000c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0;
5010c8de5b0SBaptiste Daroussin
5020c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */
5030c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0;
5040c8de5b0SBaptiste Daroussin
5050c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5060c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */
5070c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0;
5080c8de5b0SBaptiste Daroussin
5090c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */
5100c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0;
5110c8de5b0SBaptiste Daroussin
5120c8de5b0SBaptiste Daroussin /* End position of lexical position queue */
5130c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0;
5140c8de5b0SBaptiste Daroussin
5150c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */
5160c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0;
5170c8de5b0SBaptiste Daroussin #endif
5180c8de5b0SBaptiste Daroussin
5190c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */
5202aca18c7SJung-uk Kim static YYINT *yylexp = 0;
5210c8de5b0SBaptiste Daroussin
5222aca18c7SJung-uk Kim static YYINT *yylexemes = 0;
5230c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
5240c8de5b0SBaptiste Daroussin #line 178 "varsyntax_calc1.y"
5250c8de5b0SBaptiste Daroussin /* beginning of subroutines section */
5260c8de5b0SBaptiste Daroussin
5270c8de5b0SBaptiste Daroussin #define BSZ 50 /* buffer size for floating point numbers */
5280c8de5b0SBaptiste Daroussin
5290c8de5b0SBaptiste Daroussin /* lexical analysis */
5300c8de5b0SBaptiste Daroussin
5310c8de5b0SBaptiste Daroussin static void
yyerror(const char * s)5320c8de5b0SBaptiste Daroussin yyerror(const char *s)
5330c8de5b0SBaptiste Daroussin {
5340c8de5b0SBaptiste Daroussin fprintf(stderr, "%s\n", s);
5350c8de5b0SBaptiste Daroussin }
5360c8de5b0SBaptiste Daroussin
5370c8de5b0SBaptiste Daroussin int
yylex(void)5380c8de5b0SBaptiste Daroussin yylex(void)
5390c8de5b0SBaptiste Daroussin {
5400c8de5b0SBaptiste Daroussin int c;
5410c8de5b0SBaptiste Daroussin
5420c8de5b0SBaptiste Daroussin while ((c = getchar()) == ' ')
5430c8de5b0SBaptiste Daroussin { /* skip over blanks */
5440c8de5b0SBaptiste Daroussin }
5450c8de5b0SBaptiste Daroussin
5460c8de5b0SBaptiste Daroussin if (isupper(c))
5470c8de5b0SBaptiste Daroussin {
5480c8de5b0SBaptiste Daroussin yylval.ival = c - 'A';
5490c8de5b0SBaptiste Daroussin return (VREG);
5500c8de5b0SBaptiste Daroussin }
5510c8de5b0SBaptiste Daroussin if (islower(c))
5520c8de5b0SBaptiste Daroussin {
5530c8de5b0SBaptiste Daroussin yylval.ival = c - 'a';
5540c8de5b0SBaptiste Daroussin return (DREG);
5550c8de5b0SBaptiste Daroussin }
5560c8de5b0SBaptiste Daroussin
5570c8de5b0SBaptiste Daroussin if (isdigit(c) || c == '.')
5580c8de5b0SBaptiste Daroussin {
5590c8de5b0SBaptiste Daroussin /* gobble up digits, points, exponents */
5600c8de5b0SBaptiste Daroussin char buf[BSZ + 1], *cp = buf;
5610c8de5b0SBaptiste Daroussin int dot = 0, expr = 0;
5620c8de5b0SBaptiste Daroussin
5630c8de5b0SBaptiste Daroussin for (; (cp - buf) < BSZ; ++cp, c = getchar())
5640c8de5b0SBaptiste Daroussin {
5650c8de5b0SBaptiste Daroussin
5660c8de5b0SBaptiste Daroussin *cp = (char) c;
5670c8de5b0SBaptiste Daroussin if (isdigit(c))
5680c8de5b0SBaptiste Daroussin continue;
5690c8de5b0SBaptiste Daroussin if (c == '.')
5700c8de5b0SBaptiste Daroussin {
5710c8de5b0SBaptiste Daroussin if (dot++ || expr)
5720c8de5b0SBaptiste Daroussin return ('.'); /* will cause syntax error */
5730c8de5b0SBaptiste Daroussin continue;
5740c8de5b0SBaptiste Daroussin }
5750c8de5b0SBaptiste Daroussin
5760c8de5b0SBaptiste Daroussin if (c == 'e')
5770c8de5b0SBaptiste Daroussin {
5780c8de5b0SBaptiste Daroussin if (expr++)
5790c8de5b0SBaptiste Daroussin return ('e'); /* will cause syntax error */
5800c8de5b0SBaptiste Daroussin continue;
5810c8de5b0SBaptiste Daroussin }
5820c8de5b0SBaptiste Daroussin
5830c8de5b0SBaptiste Daroussin /* end of number */
5840c8de5b0SBaptiste Daroussin break;
5850c8de5b0SBaptiste Daroussin }
5860c8de5b0SBaptiste Daroussin *cp = '\0';
5870c8de5b0SBaptiste Daroussin
5880c8de5b0SBaptiste Daroussin if ((cp - buf) >= BSZ)
5890c8de5b0SBaptiste Daroussin printf("constant too long: truncated\n");
5900c8de5b0SBaptiste Daroussin else
5910c8de5b0SBaptiste Daroussin ungetc(c, stdin); /* push back last char read */
5920c8de5b0SBaptiste Daroussin yylval.dval = atof(buf);
5930c8de5b0SBaptiste Daroussin return (CONST);
5940c8de5b0SBaptiste Daroussin }
5950c8de5b0SBaptiste Daroussin return (c);
5960c8de5b0SBaptiste Daroussin }
5970c8de5b0SBaptiste Daroussin
5980c8de5b0SBaptiste Daroussin static INTERVAL
hilo(double a,double b,double c,double d)5990c8de5b0SBaptiste Daroussin hilo(double a, double b, double c, double d)
6000c8de5b0SBaptiste Daroussin {
6010c8de5b0SBaptiste Daroussin /* returns the smallest interval containing a, b, c, and d */
6020c8de5b0SBaptiste Daroussin /* used by *, / routines */
6030c8de5b0SBaptiste Daroussin INTERVAL v;
6040c8de5b0SBaptiste Daroussin
6050c8de5b0SBaptiste Daroussin if (a > b)
6060c8de5b0SBaptiste Daroussin {
6070c8de5b0SBaptiste Daroussin v.hi = a;
6080c8de5b0SBaptiste Daroussin v.lo = b;
6090c8de5b0SBaptiste Daroussin }
6100c8de5b0SBaptiste Daroussin else
6110c8de5b0SBaptiste Daroussin {
6120c8de5b0SBaptiste Daroussin v.hi = b;
6130c8de5b0SBaptiste Daroussin v.lo = a;
6140c8de5b0SBaptiste Daroussin }
6150c8de5b0SBaptiste Daroussin
6160c8de5b0SBaptiste Daroussin if (c > d)
6170c8de5b0SBaptiste Daroussin {
6180c8de5b0SBaptiste Daroussin if (c > v.hi)
6190c8de5b0SBaptiste Daroussin v.hi = c;
6200c8de5b0SBaptiste Daroussin if (d < v.lo)
6210c8de5b0SBaptiste Daroussin v.lo = d;
6220c8de5b0SBaptiste Daroussin }
6230c8de5b0SBaptiste Daroussin else
6240c8de5b0SBaptiste Daroussin {
6250c8de5b0SBaptiste Daroussin if (d > v.hi)
6260c8de5b0SBaptiste Daroussin v.hi = d;
6270c8de5b0SBaptiste Daroussin if (c < v.lo)
6280c8de5b0SBaptiste Daroussin v.lo = c;
6290c8de5b0SBaptiste Daroussin }
6300c8de5b0SBaptiste Daroussin return (v);
6310c8de5b0SBaptiste Daroussin }
6320c8de5b0SBaptiste Daroussin
6330c8de5b0SBaptiste Daroussin INTERVAL
vmul(double a,double b,INTERVAL v)6340c8de5b0SBaptiste Daroussin vmul(double a, double b, INTERVAL v)
6350c8de5b0SBaptiste Daroussin {
6360c8de5b0SBaptiste Daroussin return (hilo(a * v.hi, a * v.lo, b * v.hi, b * v.lo));
6370c8de5b0SBaptiste Daroussin }
6380c8de5b0SBaptiste Daroussin
6390c8de5b0SBaptiste Daroussin int
dcheck(INTERVAL v)6400c8de5b0SBaptiste Daroussin dcheck(INTERVAL v)
6410c8de5b0SBaptiste Daroussin {
6420c8de5b0SBaptiste Daroussin if (v.hi >= 0. && v.lo <= 0.)
6430c8de5b0SBaptiste Daroussin {
6440c8de5b0SBaptiste Daroussin printf("divisor interval contains 0.\n");
6450c8de5b0SBaptiste Daroussin return (1);
6460c8de5b0SBaptiste Daroussin }
6470c8de5b0SBaptiste Daroussin return (0);
6480c8de5b0SBaptiste Daroussin }
6490c8de5b0SBaptiste Daroussin
6500c8de5b0SBaptiste Daroussin INTERVAL
vdiv(double a,double b,INTERVAL v)6510c8de5b0SBaptiste Daroussin vdiv(double a, double b, INTERVAL v)
6520c8de5b0SBaptiste Daroussin {
6530c8de5b0SBaptiste Daroussin return (hilo(a / v.hi, a / v.lo, b / v.hi, b / v.lo));
6540c8de5b0SBaptiste Daroussin }
655b53bb29fSJung-uk Kim #line 656 "varsyntax_calc1.tab.c"
6560c8de5b0SBaptiste Daroussin
6570c8de5b0SBaptiste Daroussin /* For use in generated program */
6580c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base)
6590c8de5b0SBaptiste Daroussin #if YYBTYACC
6600c8de5b0SBaptiste Daroussin #define yytrial (yyps->save)
6610c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
6620c8de5b0SBaptiste Daroussin
6630c8de5b0SBaptiste Daroussin #if YYDEBUG
6640c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */
6650c8de5b0SBaptiste Daroussin #endif
6660c8de5b0SBaptiste Daroussin
6670c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */
6680c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */
6690c8de5b0SBaptiste Daroussin
6700c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
yygrowstack(YYSTACKDATA * data)6710c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
6720c8de5b0SBaptiste Daroussin {
6730c8de5b0SBaptiste Daroussin int i;
6740c8de5b0SBaptiste Daroussin unsigned newsize;
675c5b5d71aSJung-uk Kim YYINT *newss;
6760c8de5b0SBaptiste Daroussin YYSTYPE *newvs;
6770c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
6780c8de5b0SBaptiste Daroussin YYLTYPE *newps;
6790c8de5b0SBaptiste Daroussin #endif
6800c8de5b0SBaptiste Daroussin
6810c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0)
6820c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE;
6830c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH)
6840c8de5b0SBaptiste Daroussin return YYENOMEM;
6850c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH)
6860c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH;
6870c8de5b0SBaptiste Daroussin
6880c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base);
689c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
690bf80e08eSJung-uk Kim if (newss == NULL)
6910c8de5b0SBaptiste Daroussin return YYENOMEM;
6920c8de5b0SBaptiste Daroussin
6930c8de5b0SBaptiste Daroussin data->s_base = newss;
6940c8de5b0SBaptiste Daroussin data->s_mark = newss + i;
6950c8de5b0SBaptiste Daroussin
6960c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
697bf80e08eSJung-uk Kim if (newvs == NULL)
6980c8de5b0SBaptiste Daroussin return YYENOMEM;
6990c8de5b0SBaptiste Daroussin
7000c8de5b0SBaptiste Daroussin data->l_base = newvs;
7010c8de5b0SBaptiste Daroussin data->l_mark = newvs + i;
7020c8de5b0SBaptiste Daroussin
7030c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7040c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps));
705bf80e08eSJung-uk Kim if (newps == NULL)
7060c8de5b0SBaptiste Daroussin return YYENOMEM;
7070c8de5b0SBaptiste Daroussin
7080c8de5b0SBaptiste Daroussin data->p_base = newps;
7090c8de5b0SBaptiste Daroussin data->p_mark = newps + i;
7100c8de5b0SBaptiste Daroussin #endif
7110c8de5b0SBaptiste Daroussin
7120c8de5b0SBaptiste Daroussin data->stacksize = newsize;
7130c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1;
7140c8de5b0SBaptiste Daroussin
7150c8de5b0SBaptiste Daroussin #if YYDEBUG
7160c8de5b0SBaptiste Daroussin if (yydebug)
7170c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize);
7180c8de5b0SBaptiste Daroussin #endif
7190c8de5b0SBaptiste Daroussin return 0;
7200c8de5b0SBaptiste Daroussin }
7210c8de5b0SBaptiste Daroussin
7220c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
yyfreestack(YYSTACKDATA * data)7230c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
7240c8de5b0SBaptiste Daroussin {
7250c8de5b0SBaptiste Daroussin free(data->s_base);
7260c8de5b0SBaptiste Daroussin free(data->l_base);
7270c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7280c8de5b0SBaptiste Daroussin free(data->p_base);
7290c8de5b0SBaptiste Daroussin #endif
7300c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data));
7310c8de5b0SBaptiste Daroussin }
7320c8de5b0SBaptiste Daroussin #else
7330c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
7340c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */
7350c8de5b0SBaptiste Daroussin #if YYBTYACC
7360c8de5b0SBaptiste Daroussin
7370c8de5b0SBaptiste Daroussin static YYParseState *
yyNewState(unsigned size)7380c8de5b0SBaptiste Daroussin yyNewState(unsigned size)
7390c8de5b0SBaptiste Daroussin {
7400c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState));
7410c8de5b0SBaptiste Daroussin if (p == NULL) return NULL;
7420c8de5b0SBaptiste Daroussin
7430c8de5b0SBaptiste Daroussin p->yystack.stacksize = size;
7440c8de5b0SBaptiste Daroussin if (size == 0)
7450c8de5b0SBaptiste Daroussin {
7460c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL;
7470c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL;
7480c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7490c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL;
7500c8de5b0SBaptiste Daroussin #endif
7510c8de5b0SBaptiste Daroussin return p;
7520c8de5b0SBaptiste Daroussin }
753c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT));
7540c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL;
7550c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE));
7560c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL;
7570c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE));
7580c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7590c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE));
7600c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL;
7610c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE));
7620c8de5b0SBaptiste Daroussin #endif
7630c8de5b0SBaptiste Daroussin
7640c8de5b0SBaptiste Daroussin return p;
7650c8de5b0SBaptiste Daroussin }
7660c8de5b0SBaptiste Daroussin
7670c8de5b0SBaptiste Daroussin static void
yyFreeState(YYParseState * p)7680c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p)
7690c8de5b0SBaptiste Daroussin {
7700c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack);
7710c8de5b0SBaptiste Daroussin free(p);
7720c8de5b0SBaptiste Daroussin }
7730c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7740c8de5b0SBaptiste Daroussin
7750c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort
7760c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
7770c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
7780c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab
7790c8de5b0SBaptiste Daroussin #if YYBTYACC
7800c8de5b0SBaptiste Daroussin #define YYVALID do { if (yyps->save) goto yyvalid; } while(0)
7810c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \
7820c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0)
7830c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7840c8de5b0SBaptiste Daroussin
7850c8de5b0SBaptiste Daroussin int
YYPARSE_DECL()7860c8de5b0SBaptiste Daroussin YYPARSE_DECL()
7870c8de5b0SBaptiste Daroussin {
7880c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult;
7890c8de5b0SBaptiste Daroussin #if YYBTYACC
7900c8de5b0SBaptiste Daroussin int yynewerrflag;
7910c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL;
7920c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7930c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
794b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */
7950c8de5b0SBaptiste Daroussin #endif
7960c8de5b0SBaptiste Daroussin #if YYDEBUG
7970c8de5b0SBaptiste Daroussin const char *yys;
7980c8de5b0SBaptiste Daroussin
799bf80e08eSJung-uk Kim if ((yys = getenv("YYDEBUG")) != NULL)
8000c8de5b0SBaptiste Daroussin {
8010c8de5b0SBaptiste Daroussin yyn = *yys;
8020c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9')
8030c8de5b0SBaptiste Daroussin yydebug = yyn - '0';
8040c8de5b0SBaptiste Daroussin }
8050c8de5b0SBaptiste Daroussin if (yydebug)
8060c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX);
8070c8de5b0SBaptiste Daroussin #endif
8086166fdceSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8096166fdceSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range));
8106166fdceSJung-uk Kim #endif
8110c8de5b0SBaptiste Daroussin
8120c8de5b0SBaptiste Daroussin #if YYBTYACC
8130c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem;
8140c8de5b0SBaptiste Daroussin yyps->save = 0;
8150c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
816c5b5d71aSJung-uk Kim yym = 0;
8178e022d3cSDag-Erling Smørgrav /* yyn is set below */
8180c8de5b0SBaptiste Daroussin yynerrs = 0;
8190c8de5b0SBaptiste Daroussin yyerrflag = 0;
8200c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
8210c8de5b0SBaptiste Daroussin yystate = 0;
8220c8de5b0SBaptiste Daroussin
8230c8de5b0SBaptiste Daroussin #if YYPURE
8240c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack));
8250c8de5b0SBaptiste Daroussin #endif
8260c8de5b0SBaptiste Daroussin
8270c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
8280c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base;
8290c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base;
8300c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8310c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base;
8320c8de5b0SBaptiste Daroussin #endif
8330c8de5b0SBaptiste Daroussin yystate = 0;
8340c8de5b0SBaptiste Daroussin *yystack.s_mark = 0;
8350c8de5b0SBaptiste Daroussin
8360c8de5b0SBaptiste Daroussin yyloop:
8370c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
8380c8de5b0SBaptiste Daroussin if (yychar < 0)
8390c8de5b0SBaptiste Daroussin {
8400c8de5b0SBaptiste Daroussin #if YYBTYACC
8410c8de5b0SBaptiste Daroussin do {
8420c8de5b0SBaptiste Daroussin if (yylvp < yylve)
8430c8de5b0SBaptiste Daroussin {
8440c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */
8450c8de5b0SBaptiste Daroussin yylval = *yylvp++;
8460c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8470c8de5b0SBaptiste Daroussin yylloc = *yylpp++;
8480c8de5b0SBaptiste Daroussin #endif
8490c8de5b0SBaptiste Daroussin yychar = *yylexp++;
8500c8de5b0SBaptiste Daroussin break;
8510c8de5b0SBaptiste Daroussin }
8520c8de5b0SBaptiste Daroussin if (yyps->save)
8530c8de5b0SBaptiste Daroussin {
8540c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */
8550c8de5b0SBaptiste Daroussin if (yylvp == yylvlim)
8560c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */
85711fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals);
85811fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals);
8590c8de5b0SBaptiste Daroussin
8600c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH;
861b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem;
862b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem;
8630c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
864b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem;
8650c8de5b0SBaptiste Daroussin #endif
8660c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p;
8670c8de5b0SBaptiste Daroussin yylvlim = yylvals + s;
8680c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8690c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p;
8700c8de5b0SBaptiste Daroussin yylplim = yylpsns + s;
8710c8de5b0SBaptiste Daroussin #endif
8720c8de5b0SBaptiste Daroussin yylexp = yylexemes + p;
8730c8de5b0SBaptiste Daroussin }
8742aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX;
8750c8de5b0SBaptiste Daroussin *yylvp++ = yylval;
8760c8de5b0SBaptiste Daroussin yylve++;
8770c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8780c8de5b0SBaptiste Daroussin *yylpp++ = yylloc;
8790c8de5b0SBaptiste Daroussin yylpe++;
8800c8de5b0SBaptiste Daroussin #endif
8810c8de5b0SBaptiste Daroussin yychar = *yylexp++;
8820c8de5b0SBaptiste Daroussin break;
8830c8de5b0SBaptiste Daroussin }
8840c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */
8850c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
8860c8de5b0SBaptiste Daroussin yychar = YYLEX;
8870c8de5b0SBaptiste Daroussin #if YYBTYACC
8880c8de5b0SBaptiste Daroussin } while (0);
8890c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
8900c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF;
8910c8de5b0SBaptiste Daroussin #if YYDEBUG
8920c8de5b0SBaptiste Daroussin if (yydebug)
8930c8de5b0SBaptiste Daroussin {
894c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
8950c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)",
8960c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys);
8970c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
8980c8de5b0SBaptiste Daroussin #if YYBTYACC
8990c8de5b0SBaptiste Daroussin if (!yytrial)
9000c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
9010c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval));
9020c8de5b0SBaptiste Daroussin #endif
9030c8de5b0SBaptiste Daroussin fputc('\n', stderr);
9040c8de5b0SBaptiste Daroussin }
9050c8de5b0SBaptiste Daroussin #endif
9060c8de5b0SBaptiste Daroussin }
9070c8de5b0SBaptiste Daroussin #if YYBTYACC
9080c8de5b0SBaptiste Daroussin
9090c8de5b0SBaptiste Daroussin /* Do we have a conflict? */
9100c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
9110c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
9120c8de5b0SBaptiste Daroussin {
9130c8de5b0SBaptiste Daroussin YYINT ctry;
9140c8de5b0SBaptiste Daroussin
9150c8de5b0SBaptiste Daroussin if (yypath)
9160c8de5b0SBaptiste Daroussin {
9170c8de5b0SBaptiste Daroussin YYParseState *save;
9180c8de5b0SBaptiste Daroussin #if YYDEBUG
9190c8de5b0SBaptiste Daroussin if (yydebug)
9200c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n",
9210c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate);
9220c8de5b0SBaptiste Daroussin #endif
9230c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */
9240c8de5b0SBaptiste Daroussin save = yypath;
9250c8de5b0SBaptiste Daroussin yypath = save->save;
9260c8de5b0SBaptiste Daroussin save->save = NULL;
9270c8de5b0SBaptiste Daroussin ctry = save->ctry;
9280c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT;
9290c8de5b0SBaptiste Daroussin yyFreeState(save);
9300c8de5b0SBaptiste Daroussin
9310c8de5b0SBaptiste Daroussin }
9320c8de5b0SBaptiste Daroussin else
9330c8de5b0SBaptiste Daroussin {
9340c8de5b0SBaptiste Daroussin
9350c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */
9360c8de5b0SBaptiste Daroussin YYParseState *save;
9370c8de5b0SBaptiste Daroussin #if YYDEBUG
9380c8de5b0SBaptiste Daroussin if (yydebug)
9390c8de5b0SBaptiste Daroussin {
9400c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate);
9410c8de5b0SBaptiste Daroussin if (yyps->save)
9420c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr);
9430c8de5b0SBaptiste Daroussin else
9440c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr);
9450c8de5b0SBaptiste Daroussin }
9460c8de5b0SBaptiste Daroussin #endif
9470c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
9480c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem;
9490c8de5b0SBaptiste Daroussin save->save = yyps->save;
9500c8de5b0SBaptiste Daroussin save->state = yystate;
9510c8de5b0SBaptiste Daroussin save->errflag = yyerrflag;
9520c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base);
953c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
9540c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base);
95511fce282SBaptiste Daroussin memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
9560c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9570c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base);
95811fce282SBaptiste Daroussin memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
9590c8de5b0SBaptiste Daroussin #endif
9600c8de5b0SBaptiste Daroussin ctry = yytable[yyn];
9610c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1)
9620c8de5b0SBaptiste Daroussin {
9630c8de5b0SBaptiste Daroussin #if YYDEBUG
9640c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF)
9650c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth);
9660c8de5b0SBaptiste Daroussin #endif
9670c8de5b0SBaptiste Daroussin ctry++;
9680c8de5b0SBaptiste Daroussin }
9690c8de5b0SBaptiste Daroussin save->ctry = ctry;
9700c8de5b0SBaptiste Daroussin if (yyps->save == NULL)
9710c8de5b0SBaptiste Daroussin {
9720c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */
9730c8de5b0SBaptiste Daroussin if (!yylexemes)
9740c8de5b0SBaptiste Daroussin {
975b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT));
9760c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem;
9770c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE));
9780c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem;
9790c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH;
9800c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9810c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE));
9820c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem;
9830c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH;
9840c8de5b0SBaptiste Daroussin #endif
9850c8de5b0SBaptiste Daroussin }
9860c8de5b0SBaptiste Daroussin if (yylvp == yylve)
9870c8de5b0SBaptiste Daroussin {
9880c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals;
9890c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9900c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns;
9910c8de5b0SBaptiste Daroussin #endif
9920c8de5b0SBaptiste Daroussin yylexp = yylexemes;
9930c8de5b0SBaptiste Daroussin if (yychar >= YYEOF)
9940c8de5b0SBaptiste Daroussin {
9950c8de5b0SBaptiste Daroussin *yylve++ = yylval;
9960c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9970c8de5b0SBaptiste Daroussin *yylpe++ = yylloc;
9980c8de5b0SBaptiste Daroussin #endif
9992aca18c7SJung-uk Kim *yylexp = (YYINT) yychar;
10000c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10010c8de5b0SBaptiste Daroussin }
10020c8de5b0SBaptiste Daroussin }
10030c8de5b0SBaptiste Daroussin }
10040c8de5b0SBaptiste Daroussin if (yychar >= YYEOF)
10050c8de5b0SBaptiste Daroussin {
10060c8de5b0SBaptiste Daroussin yylvp--;
10070c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10080c8de5b0SBaptiste Daroussin yylpp--;
10090c8de5b0SBaptiste Daroussin #endif
10100c8de5b0SBaptiste Daroussin yylexp--;
10110c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10120c8de5b0SBaptiste Daroussin }
101311fce282SBaptiste Daroussin save->lexeme = (int) (yylvp - yylvals);
10140c8de5b0SBaptiste Daroussin yyps->save = save;
10150c8de5b0SBaptiste Daroussin }
10160c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry)
10170c8de5b0SBaptiste Daroussin {
10180c8de5b0SBaptiste Daroussin #if YYDEBUG
10190c8de5b0SBaptiste Daroussin if (yydebug)
10200c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
10210c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]);
10220c8de5b0SBaptiste Daroussin #endif
10230c8de5b0SBaptiste Daroussin if (yychar < 0)
10240c8de5b0SBaptiste Daroussin {
10250c8de5b0SBaptiste Daroussin yylvp++;
10260c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10270c8de5b0SBaptiste Daroussin yylpp++;
10280c8de5b0SBaptiste Daroussin #endif
10290c8de5b0SBaptiste Daroussin yylexp++;
10300c8de5b0SBaptiste Daroussin }
10310c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM)
10320c8de5b0SBaptiste Daroussin goto yyoverflow;
10330c8de5b0SBaptiste Daroussin yystate = yyctable[ctry];
1034c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
10350c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
10360c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10370c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc;
10380c8de5b0SBaptiste Daroussin #endif
10390c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10400c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag;
10410c8de5b0SBaptiste Daroussin goto yyloop;
10420c8de5b0SBaptiste Daroussin }
10430c8de5b0SBaptiste Daroussin else
10440c8de5b0SBaptiste Daroussin {
10450c8de5b0SBaptiste Daroussin yyn = yyctable[ctry];
10460c8de5b0SBaptiste Daroussin goto yyreduce;
10470c8de5b0SBaptiste Daroussin }
10480c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */
10490c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
10500c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
10510c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
10520c8de5b0SBaptiste Daroussin {
10530c8de5b0SBaptiste Daroussin #if YYDEBUG
10540c8de5b0SBaptiste Daroussin if (yydebug)
10550c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
10560c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]);
10570c8de5b0SBaptiste Daroussin #endif
10580c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
10590c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
10600c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
10610c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
10620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10630c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc;
10640c8de5b0SBaptiste Daroussin #endif
10650c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10660c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag;
10670c8de5b0SBaptiste Daroussin goto yyloop;
10680c8de5b0SBaptiste Daroussin }
10690c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
10700c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
10710c8de5b0SBaptiste Daroussin {
10720c8de5b0SBaptiste Daroussin yyn = yytable[yyn];
10730c8de5b0SBaptiste Daroussin goto yyreduce;
10740c8de5b0SBaptiste Daroussin }
10750c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery;
10760c8de5b0SBaptiste Daroussin #if YYBTYACC
10770c8de5b0SBaptiste Daroussin
10780c8de5b0SBaptiste Daroussin yynewerrflag = 1;
10790c8de5b0SBaptiste Daroussin goto yyerrhandler;
1080c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
10810c8de5b0SBaptiste Daroussin
10820c8de5b0SBaptiste Daroussin yyerrlab:
1083c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced
1084c5b5d71aSJung-uk Kim * before looking for error recovery */
1085c5b5d71aSJung-uk Kim yystack.s_mark -= yym;
1086c5b5d71aSJung-uk Kim yystate = *yystack.s_mark;
1087c5b5d71aSJung-uk Kim yystack.l_mark -= yym;
1088c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1089c5b5d71aSJung-uk Kim yystack.p_mark -= yym;
1090c5b5d71aSJung-uk Kim #endif
1091c5b5d71aSJung-uk Kim
10920c8de5b0SBaptiste Daroussin yynewerrflag = 0;
10930c8de5b0SBaptiste Daroussin yyerrhandler:
10940c8de5b0SBaptiste Daroussin while (yyps->save)
10950c8de5b0SBaptiste Daroussin {
10960c8de5b0SBaptiste Daroussin int ctry;
10970c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save;
10980c8de5b0SBaptiste Daroussin #if YYDEBUG
10990c8de5b0SBaptiste Daroussin if (yydebug)
11000c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n",
11010c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state,
11020c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme));
11030c8de5b0SBaptiste Daroussin #endif
11040c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */
11050c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals)
11060c8de5b0SBaptiste Daroussin {
11070c8de5b0SBaptiste Daroussin /* Free old saved error context state */
11080c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx);
11090c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */
11100c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
11110c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem;
11120c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save;
11130c8de5b0SBaptiste Daroussin yyerrctx->state = yystate;
11140c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag;
11150c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base);
1116c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11170c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base);
111811fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11190c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11200c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base);
112111fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11220c8de5b0SBaptiste Daroussin #endif
112311fce282SBaptiste Daroussin yyerrctx->lexeme = (int) (yylvp - yylvals);
11240c8de5b0SBaptiste Daroussin }
11250c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme;
11260c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11270c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme;
11280c8de5b0SBaptiste Daroussin #endif
11290c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme;
11300c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
11310c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base);
1132c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11330c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base);
113411fce282SBaptiste Daroussin memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11360c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base);
113711fce282SBaptiste Daroussin memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11380c8de5b0SBaptiste Daroussin #endif
11390c8de5b0SBaptiste Daroussin ctry = ++save->ctry;
11400c8de5b0SBaptiste Daroussin yystate = save->state;
11410c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */
11420c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce;
11430c8de5b0SBaptiste Daroussin yyps->save = save->save;
11440c8de5b0SBaptiste Daroussin save->save = NULL;
11450c8de5b0SBaptiste Daroussin yyFreeState(save);
11460c8de5b0SBaptiste Daroussin
11470c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */
11480c8de5b0SBaptiste Daroussin if (!yyps->save)
11490c8de5b0SBaptiste Daroussin {
11500c8de5b0SBaptiste Daroussin #if YYDEBUG
11510c8de5b0SBaptiste Daroussin if (yydebug)
11520c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n",
11530c8de5b0SBaptiste Daroussin YYPREFIX, yydepth);
11540c8de5b0SBaptiste Daroussin #endif
11550c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */
11560c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme;
11570c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11580c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme;
11590c8de5b0SBaptiste Daroussin #endif
11600c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme;
11610c8de5b0SBaptiste Daroussin yychar = yylexp[-1];
11620c8de5b0SBaptiste Daroussin yylval = yylvp[-1];
11630c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11640c8de5b0SBaptiste Daroussin yylloc = yylpp[-1];
11650c8de5b0SBaptiste Daroussin #endif
11660c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base);
1167c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11680c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base);
116911fce282SBaptiste Daroussin memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11700c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11710c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base);
117211fce282SBaptiste Daroussin memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11730c8de5b0SBaptiste Daroussin #endif
11740c8de5b0SBaptiste Daroussin yystate = yyerrctx->state;
11750c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
11760c8de5b0SBaptiste Daroussin yyerrctx = NULL;
11770c8de5b0SBaptiste Daroussin }
11780c8de5b0SBaptiste Daroussin yynewerrflag = 1;
11790c8de5b0SBaptiste Daroussin }
11800c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery;
11810c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
11820c8de5b0SBaptiste Daroussin
11830c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error");
11840c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1185b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */
11860c8de5b0SBaptiste Daroussin #endif
11870c8de5b0SBaptiste Daroussin
11880c8de5b0SBaptiste Daroussin #if !YYBTYACC
1189c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
11900c8de5b0SBaptiste Daroussin yyerrlab:
11910c8de5b0SBaptiste Daroussin #endif
11920c8de5b0SBaptiste Daroussin ++yynerrs;
11930c8de5b0SBaptiste Daroussin
11940c8de5b0SBaptiste Daroussin yyinrecovery:
11950c8de5b0SBaptiste Daroussin if (yyerrflag < 3)
11960c8de5b0SBaptiste Daroussin {
11970c8de5b0SBaptiste Daroussin yyerrflag = 3;
11980c8de5b0SBaptiste Daroussin for (;;)
11990c8de5b0SBaptiste Daroussin {
12000c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
12010c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
12020c8de5b0SBaptiste Daroussin {
12030c8de5b0SBaptiste Daroussin #if YYDEBUG
12040c8de5b0SBaptiste Daroussin if (yydebug)
12050c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n",
12060c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]);
12070c8de5b0SBaptiste Daroussin #endif
12080c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
12090c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
12100c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
12110c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
12120c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12130c8de5b0SBaptiste Daroussin /* lookahead position is error end position */
1214b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc;
12150c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */
12160c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
12170c8de5b0SBaptiste Daroussin #endif
12180c8de5b0SBaptiste Daroussin goto yyloop;
12190c8de5b0SBaptiste Daroussin }
12200c8de5b0SBaptiste Daroussin else
12210c8de5b0SBaptiste Daroussin {
12220c8de5b0SBaptiste Daroussin #if YYDEBUG
12230c8de5b0SBaptiste Daroussin if (yydebug)
12240c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n",
12250c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark);
12260c8de5b0SBaptiste Daroussin #endif
12270c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort;
12280c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12290c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */
1230b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark;
12310c8de5b0SBaptiste Daroussin #endif
12320c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
12330c8de5b0SBaptiste Daroussin #if YYBTYACC
12340c8de5b0SBaptiste Daroussin if (!yytrial)
12350c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12360c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12370c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state",
12380c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark);
12390c8de5b0SBaptiste Daroussin #else
12400c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state",
12410c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark);
12420c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
12430c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
12440c8de5b0SBaptiste Daroussin --yystack.s_mark;
12450c8de5b0SBaptiste Daroussin --yystack.l_mark;
12460c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12470c8de5b0SBaptiste Daroussin --yystack.p_mark;
12480c8de5b0SBaptiste Daroussin #endif
12490c8de5b0SBaptiste Daroussin }
12500c8de5b0SBaptiste Daroussin }
12510c8de5b0SBaptiste Daroussin }
12520c8de5b0SBaptiste Daroussin else
12530c8de5b0SBaptiste Daroussin {
12540c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort;
12550c8de5b0SBaptiste Daroussin #if YYDEBUG
12560c8de5b0SBaptiste Daroussin if (yydebug)
12570c8de5b0SBaptiste Daroussin {
1258c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
12590c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n",
12600c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys);
12610c8de5b0SBaptiste Daroussin }
12620c8de5b0SBaptiste Daroussin #endif
12630c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
12640c8de5b0SBaptiste Daroussin #if YYBTYACC
12650c8de5b0SBaptiste Daroussin if (!yytrial)
12660c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12670c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12680c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc);
12690c8de5b0SBaptiste Daroussin #else
12700c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval);
12710c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
12720c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
12730c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
12740c8de5b0SBaptiste Daroussin goto yyloop;
12750c8de5b0SBaptiste Daroussin }
12760c8de5b0SBaptiste Daroussin
12770c8de5b0SBaptiste Daroussin yyreduce:
12780c8de5b0SBaptiste Daroussin yym = yylen[yyn];
12790c8de5b0SBaptiste Daroussin #if YYDEBUG
12800c8de5b0SBaptiste Daroussin if (yydebug)
12810c8de5b0SBaptiste Daroussin {
12820c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)",
12830c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]);
12840c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
12850c8de5b0SBaptiste Daroussin #if YYBTYACC
12860c8de5b0SBaptiste Daroussin if (!yytrial)
12870c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12880c8de5b0SBaptiste Daroussin if (yym > 0)
12890c8de5b0SBaptiste Daroussin {
12900c8de5b0SBaptiste Daroussin int i;
12910c8de5b0SBaptiste Daroussin fputc('<', stderr);
12920c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--)
12930c8de5b0SBaptiste Daroussin {
12940c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr);
12950c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]],
12960c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr);
12970c8de5b0SBaptiste Daroussin }
12980c8de5b0SBaptiste Daroussin fputc('>', stderr);
12990c8de5b0SBaptiste Daroussin }
13000c8de5b0SBaptiste Daroussin #endif
13010c8de5b0SBaptiste Daroussin fputc('\n', stderr);
13020c8de5b0SBaptiste Daroussin }
13030c8de5b0SBaptiste Daroussin #endif
13040c8de5b0SBaptiste Daroussin if (yym > 0)
13050c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym];
13060c8de5b0SBaptiste Daroussin else
13070c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval);
13080c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
13090c8de5b0SBaptiste Daroussin
13100c8de5b0SBaptiste Daroussin /* Perform position reduction */
13110c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc));
13120c8de5b0SBaptiste Daroussin #if YYBTYACC
13130c8de5b0SBaptiste Daroussin if (!yytrial)
13140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
13150c8de5b0SBaptiste Daroussin {
1316b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym);
13170c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save
13180c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */
1319b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym];
13200c8de5b0SBaptiste Daroussin }
13210c8de5b0SBaptiste Daroussin #endif
13220c8de5b0SBaptiste Daroussin
13230c8de5b0SBaptiste Daroussin switch (yyn)
13240c8de5b0SBaptiste Daroussin {
13250c8de5b0SBaptiste Daroussin case 3:
13260c8de5b0SBaptiste Daroussin #line 59 "varsyntax_calc1.y"
13270c8de5b0SBaptiste Daroussin {
13280c8de5b0SBaptiste Daroussin (void) printf("%15.8f\n", yystack.l_mark[-1].dval);
13290c8de5b0SBaptiste Daroussin }
13308e022d3cSDag-Erling Smørgrav #line 1331 "varsyntax_calc1.tab.c"
13310c8de5b0SBaptiste Daroussin break;
13320c8de5b0SBaptiste Daroussin case 4:
13330c8de5b0SBaptiste Daroussin #line 63 "varsyntax_calc1.y"
13340c8de5b0SBaptiste Daroussin {
13350c8de5b0SBaptiste Daroussin (void) printf("(%15.8f, %15.8f)\n", yystack.l_mark[-1].vval.lo, yystack.l_mark[-1].vval.hi);
13360c8de5b0SBaptiste Daroussin }
13378e022d3cSDag-Erling Smørgrav #line 1338 "varsyntax_calc1.tab.c"
13380c8de5b0SBaptiste Daroussin break;
13390c8de5b0SBaptiste Daroussin case 5:
13400c8de5b0SBaptiste Daroussin #line 67 "varsyntax_calc1.y"
13410c8de5b0SBaptiste Daroussin {
13420c8de5b0SBaptiste Daroussin dreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].dval;
13430c8de5b0SBaptiste Daroussin }
13448e022d3cSDag-Erling Smørgrav #line 1345 "varsyntax_calc1.tab.c"
13450c8de5b0SBaptiste Daroussin break;
13460c8de5b0SBaptiste Daroussin case 6:
13470c8de5b0SBaptiste Daroussin #line 71 "varsyntax_calc1.y"
13480c8de5b0SBaptiste Daroussin {
13490c8de5b0SBaptiste Daroussin vreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].vval;
13500c8de5b0SBaptiste Daroussin }
13518e022d3cSDag-Erling Smørgrav #line 1352 "varsyntax_calc1.tab.c"
13520c8de5b0SBaptiste Daroussin break;
13530c8de5b0SBaptiste Daroussin case 7:
13540c8de5b0SBaptiste Daroussin #line 75 "varsyntax_calc1.y"
13550c8de5b0SBaptiste Daroussin {
13560c8de5b0SBaptiste Daroussin yyerrok;
13570c8de5b0SBaptiste Daroussin }
13588e022d3cSDag-Erling Smørgrav #line 1359 "varsyntax_calc1.tab.c"
13590c8de5b0SBaptiste Daroussin break;
13600c8de5b0SBaptiste Daroussin case 9:
13610c8de5b0SBaptiste Daroussin #line 82 "varsyntax_calc1.y"
13620c8de5b0SBaptiste Daroussin {
13630c8de5b0SBaptiste Daroussin yyval.dval = dreg[yystack.l_mark[0].ival]; /* $$ & $1 are sufficient here*/
13640c8de5b0SBaptiste Daroussin }
13658e022d3cSDag-Erling Smørgrav #line 1366 "varsyntax_calc1.tab.c"
13660c8de5b0SBaptiste Daroussin break;
13670c8de5b0SBaptiste Daroussin case 10:
13680c8de5b0SBaptiste Daroussin #line 86 "varsyntax_calc1.y"
13690c8de5b0SBaptiste Daroussin {
13700c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval + yystack.l_mark[0].dval;
13710c8de5b0SBaptiste Daroussin }
13728e022d3cSDag-Erling Smørgrav #line 1373 "varsyntax_calc1.tab.c"
13730c8de5b0SBaptiste Daroussin break;
13740c8de5b0SBaptiste Daroussin case 11:
13750c8de5b0SBaptiste Daroussin #line 90 "varsyntax_calc1.y"
13760c8de5b0SBaptiste Daroussin {
13770c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval - yystack.l_mark[0].dval;
13780c8de5b0SBaptiste Daroussin }
13798e022d3cSDag-Erling Smørgrav #line 1380 "varsyntax_calc1.tab.c"
13800c8de5b0SBaptiste Daroussin break;
13810c8de5b0SBaptiste Daroussin case 12:
13820c8de5b0SBaptiste Daroussin #line 94 "varsyntax_calc1.y"
13830c8de5b0SBaptiste Daroussin {
13840c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval * yystack.l_mark[0].dval;
13850c8de5b0SBaptiste Daroussin }
13868e022d3cSDag-Erling Smørgrav #line 1387 "varsyntax_calc1.tab.c"
13870c8de5b0SBaptiste Daroussin break;
13880c8de5b0SBaptiste Daroussin case 13:
13890c8de5b0SBaptiste Daroussin #line 98 "varsyntax_calc1.y"
13900c8de5b0SBaptiste Daroussin {
13910c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval / yystack.l_mark[0].dval;
13920c8de5b0SBaptiste Daroussin }
13938e022d3cSDag-Erling Smørgrav #line 1394 "varsyntax_calc1.tab.c"
13940c8de5b0SBaptiste Daroussin break;
13950c8de5b0SBaptiste Daroussin case 14:
13960c8de5b0SBaptiste Daroussin #line 102 "varsyntax_calc1.y"
13970c8de5b0SBaptiste Daroussin {
13980c8de5b0SBaptiste Daroussin yyval.dval = -yystack.l_mark[0].dval;
13990c8de5b0SBaptiste Daroussin }
14008e022d3cSDag-Erling Smørgrav #line 1401 "varsyntax_calc1.tab.c"
14010c8de5b0SBaptiste Daroussin break;
14020c8de5b0SBaptiste Daroussin case 15:
14030c8de5b0SBaptiste Daroussin #line 106 "varsyntax_calc1.y"
14040c8de5b0SBaptiste Daroussin {
14050c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-1].dval;
14060c8de5b0SBaptiste Daroussin }
14078e022d3cSDag-Erling Smørgrav #line 1408 "varsyntax_calc1.tab.c"
14080c8de5b0SBaptiste Daroussin break;
14090c8de5b0SBaptiste Daroussin case 16:
14100c8de5b0SBaptiste Daroussin #line 112 "varsyntax_calc1.y"
14110c8de5b0SBaptiste Daroussin {
14120c8de5b0SBaptiste Daroussin yyval.vval.hi = yyval.vval.lo = yystack.l_mark[0].dval;
14130c8de5b0SBaptiste Daroussin }
14148e022d3cSDag-Erling Smørgrav #line 1415 "varsyntax_calc1.tab.c"
14150c8de5b0SBaptiste Daroussin break;
14160c8de5b0SBaptiste Daroussin case 17:
14170c8de5b0SBaptiste Daroussin #line 116 "varsyntax_calc1.y"
14180c8de5b0SBaptiste Daroussin {
14190c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-3].dval;
14200c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-1].dval;
14210c8de5b0SBaptiste Daroussin if ( yyval.vval.lo > yyval.vval.hi )
14220c8de5b0SBaptiste Daroussin {
14230c8de5b0SBaptiste Daroussin (void) printf("interval out of order\n");
14240c8de5b0SBaptiste Daroussin YYERROR;
14250c8de5b0SBaptiste Daroussin }
14260c8de5b0SBaptiste Daroussin }
14278e022d3cSDag-Erling Smørgrav #line 1428 "varsyntax_calc1.tab.c"
14280c8de5b0SBaptiste Daroussin break;
14290c8de5b0SBaptiste Daroussin case 18:
14300c8de5b0SBaptiste Daroussin #line 126 "varsyntax_calc1.y"
14310c8de5b0SBaptiste Daroussin {
14320c8de5b0SBaptiste Daroussin yyval.vval = vreg[yystack.l_mark[0].ival];
14330c8de5b0SBaptiste Daroussin }
14348e022d3cSDag-Erling Smørgrav #line 1435 "varsyntax_calc1.tab.c"
14350c8de5b0SBaptiste Daroussin break;
14360c8de5b0SBaptiste Daroussin case 19:
14370c8de5b0SBaptiste Daroussin #line 130 "varsyntax_calc1.y"
14380c8de5b0SBaptiste Daroussin {
14390c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi + yystack.l_mark[0].vval.hi;
14400c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo + yystack.l_mark[0].vval.lo;
14410c8de5b0SBaptiste Daroussin }
14428e022d3cSDag-Erling Smørgrav #line 1443 "varsyntax_calc1.tab.c"
14430c8de5b0SBaptiste Daroussin break;
14440c8de5b0SBaptiste Daroussin case 20:
14450c8de5b0SBaptiste Daroussin #line 135 "varsyntax_calc1.y"
14460c8de5b0SBaptiste Daroussin {
14470c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.hi;
14480c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.lo;
14490c8de5b0SBaptiste Daroussin }
14508e022d3cSDag-Erling Smørgrav #line 1451 "varsyntax_calc1.tab.c"
14510c8de5b0SBaptiste Daroussin break;
14520c8de5b0SBaptiste Daroussin case 21:
14530c8de5b0SBaptiste Daroussin #line 140 "varsyntax_calc1.y"
14540c8de5b0SBaptiste Daroussin {
14550c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi - yystack.l_mark[0].vval.lo;
14560c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo - yystack.l_mark[0].vval.hi;
14570c8de5b0SBaptiste Daroussin }
14588e022d3cSDag-Erling Smørgrav #line 1459 "varsyntax_calc1.tab.c"
14590c8de5b0SBaptiste Daroussin break;
14600c8de5b0SBaptiste Daroussin case 22:
14610c8de5b0SBaptiste Daroussin #line 145 "varsyntax_calc1.y"
14620c8de5b0SBaptiste Daroussin {
14630c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.lo;
14640c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.hi;
14650c8de5b0SBaptiste Daroussin }
14668e022d3cSDag-Erling Smørgrav #line 1467 "varsyntax_calc1.tab.c"
14670c8de5b0SBaptiste Daroussin break;
14680c8de5b0SBaptiste Daroussin case 23:
14690c8de5b0SBaptiste Daroussin #line 150 "varsyntax_calc1.y"
14700c8de5b0SBaptiste Daroussin {
14710c8de5b0SBaptiste Daroussin yyval.vval = vmul( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
14720c8de5b0SBaptiste Daroussin }
14738e022d3cSDag-Erling Smørgrav #line 1474 "varsyntax_calc1.tab.c"
14740c8de5b0SBaptiste Daroussin break;
14750c8de5b0SBaptiste Daroussin case 24:
14760c8de5b0SBaptiste Daroussin #line 154 "varsyntax_calc1.y"
14770c8de5b0SBaptiste Daroussin {
14780c8de5b0SBaptiste Daroussin yyval.vval = vmul (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
14790c8de5b0SBaptiste Daroussin }
14808e022d3cSDag-Erling Smørgrav #line 1481 "varsyntax_calc1.tab.c"
14810c8de5b0SBaptiste Daroussin break;
14820c8de5b0SBaptiste Daroussin case 25:
14830c8de5b0SBaptiste Daroussin #line 158 "varsyntax_calc1.y"
14840c8de5b0SBaptiste Daroussin {
14850c8de5b0SBaptiste Daroussin if (dcheck(yystack.l_mark[0].vval)) YYERROR;
14860c8de5b0SBaptiste Daroussin yyval.vval = vdiv ( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
14870c8de5b0SBaptiste Daroussin }
14888e022d3cSDag-Erling Smørgrav #line 1489 "varsyntax_calc1.tab.c"
14890c8de5b0SBaptiste Daroussin break;
14900c8de5b0SBaptiste Daroussin case 26:
14910c8de5b0SBaptiste Daroussin #line 163 "varsyntax_calc1.y"
14920c8de5b0SBaptiste Daroussin {
14930c8de5b0SBaptiste Daroussin if (dcheck ( yystack.l_mark[0].vval )) YYERROR;
14940c8de5b0SBaptiste Daroussin yyval.vval = vdiv (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
14950c8de5b0SBaptiste Daroussin }
14968e022d3cSDag-Erling Smørgrav #line 1497 "varsyntax_calc1.tab.c"
14970c8de5b0SBaptiste Daroussin break;
14980c8de5b0SBaptiste Daroussin case 27:
14990c8de5b0SBaptiste Daroussin #line 168 "varsyntax_calc1.y"
15000c8de5b0SBaptiste Daroussin {
15010c8de5b0SBaptiste Daroussin yyval.vval.hi = -yystack.l_mark[0].vval.lo;
15020c8de5b0SBaptiste Daroussin yyval.vval.lo = -yystack.l_mark[0].vval.hi;
15030c8de5b0SBaptiste Daroussin }
15048e022d3cSDag-Erling Smørgrav #line 1505 "varsyntax_calc1.tab.c"
15050c8de5b0SBaptiste Daroussin break;
15060c8de5b0SBaptiste Daroussin case 28:
15070c8de5b0SBaptiste Daroussin #line 173 "varsyntax_calc1.y"
15080c8de5b0SBaptiste Daroussin {
15090c8de5b0SBaptiste Daroussin yyval.vval = yystack.l_mark[-1].vval;
15100c8de5b0SBaptiste Daroussin }
15118e022d3cSDag-Erling Smørgrav #line 1512 "varsyntax_calc1.tab.c"
15120c8de5b0SBaptiste Daroussin break;
15138e022d3cSDag-Erling Smørgrav #line 1514 "varsyntax_calc1.tab.c"
15140c8de5b0SBaptiste Daroussin default:
15150c8de5b0SBaptiste Daroussin break;
15160c8de5b0SBaptiste Daroussin }
15170c8de5b0SBaptiste Daroussin yystack.s_mark -= yym;
15180c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark;
15190c8de5b0SBaptiste Daroussin yystack.l_mark -= yym;
15200c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15210c8de5b0SBaptiste Daroussin yystack.p_mark -= yym;
15220c8de5b0SBaptiste Daroussin #endif
15230c8de5b0SBaptiste Daroussin yym = yylhs[yyn];
15240c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0)
15250c8de5b0SBaptiste Daroussin {
15260c8de5b0SBaptiste Daroussin #if YYDEBUG
15270c8de5b0SBaptiste Daroussin if (yydebug)
15280c8de5b0SBaptiste Daroussin {
15290c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
15300c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
15310c8de5b0SBaptiste Daroussin #if YYBTYACC
15320c8de5b0SBaptiste Daroussin if (!yytrial)
15330c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
15340c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval));
15350c8de5b0SBaptiste Daroussin #endif
15360c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL);
15370c8de5b0SBaptiste Daroussin }
15380c8de5b0SBaptiste Daroussin #endif
15390c8de5b0SBaptiste Daroussin yystate = YYFINAL;
15400c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL;
15410c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
15420c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15430c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
15440c8de5b0SBaptiste Daroussin #endif
15450c8de5b0SBaptiste Daroussin if (yychar < 0)
15460c8de5b0SBaptiste Daroussin {
15470c8de5b0SBaptiste Daroussin #if YYBTYACC
15480c8de5b0SBaptiste Daroussin do {
15490c8de5b0SBaptiste Daroussin if (yylvp < yylve)
15500c8de5b0SBaptiste Daroussin {
15510c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */
15520c8de5b0SBaptiste Daroussin yylval = *yylvp++;
15530c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15540c8de5b0SBaptiste Daroussin yylloc = *yylpp++;
15550c8de5b0SBaptiste Daroussin #endif
15560c8de5b0SBaptiste Daroussin yychar = *yylexp++;
15570c8de5b0SBaptiste Daroussin break;
15580c8de5b0SBaptiste Daroussin }
15590c8de5b0SBaptiste Daroussin if (yyps->save)
15600c8de5b0SBaptiste Daroussin {
15610c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */
15620c8de5b0SBaptiste Daroussin if (yylvp == yylvlim)
15630c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */
156411fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals);
156511fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals);
15660c8de5b0SBaptiste Daroussin
15670c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH;
1568b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL)
15690c8de5b0SBaptiste Daroussin goto yyenomem;
1570b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL)
15710c8de5b0SBaptiste Daroussin goto yyenomem;
15720c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1573b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL)
15740c8de5b0SBaptiste Daroussin goto yyenomem;
15750c8de5b0SBaptiste Daroussin #endif
15760c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p;
15770c8de5b0SBaptiste Daroussin yylvlim = yylvals + s;
15780c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15790c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p;
15800c8de5b0SBaptiste Daroussin yylplim = yylpsns + s;
15810c8de5b0SBaptiste Daroussin #endif
15820c8de5b0SBaptiste Daroussin yylexp = yylexemes + p;
15830c8de5b0SBaptiste Daroussin }
15842aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX;
15850c8de5b0SBaptiste Daroussin *yylvp++ = yylval;
15860c8de5b0SBaptiste Daroussin yylve++;
15870c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15880c8de5b0SBaptiste Daroussin *yylpp++ = yylloc;
15890c8de5b0SBaptiste Daroussin yylpe++;
15900c8de5b0SBaptiste Daroussin #endif
15910c8de5b0SBaptiste Daroussin yychar = *yylexp++;
15920c8de5b0SBaptiste Daroussin break;
15930c8de5b0SBaptiste Daroussin }
15940c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */
15950c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
15960c8de5b0SBaptiste Daroussin yychar = YYLEX;
15970c8de5b0SBaptiste Daroussin #if YYBTYACC
15980c8de5b0SBaptiste Daroussin } while (0);
15990c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16000c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF;
16010c8de5b0SBaptiste Daroussin #if YYDEBUG
16020c8de5b0SBaptiste Daroussin if (yydebug)
16030c8de5b0SBaptiste Daroussin {
1604c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
1605c5b5d71aSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n",
16060c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, YYFINAL, yychar, yys);
16070c8de5b0SBaptiste Daroussin }
16080c8de5b0SBaptiste Daroussin #endif
16090c8de5b0SBaptiste Daroussin }
16100c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept;
16110c8de5b0SBaptiste Daroussin goto yyloop;
16120c8de5b0SBaptiste Daroussin }
16130c8de5b0SBaptiste Daroussin if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
16140c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
16150c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
16160c8de5b0SBaptiste Daroussin else
16170c8de5b0SBaptiste Daroussin yystate = yydgoto[yym];
16180c8de5b0SBaptiste Daroussin #if YYDEBUG
16190c8de5b0SBaptiste Daroussin if (yydebug)
16200c8de5b0SBaptiste Daroussin {
16210c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
16220c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
16230c8de5b0SBaptiste Daroussin #if YYBTYACC
16240c8de5b0SBaptiste Daroussin if (!yytrial)
16250c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16260c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval));
16270c8de5b0SBaptiste Daroussin #endif
16280c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate);
16290c8de5b0SBaptiste Daroussin }
16300c8de5b0SBaptiste Daroussin #endif
16310c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
1632c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
16330c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
16340c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16350c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
16360c8de5b0SBaptiste Daroussin #endif
16370c8de5b0SBaptiste Daroussin goto yyloop;
16380c8de5b0SBaptiste Daroussin #if YYBTYACC
16390c8de5b0SBaptiste Daroussin
16400c8de5b0SBaptiste Daroussin /* Reduction declares that this path is valid. Set yypath and do a full parse */
16410c8de5b0SBaptiste Daroussin yyvalid:
16420c8de5b0SBaptiste Daroussin if (yypath) YYABORT;
16430c8de5b0SBaptiste Daroussin while (yyps->save)
16440c8de5b0SBaptiste Daroussin {
16450c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save;
16460c8de5b0SBaptiste Daroussin yyps->save = save->save;
16470c8de5b0SBaptiste Daroussin save->save = yypath;
16480c8de5b0SBaptiste Daroussin yypath = save;
16490c8de5b0SBaptiste Daroussin }
16500c8de5b0SBaptiste Daroussin #if YYDEBUG
16510c8de5b0SBaptiste Daroussin if (yydebug)
16520c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n",
16530c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme));
16540c8de5b0SBaptiste Daroussin #endif
16550c8de5b0SBaptiste Daroussin if (yyerrctx)
16560c8de5b0SBaptiste Daroussin {
16570c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
16580c8de5b0SBaptiste Daroussin yyerrctx = NULL;
16590c8de5b0SBaptiste Daroussin }
16600c8de5b0SBaptiste Daroussin yylvp = yylvals + yypath->lexeme;
16610c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16620c8de5b0SBaptiste Daroussin yylpp = yylpsns + yypath->lexeme;
16630c8de5b0SBaptiste Daroussin #endif
16640c8de5b0SBaptiste Daroussin yylexp = yylexemes + yypath->lexeme;
16650c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
16660c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base);
1667c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
16680c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base);
166911fce282SBaptiste Daroussin memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
16700c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16710c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base);
167211fce282SBaptiste Daroussin memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
16730c8de5b0SBaptiste Daroussin #endif
16740c8de5b0SBaptiste Daroussin yystate = yypath->state;
16750c8de5b0SBaptiste Daroussin goto yyloop;
16760c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16770c8de5b0SBaptiste Daroussin
16780c8de5b0SBaptiste Daroussin yyoverflow:
16790c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow");
16800c8de5b0SBaptiste Daroussin #if YYBTYACC
16810c8de5b0SBaptiste Daroussin goto yyabort_nomem;
16820c8de5b0SBaptiste Daroussin yyenomem:
16830c8de5b0SBaptiste Daroussin YYERROR_CALL("memory exhausted");
16840c8de5b0SBaptiste Daroussin yyabort_nomem:
16850c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16860c8de5b0SBaptiste Daroussin yyresult = 2;
16870c8de5b0SBaptiste Daroussin goto yyreturn;
16880c8de5b0SBaptiste Daroussin
16890c8de5b0SBaptiste Daroussin yyabort:
16900c8de5b0SBaptiste Daroussin yyresult = 1;
16910c8de5b0SBaptiste Daroussin goto yyreturn;
16920c8de5b0SBaptiste Daroussin
16930c8de5b0SBaptiste Daroussin yyaccept:
16940c8de5b0SBaptiste Daroussin #if YYBTYACC
16950c8de5b0SBaptiste Daroussin if (yyps->save) goto yyvalid;
16960c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16970c8de5b0SBaptiste Daroussin yyresult = 0;
16980c8de5b0SBaptiste Daroussin
16990c8de5b0SBaptiste Daroussin yyreturn:
17000c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
17010c8de5b0SBaptiste Daroussin if (yychar != YYEOF && yychar != YYEMPTY)
17020c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
17030c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc);
17040c8de5b0SBaptiste Daroussin #else
17050c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval);
17060c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
17070c8de5b0SBaptiste Daroussin
17080c8de5b0SBaptiste Daroussin {
17090c8de5b0SBaptiste Daroussin YYSTYPE *pv;
17100c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
17110c8de5b0SBaptiste Daroussin YYLTYPE *pp;
17120c8de5b0SBaptiste Daroussin
17130c8de5b0SBaptiste Daroussin for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp)
17140c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state",
17150c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp);
17160c8de5b0SBaptiste Daroussin #else
17170c8de5b0SBaptiste Daroussin for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv)
17180c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state",
17190c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv);
17200c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
17210c8de5b0SBaptiste Daroussin }
17220c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
17230c8de5b0SBaptiste Daroussin
17240c8de5b0SBaptiste Daroussin #if YYBTYACC
17250c8de5b0SBaptiste Daroussin if (yyerrctx)
17260c8de5b0SBaptiste Daroussin {
17270c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
17280c8de5b0SBaptiste Daroussin yyerrctx = NULL;
17290c8de5b0SBaptiste Daroussin }
17300c8de5b0SBaptiste Daroussin while (yyps)
17310c8de5b0SBaptiste Daroussin {
17320c8de5b0SBaptiste Daroussin YYParseState *save = yyps;
17330c8de5b0SBaptiste Daroussin yyps = save->save;
17340c8de5b0SBaptiste Daroussin save->save = NULL;
17350c8de5b0SBaptiste Daroussin yyFreeState(save);
17360c8de5b0SBaptiste Daroussin }
17370c8de5b0SBaptiste Daroussin while (yypath)
17380c8de5b0SBaptiste Daroussin {
17390c8de5b0SBaptiste Daroussin YYParseState *save = yypath;
17400c8de5b0SBaptiste Daroussin yypath = save->save;
17410c8de5b0SBaptiste Daroussin save->save = NULL;
17420c8de5b0SBaptiste Daroussin yyFreeState(save);
17430c8de5b0SBaptiste Daroussin }
17440c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
17450c8de5b0SBaptiste Daroussin yyfreestack(&yystack);
17460c8de5b0SBaptiste Daroussin return (yyresult);
17470c8de5b0SBaptiste Daroussin }
1748