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 #undef YYBTYACC
170c8de5b0SBaptiste Daroussin #define YYBTYACC 0
180c8de5b0SBaptiste Daroussin #define YYDEBUGSTR YYPREFIX "debug"
190c8de5b0SBaptiste Daroussin
200c8de5b0SBaptiste Daroussin #ifndef yyparse
210c8de5b0SBaptiste Daroussin #define yyparse calc1_parse
220c8de5b0SBaptiste Daroussin #endif /* yyparse */
230c8de5b0SBaptiste Daroussin
240c8de5b0SBaptiste Daroussin #ifndef yylex
250c8de5b0SBaptiste Daroussin #define yylex calc1_lex
260c8de5b0SBaptiste Daroussin #endif /* yylex */
270c8de5b0SBaptiste Daroussin
280c8de5b0SBaptiste Daroussin #ifndef yyerror
290c8de5b0SBaptiste Daroussin #define yyerror calc1_error
300c8de5b0SBaptiste Daroussin #endif /* yyerror */
310c8de5b0SBaptiste Daroussin
320c8de5b0SBaptiste Daroussin #ifndef yychar
330c8de5b0SBaptiste Daroussin #define yychar calc1_char
340c8de5b0SBaptiste Daroussin #endif /* yychar */
350c8de5b0SBaptiste Daroussin
360c8de5b0SBaptiste Daroussin #ifndef yyval
370c8de5b0SBaptiste Daroussin #define yyval calc1_val
380c8de5b0SBaptiste Daroussin #endif /* yyval */
390c8de5b0SBaptiste Daroussin
400c8de5b0SBaptiste Daroussin #ifndef yylval
410c8de5b0SBaptiste Daroussin #define yylval calc1_lval
420c8de5b0SBaptiste Daroussin #endif /* yylval */
430c8de5b0SBaptiste Daroussin
440c8de5b0SBaptiste Daroussin #ifndef yydebug
450c8de5b0SBaptiste Daroussin #define yydebug calc1_debug
460c8de5b0SBaptiste Daroussin #endif /* yydebug */
470c8de5b0SBaptiste Daroussin
480c8de5b0SBaptiste Daroussin #ifndef yynerrs
490c8de5b0SBaptiste Daroussin #define yynerrs calc1_nerrs
500c8de5b0SBaptiste Daroussin #endif /* yynerrs */
510c8de5b0SBaptiste Daroussin
520c8de5b0SBaptiste Daroussin #ifndef yyerrflag
530c8de5b0SBaptiste Daroussin #define yyerrflag calc1_errflag
540c8de5b0SBaptiste Daroussin #endif /* yyerrflag */
550c8de5b0SBaptiste Daroussin
560c8de5b0SBaptiste Daroussin #ifndef yylhs
570c8de5b0SBaptiste Daroussin #define yylhs calc1_lhs
580c8de5b0SBaptiste Daroussin #endif /* yylhs */
590c8de5b0SBaptiste Daroussin
600c8de5b0SBaptiste Daroussin #ifndef yylen
610c8de5b0SBaptiste Daroussin #define yylen calc1_len
620c8de5b0SBaptiste Daroussin #endif /* yylen */
630c8de5b0SBaptiste Daroussin
640c8de5b0SBaptiste Daroussin #ifndef yydefred
650c8de5b0SBaptiste Daroussin #define yydefred calc1_defred
660c8de5b0SBaptiste Daroussin #endif /* yydefred */
670c8de5b0SBaptiste Daroussin
680c8de5b0SBaptiste Daroussin #ifndef yystos
690c8de5b0SBaptiste Daroussin #define yystos calc1_stos
700c8de5b0SBaptiste Daroussin #endif /* yystos */
710c8de5b0SBaptiste Daroussin
720c8de5b0SBaptiste Daroussin #ifndef yydgoto
730c8de5b0SBaptiste Daroussin #define yydgoto calc1_dgoto
740c8de5b0SBaptiste Daroussin #endif /* yydgoto */
750c8de5b0SBaptiste Daroussin
760c8de5b0SBaptiste Daroussin #ifndef yysindex
770c8de5b0SBaptiste Daroussin #define yysindex calc1_sindex
780c8de5b0SBaptiste Daroussin #endif /* yysindex */
790c8de5b0SBaptiste Daroussin
800c8de5b0SBaptiste Daroussin #ifndef yyrindex
810c8de5b0SBaptiste Daroussin #define yyrindex calc1_rindex
820c8de5b0SBaptiste Daroussin #endif /* yyrindex */
830c8de5b0SBaptiste Daroussin
840c8de5b0SBaptiste Daroussin #ifndef yygindex
850c8de5b0SBaptiste Daroussin #define yygindex calc1_gindex
860c8de5b0SBaptiste Daroussin #endif /* yygindex */
870c8de5b0SBaptiste Daroussin
880c8de5b0SBaptiste Daroussin #ifndef yytable
890c8de5b0SBaptiste Daroussin #define yytable calc1_table
900c8de5b0SBaptiste Daroussin #endif /* yytable */
910c8de5b0SBaptiste Daroussin
920c8de5b0SBaptiste Daroussin #ifndef yycheck
930c8de5b0SBaptiste Daroussin #define yycheck calc1_check
940c8de5b0SBaptiste Daroussin #endif /* yycheck */
950c8de5b0SBaptiste Daroussin
960c8de5b0SBaptiste Daroussin #ifndef yyname
970c8de5b0SBaptiste Daroussin #define yyname calc1_name
980c8de5b0SBaptiste Daroussin #endif /* yyname */
990c8de5b0SBaptiste Daroussin
1000c8de5b0SBaptiste Daroussin #ifndef yyrule
1010c8de5b0SBaptiste Daroussin #define yyrule calc1_rule
1020c8de5b0SBaptiste Daroussin #endif /* yyrule */
1030c8de5b0SBaptiste Daroussin
1040c8de5b0SBaptiste Daroussin #if YYBTYACC
1050c8de5b0SBaptiste Daroussin
1060c8de5b0SBaptiste Daroussin #ifndef yycindex
1070c8de5b0SBaptiste Daroussin #define yycindex calc1_cindex
1080c8de5b0SBaptiste Daroussin #endif /* yycindex */
1090c8de5b0SBaptiste Daroussin
1100c8de5b0SBaptiste Daroussin #ifndef yyctable
1110c8de5b0SBaptiste Daroussin #define yyctable calc1_ctable
1120c8de5b0SBaptiste Daroussin #endif /* yyctable */
1130c8de5b0SBaptiste Daroussin
1140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
1150c8de5b0SBaptiste Daroussin
1160c8de5b0SBaptiste Daroussin #define YYPREFIX "calc1_"
1170c8de5b0SBaptiste Daroussin
1180c8de5b0SBaptiste Daroussin #define YYPURE 0
1190c8de5b0SBaptiste Daroussin
1200c8de5b0SBaptiste Daroussin #line 2 "calc1.y"
1210c8de5b0SBaptiste Daroussin
1220c8de5b0SBaptiste Daroussin /* http://dinosaur.compilertools.net/yacc/index.html */
1230c8de5b0SBaptiste Daroussin
1240c8de5b0SBaptiste Daroussin #include <stdlib.h>
1250c8de5b0SBaptiste Daroussin #include <stdio.h>
1260c8de5b0SBaptiste Daroussin #include <ctype.h>
1270c8de5b0SBaptiste Daroussin #include <math.h>
1280c8de5b0SBaptiste Daroussin
1290c8de5b0SBaptiste Daroussin typedef struct interval
1300c8de5b0SBaptiste Daroussin {
1310c8de5b0SBaptiste Daroussin double lo, hi;
1320c8de5b0SBaptiste Daroussin }
1330c8de5b0SBaptiste Daroussin INTERVAL;
1340c8de5b0SBaptiste Daroussin
1350c8de5b0SBaptiste Daroussin INTERVAL vmul(double, double, INTERVAL);
1360c8de5b0SBaptiste Daroussin INTERVAL vdiv(double, double, INTERVAL);
1370c8de5b0SBaptiste Daroussin
1380c8de5b0SBaptiste Daroussin extern int yylex(void);
1390c8de5b0SBaptiste Daroussin static void yyerror(const char *s);
1400c8de5b0SBaptiste Daroussin
1410c8de5b0SBaptiste Daroussin int dcheck(INTERVAL);
1420c8de5b0SBaptiste Daroussin
1430c8de5b0SBaptiste Daroussin double dreg[26];
1440c8de5b0SBaptiste Daroussin INTERVAL vreg[26];
1450c8de5b0SBaptiste Daroussin
1460c8de5b0SBaptiste Daroussin #ifdef YYSTYPE
1470c8de5b0SBaptiste Daroussin #undef YYSTYPE_IS_DECLARED
1480c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
1490c8de5b0SBaptiste Daroussin #endif
1500c8de5b0SBaptiste Daroussin #ifndef YYSTYPE_IS_DECLARED
1510c8de5b0SBaptiste Daroussin #define YYSTYPE_IS_DECLARED 1
152c5b5d71aSJung-uk Kim #line 31 "calc1.y"
153*822ca327SBaptiste Daroussin typedef union YYSTYPE
1540c8de5b0SBaptiste Daroussin {
1550c8de5b0SBaptiste Daroussin int ival;
1560c8de5b0SBaptiste Daroussin double dval;
1570c8de5b0SBaptiste Daroussin INTERVAL vval;
1580c8de5b0SBaptiste Daroussin } YYSTYPE;
1590c8de5b0SBaptiste Daroussin #endif /* !YYSTYPE_IS_DECLARED */
1600c8de5b0SBaptiste Daroussin #line 161 "calc1.tab.c"
1610c8de5b0SBaptiste Daroussin
1620c8de5b0SBaptiste Daroussin /* compatibility with bison */
1630c8de5b0SBaptiste Daroussin #ifdef YYPARSE_PARAM
1640c8de5b0SBaptiste Daroussin /* compatibility with FreeBSD */
1650c8de5b0SBaptiste Daroussin # ifdef YYPARSE_PARAM_TYPE
1660c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
1670c8de5b0SBaptiste Daroussin # else
1680c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
1690c8de5b0SBaptiste Daroussin # endif
1700c8de5b0SBaptiste Daroussin #else
1710c8de5b0SBaptiste Daroussin # define YYPARSE_DECL() yyparse(void)
1720c8de5b0SBaptiste Daroussin #endif
1730c8de5b0SBaptiste Daroussin
1740c8de5b0SBaptiste Daroussin /* Parameters sent to lex. */
1750c8de5b0SBaptiste Daroussin #ifdef YYLEX_PARAM
1760c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void *YYLEX_PARAM)
1770c8de5b0SBaptiste Daroussin # define YYLEX yylex(YYLEX_PARAM)
1780c8de5b0SBaptiste Daroussin #else
1790c8de5b0SBaptiste Daroussin # define YYLEX_DECL() yylex(void)
1800c8de5b0SBaptiste Daroussin # define YYLEX yylex()
1810c8de5b0SBaptiste Daroussin #endif
1820c8de5b0SBaptiste Daroussin
1830c8de5b0SBaptiste Daroussin /* Parameters sent to yyerror. */
1840c8de5b0SBaptiste Daroussin #ifndef YYERROR_DECL
1850c8de5b0SBaptiste Daroussin #define YYERROR_DECL() yyerror(const char *s)
1860c8de5b0SBaptiste Daroussin #endif
1870c8de5b0SBaptiste Daroussin #ifndef YYERROR_CALL
1880c8de5b0SBaptiste Daroussin #define YYERROR_CALL(msg) yyerror(msg)
1890c8de5b0SBaptiste Daroussin #endif
1900c8de5b0SBaptiste Daroussin
1910c8de5b0SBaptiste Daroussin extern int YYPARSE_DECL();
1920c8de5b0SBaptiste Daroussin
1930c8de5b0SBaptiste Daroussin #define DREG 257
1940c8de5b0SBaptiste Daroussin #define VREG 258
1950c8de5b0SBaptiste Daroussin #define CONST 259
1960c8de5b0SBaptiste Daroussin #define UMINUS 260
1970c8de5b0SBaptiste Daroussin #define YYERRCODE 256
198b53bb29fSJung-uk Kim typedef int YYINT;
1990c8de5b0SBaptiste Daroussin static const YYINT calc1_lhs[] = { -1,
2000c8de5b0SBaptiste Daroussin 3, 3, 0, 0, 0, 0, 0, 1, 1, 1,
2010c8de5b0SBaptiste Daroussin 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
2020c8de5b0SBaptiste Daroussin 2, 2, 2, 2, 2, 2, 2, 2,
2030c8de5b0SBaptiste Daroussin };
2040c8de5b0SBaptiste Daroussin static const YYINT calc1_len[] = { 2,
2050c8de5b0SBaptiste Daroussin 0, 2, 2, 2, 4, 4, 2, 1, 1, 3,
2060c8de5b0SBaptiste Daroussin 3, 3, 3, 2, 3, 1, 5, 1, 3, 3,
2070c8de5b0SBaptiste Daroussin 3, 3, 3, 3, 3, 3, 2, 3,
2080c8de5b0SBaptiste Daroussin };
2090c8de5b0SBaptiste Daroussin static const YYINT calc1_defred[] = { 0,
2100c8de5b0SBaptiste Daroussin 0, 0, 0, 8, 0, 0, 0, 0, 0, 7,
2110c8de5b0SBaptiste Daroussin 0, 0, 9, 18, 14, 27, 0, 0, 0, 0,
2120c8de5b0SBaptiste Daroussin 0, 0, 3, 0, 0, 0, 0, 4, 0, 0,
2130c8de5b0SBaptiste Daroussin 0, 0, 0, 15, 0, 28, 0, 0, 0, 0,
2140c8de5b0SBaptiste Daroussin 12, 24, 13, 26, 0, 0, 23, 25, 14, 0,
2150c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 5, 6, 0, 0, 0, 12,
2160c8de5b0SBaptiste Daroussin 13, 17,
2170c8de5b0SBaptiste Daroussin };
2182aca18c7SJung-uk Kim #if defined(YYDESTRUCT_CALL) || defined(YYSTYPE_TOSTRING)
2190c8de5b0SBaptiste Daroussin static const YYINT calc1_stos[] = { 0,
2200c8de5b0SBaptiste Daroussin 256, 257, 258, 259, 45, 40, 262, 263, 264, 10,
2210c8de5b0SBaptiste Daroussin 61, 61, 257, 258, 263, 264, 263, 264, 43, 45,
2220c8de5b0SBaptiste Daroussin 42, 47, 10, 43, 45, 42, 47, 10, 45, 40,
2230c8de5b0SBaptiste Daroussin 263, 263, 264, 41, 44, 41, 263, 264, 263, 264,
2240c8de5b0SBaptiste Daroussin 263, 264, 263, 264, 264, 264, 264, 264, 263, 263,
2250c8de5b0SBaptiste Daroussin 43, 45, 42, 47, 10, 10, 263, 263, 263, 263,
2260c8de5b0SBaptiste Daroussin 263, 41,
2270c8de5b0SBaptiste Daroussin };
2282aca18c7SJung-uk Kim #endif /* YYDESTRUCT_CALL || YYSTYPE_TOSTRING */
2290c8de5b0SBaptiste Daroussin static const YYINT calc1_dgoto[] = { 7,
2300c8de5b0SBaptiste Daroussin 32, 9, 0,
2310c8de5b0SBaptiste Daroussin };
2320c8de5b0SBaptiste Daroussin static const YYINT calc1_sindex[] = { -40,
2330c8de5b0SBaptiste Daroussin -8, -48, -47, 0, -37, -37, 0, 2, 17, 0,
2340c8de5b0SBaptiste Daroussin -34, -37, 0, 0, 0, 0, -25, 90, -37, -37,
2350c8de5b0SBaptiste Daroussin -37, -37, 0, -37, -37, -37, -37, 0, -34, -34,
2360c8de5b0SBaptiste Daroussin 25, 125, 31, 0, -34, 0, -11, 37, -11, 37,
2370c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 37, 37, 0, 0, 0, 111,
2380c8de5b0SBaptiste Daroussin -34, -34, -34, -34, 0, 0, 118, 69, 69, 0,
2390c8de5b0SBaptiste Daroussin 0, 0,
2400c8de5b0SBaptiste Daroussin };
2410c8de5b0SBaptiste Daroussin static const YYINT calc1_rindex[] = { 0,
2420c8de5b0SBaptiste Daroussin 0, 38, 44, 0, 0, 0, 0, 0, 0, 0,
2430c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2440c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
2450c8de5b0SBaptiste Daroussin 0, -9, 0, 0, 0, 0, 51, -3, 56, 61,
2460c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 67, 72, 0, 0, 0, 0,
2470c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 78, 83, 0,
2480c8de5b0SBaptiste Daroussin 0, 0,
2490c8de5b0SBaptiste Daroussin };
2500c8de5b0SBaptiste Daroussin #if YYBTYACC
2510c8de5b0SBaptiste Daroussin static const YYINT calc1_cindex[] = { 0,
2520c8de5b0SBaptiste Daroussin 0, 0, 0, 0, 0, 0, 0, 0, 0, 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,
2590c8de5b0SBaptiste Daroussin };
2600c8de5b0SBaptiste Daroussin #endif
2610c8de5b0SBaptiste Daroussin static const YYINT calc1_gindex[] = { 0,
2620c8de5b0SBaptiste Daroussin 4, 124, 0,
2630c8de5b0SBaptiste Daroussin };
2640c8de5b0SBaptiste Daroussin #define YYTABLESIZE 225
2650c8de5b0SBaptiste Daroussin static const YYINT calc1_table[] = { 6,
2660c8de5b0SBaptiste Daroussin 16, 10, 6, 8, 5, 30, 20, 5, 15, 17,
2670c8de5b0SBaptiste Daroussin 29, 23, 11, 12, 31, 34, 21, 19, 35, 20,
2680c8de5b0SBaptiste Daroussin 0, 22, 37, 39, 41, 43, 28, 0, 0, 0,
2690c8de5b0SBaptiste Daroussin 21, 16, 49, 50, 55, 22, 0, 20, 57, 20,
2700c8de5b0SBaptiste Daroussin 56, 20, 0, 21, 19, 0, 20, 9, 22, 0,
2710c8de5b0SBaptiste Daroussin 0, 0, 0, 18, 58, 59, 60, 61, 26, 24,
2720c8de5b0SBaptiste Daroussin 10, 25, 0, 27, 0, 11, 53, 51, 0, 52,
2730c8de5b0SBaptiste Daroussin 22, 54, 26, 24, 0, 25, 19, 27, 26, 9,
2740c8de5b0SBaptiste Daroussin 9, 21, 9, 27, 9, 18, 18, 10, 18, 0,
2750c8de5b0SBaptiste Daroussin 18, 10, 11, 10, 10, 10, 11, 0, 11, 11,
2760c8de5b0SBaptiste Daroussin 11, 22, 0, 22, 0, 22, 0, 19, 0, 19,
2770c8de5b0SBaptiste Daroussin 53, 19, 21, 0, 21, 54, 21, 0, 10, 0,
2780c8de5b0SBaptiste Daroussin 10, 0, 10, 11, 0, 11, 0, 11, 16, 18,
2790c8de5b0SBaptiste Daroussin 36, 26, 24, 0, 25, 33, 27, 0, 0, 0,
2800c8de5b0SBaptiste Daroussin 0, 0, 38, 40, 42, 44, 0, 45, 46, 47,
2810c8de5b0SBaptiste Daroussin 48, 34, 53, 51, 0, 52, 0, 54, 62, 53,
2820c8de5b0SBaptiste Daroussin 51, 0, 52, 0, 54, 0, 21, 19, 0, 20,
2830c8de5b0SBaptiste Daroussin 0, 22, 0, 0, 0, 0, 0, 0, 0, 0,
2840c8de5b0SBaptiste Daroussin 0, 0, 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, 1, 2, 3, 4, 13,
2880c8de5b0SBaptiste Daroussin 14, 4, 13, 0, 4,
2890c8de5b0SBaptiste Daroussin };
2900c8de5b0SBaptiste Daroussin static const YYINT calc1_check[] = { 40,
2910c8de5b0SBaptiste Daroussin 10, 10, 40, 0, 45, 40, 10, 45, 5, 6,
2920c8de5b0SBaptiste Daroussin 45, 10, 61, 61, 11, 41, 42, 43, 44, 45,
2930c8de5b0SBaptiste Daroussin -1, 47, 19, 20, 21, 22, 10, -1, -1, -1,
2940c8de5b0SBaptiste Daroussin 42, 41, 29, 30, 10, 47, -1, 41, 35, 43,
2950c8de5b0SBaptiste Daroussin 10, 45, -1, 42, 43, -1, 45, 10, 47, -1,
2960c8de5b0SBaptiste Daroussin -1, -1, -1, 10, 51, 52, 53, 54, 42, 43,
2970c8de5b0SBaptiste Daroussin 10, 45, -1, 47, -1, 10, 42, 43, -1, 45,
2980c8de5b0SBaptiste Daroussin 10, 47, 42, 43, -1, 45, 10, 47, 42, 42,
2990c8de5b0SBaptiste Daroussin 43, 10, 45, 47, 47, 42, 43, 10, 45, -1,
3000c8de5b0SBaptiste Daroussin 47, 41, 10, 43, 44, 45, 41, -1, 43, 44,
3010c8de5b0SBaptiste Daroussin 45, 41, -1, 43, -1, 45, -1, 41, -1, 43,
3020c8de5b0SBaptiste Daroussin 42, 45, 41, -1, 43, 47, 45, -1, 41, -1,
3030c8de5b0SBaptiste Daroussin 43, -1, 45, 41, -1, 43, -1, 45, 5, 6,
3040c8de5b0SBaptiste Daroussin 41, 42, 43, -1, 45, 12, 47, -1, -1, -1,
3050c8de5b0SBaptiste Daroussin -1, -1, 19, 20, 21, 22, -1, 24, 25, 26,
3060c8de5b0SBaptiste Daroussin 27, 41, 42, 43, -1, 45, -1, 47, 41, 42,
3070c8de5b0SBaptiste Daroussin 43, -1, 45, -1, 47, -1, 42, 43, -1, 45,
3080c8de5b0SBaptiste Daroussin -1, 47, -1, -1, -1, -1, -1, -1, -1, -1,
3090c8de5b0SBaptiste Daroussin -1, -1, -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, 256, 257, 258, 259, 257,
3130c8de5b0SBaptiste Daroussin 258, 259, 257, -1, 259,
3140c8de5b0SBaptiste Daroussin };
31511fce282SBaptiste Daroussin #if YYBTYACC
31611fce282SBaptiste Daroussin static const YYINT calc1_ctable[] = { -1,
31711fce282SBaptiste Daroussin -1, -1, -1, -1, -1, -1, -1, -1, -1, -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,
34011fce282SBaptiste Daroussin };
34111fce282SBaptiste Daroussin #endif
3420c8de5b0SBaptiste Daroussin #define YYFINAL 7
3430c8de5b0SBaptiste Daroussin #ifndef YYDEBUG
3440c8de5b0SBaptiste Daroussin #define YYDEBUG 0
3450c8de5b0SBaptiste Daroussin #endif
3460c8de5b0SBaptiste Daroussin #define YYMAXTOKEN 260
3470c8de5b0SBaptiste Daroussin #define YYUNDFTOKEN 266
3480c8de5b0SBaptiste Daroussin #define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? YYUNDFTOKEN : (a))
3490c8de5b0SBaptiste Daroussin #if YYDEBUG
3500c8de5b0SBaptiste Daroussin static const char *const calc1_name[] = {
3510c8de5b0SBaptiste Daroussin
3520c8de5b0SBaptiste 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,
3530c8de5b0SBaptiste Daroussin 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,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,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,
3590c8de5b0SBaptiste Daroussin "error","DREG","VREG","CONST","UMINUS","$accept","line","dexp","vexp","lines",
3600c8de5b0SBaptiste Daroussin "illegal-symbol",
3610c8de5b0SBaptiste Daroussin };
3620c8de5b0SBaptiste Daroussin static const char *const calc1_rule[] = {
3630c8de5b0SBaptiste Daroussin "$accept : line",
3640c8de5b0SBaptiste Daroussin "lines :",
3650c8de5b0SBaptiste Daroussin "lines : lines line",
3660c8de5b0SBaptiste Daroussin "line : dexp '\\n'",
3670c8de5b0SBaptiste Daroussin "line : vexp '\\n'",
3680c8de5b0SBaptiste Daroussin "line : DREG '=' dexp '\\n'",
3690c8de5b0SBaptiste Daroussin "line : VREG '=' vexp '\\n'",
3700c8de5b0SBaptiste Daroussin "line : error '\\n'",
3710c8de5b0SBaptiste Daroussin "dexp : CONST",
3720c8de5b0SBaptiste Daroussin "dexp : DREG",
3730c8de5b0SBaptiste Daroussin "dexp : dexp '+' dexp",
3740c8de5b0SBaptiste Daroussin "dexp : dexp '-' dexp",
3750c8de5b0SBaptiste Daroussin "dexp : dexp '*' dexp",
3760c8de5b0SBaptiste Daroussin "dexp : dexp '/' dexp",
3770c8de5b0SBaptiste Daroussin "dexp : '-' dexp",
3780c8de5b0SBaptiste Daroussin "dexp : '(' dexp ')'",
3790c8de5b0SBaptiste Daroussin "vexp : dexp",
3800c8de5b0SBaptiste Daroussin "vexp : '(' dexp ',' dexp ')'",
3810c8de5b0SBaptiste Daroussin "vexp : VREG",
3820c8de5b0SBaptiste Daroussin "vexp : vexp '+' vexp",
3830c8de5b0SBaptiste Daroussin "vexp : dexp '+' vexp",
3840c8de5b0SBaptiste Daroussin "vexp : vexp '-' vexp",
3850c8de5b0SBaptiste Daroussin "vexp : dexp '-' vexp",
3860c8de5b0SBaptiste Daroussin "vexp : vexp '*' vexp",
3870c8de5b0SBaptiste Daroussin "vexp : dexp '*' vexp",
3880c8de5b0SBaptiste Daroussin "vexp : vexp '/' vexp",
3890c8de5b0SBaptiste Daroussin "vexp : dexp '/' vexp",
3900c8de5b0SBaptiste Daroussin "vexp : '-' vexp",
3910c8de5b0SBaptiste Daroussin "vexp : '(' vexp ')'",
3920c8de5b0SBaptiste Daroussin
3930c8de5b0SBaptiste Daroussin };
3940c8de5b0SBaptiste Daroussin #endif
3950c8de5b0SBaptiste Daroussin
396b53bb29fSJung-uk Kim #if YYDEBUG
3970c8de5b0SBaptiste Daroussin int yydebug;
398b53bb29fSJung-uk Kim #endif
3990c8de5b0SBaptiste Daroussin
4000c8de5b0SBaptiste Daroussin int yyerrflag;
4010c8de5b0SBaptiste Daroussin int yychar;
4020c8de5b0SBaptiste Daroussin YYSTYPE yyval;
4030c8de5b0SBaptiste Daroussin YYSTYPE yylval;
404b53bb29fSJung-uk Kim int yynerrs;
405b53bb29fSJung-uk Kim
4060c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4070c8de5b0SBaptiste Daroussin YYLTYPE yyloc; /* position returned by actions */
4080c8de5b0SBaptiste Daroussin YYLTYPE yylloc; /* position from the lexer */
4090c8de5b0SBaptiste Daroussin #endif
4100c8de5b0SBaptiste Daroussin
4110c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4120c8de5b0SBaptiste Daroussin #ifndef YYLLOC_DEFAULT
4130c8de5b0SBaptiste Daroussin #define YYLLOC_DEFAULT(loc, rhs, n) \
4140c8de5b0SBaptiste Daroussin do \
4150c8de5b0SBaptiste Daroussin { \
4160c8de5b0SBaptiste Daroussin if (n == 0) \
4170c8de5b0SBaptiste Daroussin { \
418b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 0).last_line; \
419b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 0).last_column; \
420b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, 0).last_line; \
421b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, 0).last_column; \
4220c8de5b0SBaptiste Daroussin } \
4230c8de5b0SBaptiste Daroussin else \
4240c8de5b0SBaptiste Daroussin { \
425b53bb29fSJung-uk Kim (loc).first_line = YYRHSLOC(rhs, 1).first_line; \
426b53bb29fSJung-uk Kim (loc).first_column = YYRHSLOC(rhs, 1).first_column; \
427b53bb29fSJung-uk Kim (loc).last_line = YYRHSLOC(rhs, n).last_line; \
428b53bb29fSJung-uk Kim (loc).last_column = YYRHSLOC(rhs, n).last_column; \
4290c8de5b0SBaptiste Daroussin } \
4300c8de5b0SBaptiste Daroussin } while (0)
4310c8de5b0SBaptiste Daroussin #endif /* YYLLOC_DEFAULT */
4320c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
4330c8de5b0SBaptiste Daroussin #if YYBTYACC
4340c8de5b0SBaptiste Daroussin
4350c8de5b0SBaptiste Daroussin #ifndef YYLVQUEUEGROWTH
4360c8de5b0SBaptiste Daroussin #define YYLVQUEUEGROWTH 32
4370c8de5b0SBaptiste Daroussin #endif
4380c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
4390c8de5b0SBaptiste Daroussin
4400c8de5b0SBaptiste Daroussin /* define the initial stack-sizes */
4410c8de5b0SBaptiste Daroussin #ifdef YYSTACKSIZE
4420c8de5b0SBaptiste Daroussin #undef YYMAXDEPTH
4430c8de5b0SBaptiste Daroussin #define YYMAXDEPTH YYSTACKSIZE
4440c8de5b0SBaptiste Daroussin #else
4450c8de5b0SBaptiste Daroussin #ifdef YYMAXDEPTH
4460c8de5b0SBaptiste Daroussin #define YYSTACKSIZE YYMAXDEPTH
4470c8de5b0SBaptiste Daroussin #else
4480c8de5b0SBaptiste Daroussin #define YYSTACKSIZE 10000
4490c8de5b0SBaptiste Daroussin #define YYMAXDEPTH 10000
4500c8de5b0SBaptiste Daroussin #endif
4510c8de5b0SBaptiste Daroussin #endif
4520c8de5b0SBaptiste Daroussin
4530c8de5b0SBaptiste Daroussin #ifndef YYINITSTACKSIZE
4540c8de5b0SBaptiste Daroussin #define YYINITSTACKSIZE 200
4550c8de5b0SBaptiste Daroussin #endif
4560c8de5b0SBaptiste Daroussin
4570c8de5b0SBaptiste Daroussin typedef struct {
4580c8de5b0SBaptiste Daroussin unsigned stacksize;
459c5b5d71aSJung-uk Kim YYINT *s_base;
460c5b5d71aSJung-uk Kim YYINT *s_mark;
461c5b5d71aSJung-uk Kim YYINT *s_last;
4620c8de5b0SBaptiste Daroussin YYSTYPE *l_base;
4630c8de5b0SBaptiste Daroussin YYSTYPE *l_mark;
4640c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
4650c8de5b0SBaptiste Daroussin YYLTYPE *p_base;
4660c8de5b0SBaptiste Daroussin YYLTYPE *p_mark;
4670c8de5b0SBaptiste Daroussin #endif
4680c8de5b0SBaptiste Daroussin } YYSTACKDATA;
4690c8de5b0SBaptiste Daroussin #if YYBTYACC
4700c8de5b0SBaptiste Daroussin
4710c8de5b0SBaptiste Daroussin struct YYParseState_s
4720c8de5b0SBaptiste Daroussin {
4730c8de5b0SBaptiste Daroussin struct YYParseState_s *save; /* Previously saved parser state */
4740c8de5b0SBaptiste Daroussin YYSTACKDATA yystack; /* saved parser stack */
4750c8de5b0SBaptiste Daroussin int state; /* saved parser state */
4760c8de5b0SBaptiste Daroussin int errflag; /* saved error recovery status */
4770c8de5b0SBaptiste Daroussin int lexeme; /* saved index of the conflict lexeme in the lexical queue */
4780c8de5b0SBaptiste Daroussin YYINT ctry; /* saved index in yyctable[] for this conflict */
4790c8de5b0SBaptiste Daroussin };
4800c8de5b0SBaptiste Daroussin typedef struct YYParseState_s YYParseState;
4810c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
4820c8de5b0SBaptiste Daroussin /* variables for the parser stack */
4830c8de5b0SBaptiste Daroussin static YYSTACKDATA yystack;
4840c8de5b0SBaptiste Daroussin #if YYBTYACC
4850c8de5b0SBaptiste Daroussin
4860c8de5b0SBaptiste Daroussin /* Current parser state */
4870c8de5b0SBaptiste Daroussin static YYParseState *yyps = 0;
4880c8de5b0SBaptiste Daroussin
4890c8de5b0SBaptiste Daroussin /* yypath != NULL: do the full parse, starting at *yypath parser state. */
4900c8de5b0SBaptiste Daroussin static YYParseState *yypath = 0;
4910c8de5b0SBaptiste Daroussin
4920c8de5b0SBaptiste Daroussin /* Base of the lexical value queue */
4930c8de5b0SBaptiste Daroussin static YYSTYPE *yylvals = 0;
4940c8de5b0SBaptiste Daroussin
4950c8de5b0SBaptiste Daroussin /* Current position at lexical value queue */
4960c8de5b0SBaptiste Daroussin static YYSTYPE *yylvp = 0;
4970c8de5b0SBaptiste Daroussin
4980c8de5b0SBaptiste Daroussin /* End position of lexical value queue */
4990c8de5b0SBaptiste Daroussin static YYSTYPE *yylve = 0;
5000c8de5b0SBaptiste Daroussin
5010c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical value queue */
5020c8de5b0SBaptiste Daroussin static YYSTYPE *yylvlim = 0;
5030c8de5b0SBaptiste Daroussin
5040c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
5050c8de5b0SBaptiste Daroussin /* Base of the lexical position queue */
5060c8de5b0SBaptiste Daroussin static YYLTYPE *yylpsns = 0;
5070c8de5b0SBaptiste Daroussin
5080c8de5b0SBaptiste Daroussin /* Current position at lexical position queue */
5090c8de5b0SBaptiste Daroussin static YYLTYPE *yylpp = 0;
5100c8de5b0SBaptiste Daroussin
5110c8de5b0SBaptiste Daroussin /* End position of lexical position queue */
5120c8de5b0SBaptiste Daroussin static YYLTYPE *yylpe = 0;
5130c8de5b0SBaptiste Daroussin
5140c8de5b0SBaptiste Daroussin /* The last allocated position at the lexical position queue */
5150c8de5b0SBaptiste Daroussin static YYLTYPE *yylplim = 0;
5160c8de5b0SBaptiste Daroussin #endif
5170c8de5b0SBaptiste Daroussin
5180c8de5b0SBaptiste Daroussin /* Current position at lexical token queue */
5192aca18c7SJung-uk Kim static YYINT *yylexp = 0;
5200c8de5b0SBaptiste Daroussin
5212aca18c7SJung-uk Kim static YYINT *yylexemes = 0;
5220c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
5230c8de5b0SBaptiste Daroussin #line 176 "calc1.y"
5240c8de5b0SBaptiste Daroussin /* beginning of subroutines section */
5250c8de5b0SBaptiste Daroussin
5260c8de5b0SBaptiste Daroussin #define BSZ 50 /* buffer size for floating point numbers */
5270c8de5b0SBaptiste Daroussin
5280c8de5b0SBaptiste Daroussin /* lexical analysis */
5290c8de5b0SBaptiste Daroussin
5300c8de5b0SBaptiste Daroussin static void
yyerror(const char * s)5310c8de5b0SBaptiste Daroussin yyerror(const char *s)
5320c8de5b0SBaptiste Daroussin {
5330c8de5b0SBaptiste Daroussin fprintf(stderr, "%s\n", s);
5340c8de5b0SBaptiste Daroussin }
5350c8de5b0SBaptiste Daroussin
5360c8de5b0SBaptiste Daroussin int
yylex(void)5370c8de5b0SBaptiste Daroussin yylex(void)
5380c8de5b0SBaptiste Daroussin {
5390c8de5b0SBaptiste Daroussin int c;
5400c8de5b0SBaptiste Daroussin
5410c8de5b0SBaptiste Daroussin while ((c = getchar()) == ' ')
5420c8de5b0SBaptiste Daroussin { /* skip over blanks */
5430c8de5b0SBaptiste Daroussin }
5440c8de5b0SBaptiste Daroussin
5450c8de5b0SBaptiste Daroussin if (isupper(c))
5460c8de5b0SBaptiste Daroussin {
5470c8de5b0SBaptiste Daroussin yylval.ival = c - 'A';
5480c8de5b0SBaptiste Daroussin return (VREG);
5490c8de5b0SBaptiste Daroussin }
5500c8de5b0SBaptiste Daroussin if (islower(c))
5510c8de5b0SBaptiste Daroussin {
5520c8de5b0SBaptiste Daroussin yylval.ival = c - 'a';
5530c8de5b0SBaptiste Daroussin return (DREG);
5540c8de5b0SBaptiste Daroussin }
5550c8de5b0SBaptiste Daroussin
5560c8de5b0SBaptiste Daroussin if (isdigit(c) || c == '.')
5570c8de5b0SBaptiste Daroussin {
5580c8de5b0SBaptiste Daroussin /* gobble up digits, points, exponents */
5590c8de5b0SBaptiste Daroussin char buf[BSZ + 1], *cp = buf;
5600c8de5b0SBaptiste Daroussin int dot = 0, expr = 0;
5610c8de5b0SBaptiste Daroussin
5620c8de5b0SBaptiste Daroussin for (; (cp - buf) < BSZ; ++cp, c = getchar())
5630c8de5b0SBaptiste Daroussin {
5640c8de5b0SBaptiste Daroussin
5650c8de5b0SBaptiste Daroussin *cp = (char) c;
5660c8de5b0SBaptiste Daroussin if (isdigit(c))
5670c8de5b0SBaptiste Daroussin continue;
5680c8de5b0SBaptiste Daroussin if (c == '.')
5690c8de5b0SBaptiste Daroussin {
5700c8de5b0SBaptiste Daroussin if (dot++ || expr)
5710c8de5b0SBaptiste Daroussin return ('.'); /* will cause syntax error */
5720c8de5b0SBaptiste Daroussin continue;
5730c8de5b0SBaptiste Daroussin }
5740c8de5b0SBaptiste Daroussin
5750c8de5b0SBaptiste Daroussin if (c == 'e')
5760c8de5b0SBaptiste Daroussin {
5770c8de5b0SBaptiste Daroussin if (expr++)
5780c8de5b0SBaptiste Daroussin return ('e'); /* will cause syntax error */
5790c8de5b0SBaptiste Daroussin continue;
5800c8de5b0SBaptiste Daroussin }
5810c8de5b0SBaptiste Daroussin
5820c8de5b0SBaptiste Daroussin /* end of number */
5830c8de5b0SBaptiste Daroussin break;
5840c8de5b0SBaptiste Daroussin }
5850c8de5b0SBaptiste Daroussin *cp = '\0';
5860c8de5b0SBaptiste Daroussin
5870c8de5b0SBaptiste Daroussin if ((cp - buf) >= BSZ)
5880c8de5b0SBaptiste Daroussin printf("constant too long: truncated\n");
5890c8de5b0SBaptiste Daroussin else
5900c8de5b0SBaptiste Daroussin ungetc(c, stdin); /* push back last char read */
5910c8de5b0SBaptiste Daroussin yylval.dval = atof(buf);
5920c8de5b0SBaptiste Daroussin return (CONST);
5930c8de5b0SBaptiste Daroussin }
5940c8de5b0SBaptiste Daroussin return (c);
5950c8de5b0SBaptiste Daroussin }
5960c8de5b0SBaptiste Daroussin
5970c8de5b0SBaptiste Daroussin static INTERVAL
hilo(double a,double b,double c,double d)5980c8de5b0SBaptiste Daroussin hilo(double a, double b, double c, double d)
5990c8de5b0SBaptiste Daroussin {
6000c8de5b0SBaptiste Daroussin /* returns the smallest interval containing a, b, c, and d */
6010c8de5b0SBaptiste Daroussin /* used by *, / routines */
6020c8de5b0SBaptiste Daroussin INTERVAL v;
6030c8de5b0SBaptiste Daroussin
6040c8de5b0SBaptiste Daroussin if (a > b)
6050c8de5b0SBaptiste Daroussin {
6060c8de5b0SBaptiste Daroussin v.hi = a;
6070c8de5b0SBaptiste Daroussin v.lo = b;
6080c8de5b0SBaptiste Daroussin }
6090c8de5b0SBaptiste Daroussin else
6100c8de5b0SBaptiste Daroussin {
6110c8de5b0SBaptiste Daroussin v.hi = b;
6120c8de5b0SBaptiste Daroussin v.lo = a;
6130c8de5b0SBaptiste Daroussin }
6140c8de5b0SBaptiste Daroussin
6150c8de5b0SBaptiste Daroussin if (c > d)
6160c8de5b0SBaptiste Daroussin {
6170c8de5b0SBaptiste Daroussin if (c > v.hi)
6180c8de5b0SBaptiste Daroussin v.hi = c;
6190c8de5b0SBaptiste Daroussin if (d < v.lo)
6200c8de5b0SBaptiste Daroussin v.lo = d;
6210c8de5b0SBaptiste Daroussin }
6220c8de5b0SBaptiste Daroussin else
6230c8de5b0SBaptiste Daroussin {
6240c8de5b0SBaptiste Daroussin if (d > v.hi)
6250c8de5b0SBaptiste Daroussin v.hi = d;
6260c8de5b0SBaptiste Daroussin if (c < v.lo)
6270c8de5b0SBaptiste Daroussin v.lo = c;
6280c8de5b0SBaptiste Daroussin }
6290c8de5b0SBaptiste Daroussin return (v);
6300c8de5b0SBaptiste Daroussin }
6310c8de5b0SBaptiste Daroussin
6320c8de5b0SBaptiste Daroussin INTERVAL
vmul(double a,double b,INTERVAL v)6330c8de5b0SBaptiste Daroussin vmul(double a, double b, INTERVAL v)
6340c8de5b0SBaptiste Daroussin {
6350c8de5b0SBaptiste Daroussin return (hilo(a * v.hi, a * v.lo, b * v.hi, b * v.lo));
6360c8de5b0SBaptiste Daroussin }
6370c8de5b0SBaptiste Daroussin
6380c8de5b0SBaptiste Daroussin int
dcheck(INTERVAL v)6390c8de5b0SBaptiste Daroussin dcheck(INTERVAL v)
6400c8de5b0SBaptiste Daroussin {
6410c8de5b0SBaptiste Daroussin if (v.hi >= 0. && v.lo <= 0.)
6420c8de5b0SBaptiste Daroussin {
6430c8de5b0SBaptiste Daroussin printf("divisor interval contains 0.\n");
6440c8de5b0SBaptiste Daroussin return (1);
6450c8de5b0SBaptiste Daroussin }
6460c8de5b0SBaptiste Daroussin return (0);
6470c8de5b0SBaptiste Daroussin }
6480c8de5b0SBaptiste Daroussin
6490c8de5b0SBaptiste Daroussin INTERVAL
vdiv(double a,double b,INTERVAL v)6500c8de5b0SBaptiste Daroussin vdiv(double a, double b, INTERVAL v)
6510c8de5b0SBaptiste Daroussin {
6520c8de5b0SBaptiste Daroussin return (hilo(a / v.hi, a / v.lo, b / v.hi, b / v.lo));
6530c8de5b0SBaptiste Daroussin }
654b53bb29fSJung-uk Kim #line 655 "calc1.tab.c"
6550c8de5b0SBaptiste Daroussin
6560c8de5b0SBaptiste Daroussin /* For use in generated program */
6570c8de5b0SBaptiste Daroussin #define yydepth (int)(yystack.s_mark - yystack.s_base)
6580c8de5b0SBaptiste Daroussin #if YYBTYACC
6590c8de5b0SBaptiste Daroussin #define yytrial (yyps->save)
6600c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
6610c8de5b0SBaptiste Daroussin
6620c8de5b0SBaptiste Daroussin #if YYDEBUG
6630c8de5b0SBaptiste Daroussin #include <stdio.h> /* needed for printf */
6640c8de5b0SBaptiste Daroussin #endif
6650c8de5b0SBaptiste Daroussin
6660c8de5b0SBaptiste Daroussin #include <stdlib.h> /* needed for malloc, etc */
6670c8de5b0SBaptiste Daroussin #include <string.h> /* needed for memset */
6680c8de5b0SBaptiste Daroussin
6690c8de5b0SBaptiste Daroussin /* allocate initial stack or double stack size, up to YYMAXDEPTH */
yygrowstack(YYSTACKDATA * data)6700c8de5b0SBaptiste Daroussin static int yygrowstack(YYSTACKDATA *data)
6710c8de5b0SBaptiste Daroussin {
6720c8de5b0SBaptiste Daroussin int i;
6730c8de5b0SBaptiste Daroussin unsigned newsize;
674c5b5d71aSJung-uk Kim YYINT *newss;
6750c8de5b0SBaptiste Daroussin YYSTYPE *newvs;
6760c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
6770c8de5b0SBaptiste Daroussin YYLTYPE *newps;
6780c8de5b0SBaptiste Daroussin #endif
6790c8de5b0SBaptiste Daroussin
6800c8de5b0SBaptiste Daroussin if ((newsize = data->stacksize) == 0)
6810c8de5b0SBaptiste Daroussin newsize = YYINITSTACKSIZE;
6820c8de5b0SBaptiste Daroussin else if (newsize >= YYMAXDEPTH)
6830c8de5b0SBaptiste Daroussin return YYENOMEM;
6840c8de5b0SBaptiste Daroussin else if ((newsize *= 2) > YYMAXDEPTH)
6850c8de5b0SBaptiste Daroussin newsize = YYMAXDEPTH;
6860c8de5b0SBaptiste Daroussin
6870c8de5b0SBaptiste Daroussin i = (int) (data->s_mark - data->s_base);
688c5b5d71aSJung-uk Kim newss = (YYINT *)realloc(data->s_base, newsize * sizeof(*newss));
689bf80e08eSJung-uk Kim if (newss == NULL)
6900c8de5b0SBaptiste Daroussin return YYENOMEM;
6910c8de5b0SBaptiste Daroussin
6920c8de5b0SBaptiste Daroussin data->s_base = newss;
6930c8de5b0SBaptiste Daroussin data->s_mark = newss + i;
6940c8de5b0SBaptiste Daroussin
6950c8de5b0SBaptiste Daroussin newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
696bf80e08eSJung-uk Kim if (newvs == NULL)
6970c8de5b0SBaptiste Daroussin return YYENOMEM;
6980c8de5b0SBaptiste Daroussin
6990c8de5b0SBaptiste Daroussin data->l_base = newvs;
7000c8de5b0SBaptiste Daroussin data->l_mark = newvs + i;
7010c8de5b0SBaptiste Daroussin
7020c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7030c8de5b0SBaptiste Daroussin newps = (YYLTYPE *)realloc(data->p_base, newsize * sizeof(*newps));
704bf80e08eSJung-uk Kim if (newps == NULL)
7050c8de5b0SBaptiste Daroussin return YYENOMEM;
7060c8de5b0SBaptiste Daroussin
7070c8de5b0SBaptiste Daroussin data->p_base = newps;
7080c8de5b0SBaptiste Daroussin data->p_mark = newps + i;
7090c8de5b0SBaptiste Daroussin #endif
7100c8de5b0SBaptiste Daroussin
7110c8de5b0SBaptiste Daroussin data->stacksize = newsize;
7120c8de5b0SBaptiste Daroussin data->s_last = data->s_base + newsize - 1;
7130c8de5b0SBaptiste Daroussin
7140c8de5b0SBaptiste Daroussin #if YYDEBUG
7150c8de5b0SBaptiste Daroussin if (yydebug)
7160c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug: stack size increased to %d\n", YYPREFIX, newsize);
7170c8de5b0SBaptiste Daroussin #endif
7180c8de5b0SBaptiste Daroussin return 0;
7190c8de5b0SBaptiste Daroussin }
7200c8de5b0SBaptiste Daroussin
7210c8de5b0SBaptiste Daroussin #if YYPURE || defined(YY_NO_LEAKS)
yyfreestack(YYSTACKDATA * data)7220c8de5b0SBaptiste Daroussin static void yyfreestack(YYSTACKDATA *data)
7230c8de5b0SBaptiste Daroussin {
7240c8de5b0SBaptiste Daroussin free(data->s_base);
7250c8de5b0SBaptiste Daroussin free(data->l_base);
7260c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7270c8de5b0SBaptiste Daroussin free(data->p_base);
7280c8de5b0SBaptiste Daroussin #endif
7290c8de5b0SBaptiste Daroussin memset(data, 0, sizeof(*data));
7300c8de5b0SBaptiste Daroussin }
7310c8de5b0SBaptiste Daroussin #else
7320c8de5b0SBaptiste Daroussin #define yyfreestack(data) /* nothing */
7330c8de5b0SBaptiste Daroussin #endif /* YYPURE || defined(YY_NO_LEAKS) */
7340c8de5b0SBaptiste Daroussin #if YYBTYACC
7350c8de5b0SBaptiste Daroussin
7360c8de5b0SBaptiste Daroussin static YYParseState *
yyNewState(unsigned size)7370c8de5b0SBaptiste Daroussin yyNewState(unsigned size)
7380c8de5b0SBaptiste Daroussin {
7390c8de5b0SBaptiste Daroussin YYParseState *p = (YYParseState *) malloc(sizeof(YYParseState));
7400c8de5b0SBaptiste Daroussin if (p == NULL) return NULL;
7410c8de5b0SBaptiste Daroussin
7420c8de5b0SBaptiste Daroussin p->yystack.stacksize = size;
7430c8de5b0SBaptiste Daroussin if (size == 0)
7440c8de5b0SBaptiste Daroussin {
7450c8de5b0SBaptiste Daroussin p->yystack.s_base = NULL;
7460c8de5b0SBaptiste Daroussin p->yystack.l_base = NULL;
7470c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7480c8de5b0SBaptiste Daroussin p->yystack.p_base = NULL;
7490c8de5b0SBaptiste Daroussin #endif
7500c8de5b0SBaptiste Daroussin return p;
7510c8de5b0SBaptiste Daroussin }
752c5b5d71aSJung-uk Kim p->yystack.s_base = (YYINT *) malloc(size * sizeof(YYINT));
7530c8de5b0SBaptiste Daroussin if (p->yystack.s_base == NULL) return NULL;
7540c8de5b0SBaptiste Daroussin p->yystack.l_base = (YYSTYPE *) malloc(size * sizeof(YYSTYPE));
7550c8de5b0SBaptiste Daroussin if (p->yystack.l_base == NULL) return NULL;
7560c8de5b0SBaptiste Daroussin memset(p->yystack.l_base, 0, size * sizeof(YYSTYPE));
7570c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
7580c8de5b0SBaptiste Daroussin p->yystack.p_base = (YYLTYPE *) malloc(size * sizeof(YYLTYPE));
7590c8de5b0SBaptiste Daroussin if (p->yystack.p_base == NULL) return NULL;
7600c8de5b0SBaptiste Daroussin memset(p->yystack.p_base, 0, size * sizeof(YYLTYPE));
7610c8de5b0SBaptiste Daroussin #endif
7620c8de5b0SBaptiste Daroussin
7630c8de5b0SBaptiste Daroussin return p;
7640c8de5b0SBaptiste Daroussin }
7650c8de5b0SBaptiste Daroussin
7660c8de5b0SBaptiste Daroussin static void
yyFreeState(YYParseState * p)7670c8de5b0SBaptiste Daroussin yyFreeState(YYParseState *p)
7680c8de5b0SBaptiste Daroussin {
7690c8de5b0SBaptiste Daroussin yyfreestack(&p->yystack);
7700c8de5b0SBaptiste Daroussin free(p);
7710c8de5b0SBaptiste Daroussin }
7720c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7730c8de5b0SBaptiste Daroussin
7740c8de5b0SBaptiste Daroussin #define YYABORT goto yyabort
7750c8de5b0SBaptiste Daroussin #define YYREJECT goto yyabort
7760c8de5b0SBaptiste Daroussin #define YYACCEPT goto yyaccept
7770c8de5b0SBaptiste Daroussin #define YYERROR goto yyerrlab
7780c8de5b0SBaptiste Daroussin #if YYBTYACC
7790c8de5b0SBaptiste Daroussin #define YYVALID do { if (yyps->save) goto yyvalid; } while(0)
7800c8de5b0SBaptiste Daroussin #define YYVALID_NESTED do { if (yyps->save && \
7810c8de5b0SBaptiste Daroussin yyps->save->save == 0) goto yyvalid; } while(0)
7820c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7830c8de5b0SBaptiste Daroussin
7840c8de5b0SBaptiste Daroussin int
YYPARSE_DECL()7850c8de5b0SBaptiste Daroussin YYPARSE_DECL()
7860c8de5b0SBaptiste Daroussin {
7870c8de5b0SBaptiste Daroussin int yym, yyn, yystate, yyresult;
7880c8de5b0SBaptiste Daroussin #if YYBTYACC
7890c8de5b0SBaptiste Daroussin int yynewerrflag;
7900c8de5b0SBaptiste Daroussin YYParseState *yyerrctx = NULL;
7910c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
7920c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
793b53bb29fSJung-uk Kim YYLTYPE yyerror_loc_range[3]; /* position of error start/end (0 unused) */
7940c8de5b0SBaptiste Daroussin #endif
7950c8de5b0SBaptiste Daroussin #if YYDEBUG
7960c8de5b0SBaptiste Daroussin const char *yys;
7970c8de5b0SBaptiste Daroussin
798bf80e08eSJung-uk Kim if ((yys = getenv("YYDEBUG")) != NULL)
7990c8de5b0SBaptiste Daroussin {
8000c8de5b0SBaptiste Daroussin yyn = *yys;
8010c8de5b0SBaptiste Daroussin if (yyn >= '0' && yyn <= '9')
8020c8de5b0SBaptiste Daroussin yydebug = yyn - '0';
8030c8de5b0SBaptiste Daroussin }
8040c8de5b0SBaptiste Daroussin if (yydebug)
8050c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[<# of symbols on state stack>]\n", YYPREFIX);
8060c8de5b0SBaptiste Daroussin #endif
8076166fdceSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8086166fdceSJung-uk Kim memset(yyerror_loc_range, 0, sizeof(yyerror_loc_range));
8096166fdceSJung-uk Kim #endif
8100c8de5b0SBaptiste Daroussin
8110c8de5b0SBaptiste Daroussin #if YYBTYACC
8120c8de5b0SBaptiste Daroussin yyps = yyNewState(0); if (yyps == 0) goto yyenomem;
8130c8de5b0SBaptiste Daroussin yyps->save = 0;
8140c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
815c5b5d71aSJung-uk Kim yym = 0;
8168e022d3cSDag-Erling Smørgrav /* yyn is set below */
8170c8de5b0SBaptiste Daroussin yynerrs = 0;
8180c8de5b0SBaptiste Daroussin yyerrflag = 0;
8190c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
8200c8de5b0SBaptiste Daroussin yystate = 0;
8210c8de5b0SBaptiste Daroussin
8220c8de5b0SBaptiste Daroussin #if YYPURE
8230c8de5b0SBaptiste Daroussin memset(&yystack, 0, sizeof(yystack));
8240c8de5b0SBaptiste Daroussin #endif
8250c8de5b0SBaptiste Daroussin
8260c8de5b0SBaptiste Daroussin if (yystack.s_base == NULL && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
8270c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base;
8280c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base;
8290c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8300c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base;
8310c8de5b0SBaptiste Daroussin #endif
8320c8de5b0SBaptiste Daroussin yystate = 0;
8330c8de5b0SBaptiste Daroussin *yystack.s_mark = 0;
8340c8de5b0SBaptiste Daroussin
8350c8de5b0SBaptiste Daroussin yyloop:
8360c8de5b0SBaptiste Daroussin if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
8370c8de5b0SBaptiste Daroussin if (yychar < 0)
8380c8de5b0SBaptiste Daroussin {
8390c8de5b0SBaptiste Daroussin #if YYBTYACC
8400c8de5b0SBaptiste Daroussin do {
8410c8de5b0SBaptiste Daroussin if (yylvp < yylve)
8420c8de5b0SBaptiste Daroussin {
8430c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */
8440c8de5b0SBaptiste Daroussin yylval = *yylvp++;
8450c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8460c8de5b0SBaptiste Daroussin yylloc = *yylpp++;
8470c8de5b0SBaptiste Daroussin #endif
8480c8de5b0SBaptiste Daroussin yychar = *yylexp++;
8490c8de5b0SBaptiste Daroussin break;
8500c8de5b0SBaptiste Daroussin }
8510c8de5b0SBaptiste Daroussin if (yyps->save)
8520c8de5b0SBaptiste Daroussin {
8530c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */
8540c8de5b0SBaptiste Daroussin if (yylvp == yylvlim)
8550c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */
85611fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals);
85711fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals);
8580c8de5b0SBaptiste Daroussin
8590c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH;
860b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL) goto yyenomem;
861b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL) goto yyenomem;
8620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
863b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL) goto yyenomem;
8640c8de5b0SBaptiste Daroussin #endif
8650c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p;
8660c8de5b0SBaptiste Daroussin yylvlim = yylvals + s;
8670c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8680c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p;
8690c8de5b0SBaptiste Daroussin yylplim = yylpsns + s;
8700c8de5b0SBaptiste Daroussin #endif
8710c8de5b0SBaptiste Daroussin yylexp = yylexemes + p;
8720c8de5b0SBaptiste Daroussin }
8732aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX;
8740c8de5b0SBaptiste Daroussin *yylvp++ = yylval;
8750c8de5b0SBaptiste Daroussin yylve++;
8760c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
8770c8de5b0SBaptiste Daroussin *yylpp++ = yylloc;
8780c8de5b0SBaptiste Daroussin yylpe++;
8790c8de5b0SBaptiste Daroussin #endif
8800c8de5b0SBaptiste Daroussin yychar = *yylexp++;
8810c8de5b0SBaptiste Daroussin break;
8820c8de5b0SBaptiste Daroussin }
8830c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */
8840c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
8850c8de5b0SBaptiste Daroussin yychar = YYLEX;
8860c8de5b0SBaptiste Daroussin #if YYBTYACC
8870c8de5b0SBaptiste Daroussin } while (0);
8880c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
8890c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF;
8900c8de5b0SBaptiste Daroussin #if YYDEBUG
8910c8de5b0SBaptiste Daroussin if (yydebug)
8920c8de5b0SBaptiste Daroussin {
893c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
8940c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)",
8950c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys);
8960c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
8970c8de5b0SBaptiste Daroussin #if YYBTYACC
8980c8de5b0SBaptiste Daroussin if (!yytrial)
8990c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
9000c8de5b0SBaptiste Daroussin fprintf(stderr, " <%s>", YYSTYPE_TOSTRING(yychar, yylval));
9010c8de5b0SBaptiste Daroussin #endif
9020c8de5b0SBaptiste Daroussin fputc('\n', stderr);
9030c8de5b0SBaptiste Daroussin }
9040c8de5b0SBaptiste Daroussin #endif
9050c8de5b0SBaptiste Daroussin }
9060c8de5b0SBaptiste Daroussin #if YYBTYACC
9070c8de5b0SBaptiste Daroussin
9080c8de5b0SBaptiste Daroussin /* Do we have a conflict? */
9090c8de5b0SBaptiste Daroussin if (((yyn = yycindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
9100c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
9110c8de5b0SBaptiste Daroussin {
9120c8de5b0SBaptiste Daroussin YYINT ctry;
9130c8de5b0SBaptiste Daroussin
9140c8de5b0SBaptiste Daroussin if (yypath)
9150c8de5b0SBaptiste Daroussin {
9160c8de5b0SBaptiste Daroussin YYParseState *save;
9170c8de5b0SBaptiste Daroussin #if YYDEBUG
9180c8de5b0SBaptiste Daroussin if (yydebug)
9190c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d: following successful trial parse\n",
9200c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate);
9210c8de5b0SBaptiste Daroussin #endif
9220c8de5b0SBaptiste Daroussin /* Switch to the next conflict context */
9230c8de5b0SBaptiste Daroussin save = yypath;
9240c8de5b0SBaptiste Daroussin yypath = save->save;
9250c8de5b0SBaptiste Daroussin save->save = NULL;
9260c8de5b0SBaptiste Daroussin ctry = save->ctry;
9270c8de5b0SBaptiste Daroussin if (save->state != yystate) YYABORT;
9280c8de5b0SBaptiste Daroussin yyFreeState(save);
9290c8de5b0SBaptiste Daroussin
9300c8de5b0SBaptiste Daroussin }
9310c8de5b0SBaptiste Daroussin else
9320c8de5b0SBaptiste Daroussin {
9330c8de5b0SBaptiste Daroussin
9340c8de5b0SBaptiste Daroussin /* Unresolved conflict - start/continue trial parse */
9350c8de5b0SBaptiste Daroussin YYParseState *save;
9360c8de5b0SBaptiste Daroussin #if YYDEBUG
9370c8de5b0SBaptiste Daroussin if (yydebug)
9380c8de5b0SBaptiste Daroussin {
9390c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: CONFLICT in state %d. ", YYDEBUGSTR, yydepth, yystate);
9400c8de5b0SBaptiste Daroussin if (yyps->save)
9410c8de5b0SBaptiste Daroussin fputs("ALREADY in conflict, continuing trial parse.\n", stderr);
9420c8de5b0SBaptiste Daroussin else
9430c8de5b0SBaptiste Daroussin fputs("Starting trial parse.\n", stderr);
9440c8de5b0SBaptiste Daroussin }
9450c8de5b0SBaptiste Daroussin #endif
9460c8de5b0SBaptiste Daroussin save = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
9470c8de5b0SBaptiste Daroussin if (save == NULL) goto yyenomem;
9480c8de5b0SBaptiste Daroussin save->save = yyps->save;
9490c8de5b0SBaptiste Daroussin save->state = yystate;
9500c8de5b0SBaptiste Daroussin save->errflag = yyerrflag;
9510c8de5b0SBaptiste Daroussin save->yystack.s_mark = save->yystack.s_base + (yystack.s_mark - yystack.s_base);
952c5b5d71aSJung-uk Kim memcpy (save->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
9530c8de5b0SBaptiste Daroussin save->yystack.l_mark = save->yystack.l_base + (yystack.l_mark - yystack.l_base);
95411fce282SBaptiste Daroussin memcpy (save->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
9550c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9560c8de5b0SBaptiste Daroussin save->yystack.p_mark = save->yystack.p_base + (yystack.p_mark - yystack.p_base);
95711fce282SBaptiste Daroussin memcpy (save->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
9580c8de5b0SBaptiste Daroussin #endif
9590c8de5b0SBaptiste Daroussin ctry = yytable[yyn];
9600c8de5b0SBaptiste Daroussin if (yyctable[ctry] == -1)
9610c8de5b0SBaptiste Daroussin {
9620c8de5b0SBaptiste Daroussin #if YYDEBUG
9630c8de5b0SBaptiste Daroussin if (yydebug && yychar >= YYEOF)
9640c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: backtracking 1 token\n", YYDEBUGSTR, yydepth);
9650c8de5b0SBaptiste Daroussin #endif
9660c8de5b0SBaptiste Daroussin ctry++;
9670c8de5b0SBaptiste Daroussin }
9680c8de5b0SBaptiste Daroussin save->ctry = ctry;
9690c8de5b0SBaptiste Daroussin if (yyps->save == NULL)
9700c8de5b0SBaptiste Daroussin {
9710c8de5b0SBaptiste Daroussin /* If this is a first conflict in the stack, start saving lexemes */
9720c8de5b0SBaptiste Daroussin if (!yylexemes)
9730c8de5b0SBaptiste Daroussin {
974b53bb29fSJung-uk Kim yylexemes = (YYINT *) malloc((YYLVQUEUEGROWTH) * sizeof(YYINT));
9750c8de5b0SBaptiste Daroussin if (yylexemes == NULL) goto yyenomem;
9760c8de5b0SBaptiste Daroussin yylvals = (YYSTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYSTYPE));
9770c8de5b0SBaptiste Daroussin if (yylvals == NULL) goto yyenomem;
9780c8de5b0SBaptiste Daroussin yylvlim = yylvals + YYLVQUEUEGROWTH;
9790c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9800c8de5b0SBaptiste Daroussin yylpsns = (YYLTYPE *) malloc((YYLVQUEUEGROWTH) * sizeof(YYLTYPE));
9810c8de5b0SBaptiste Daroussin if (yylpsns == NULL) goto yyenomem;
9820c8de5b0SBaptiste Daroussin yylplim = yylpsns + YYLVQUEUEGROWTH;
9830c8de5b0SBaptiste Daroussin #endif
9840c8de5b0SBaptiste Daroussin }
9850c8de5b0SBaptiste Daroussin if (yylvp == yylve)
9860c8de5b0SBaptiste Daroussin {
9870c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals;
9880c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9890c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns;
9900c8de5b0SBaptiste Daroussin #endif
9910c8de5b0SBaptiste Daroussin yylexp = yylexemes;
9920c8de5b0SBaptiste Daroussin if (yychar >= YYEOF)
9930c8de5b0SBaptiste Daroussin {
9940c8de5b0SBaptiste Daroussin *yylve++ = yylval;
9950c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
9960c8de5b0SBaptiste Daroussin *yylpe++ = yylloc;
9970c8de5b0SBaptiste Daroussin #endif
9982aca18c7SJung-uk Kim *yylexp = (YYINT) yychar;
9990c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10000c8de5b0SBaptiste Daroussin }
10010c8de5b0SBaptiste Daroussin }
10020c8de5b0SBaptiste Daroussin }
10030c8de5b0SBaptiste Daroussin if (yychar >= YYEOF)
10040c8de5b0SBaptiste Daroussin {
10050c8de5b0SBaptiste Daroussin yylvp--;
10060c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10070c8de5b0SBaptiste Daroussin yylpp--;
10080c8de5b0SBaptiste Daroussin #endif
10090c8de5b0SBaptiste Daroussin yylexp--;
10100c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10110c8de5b0SBaptiste Daroussin }
101211fce282SBaptiste Daroussin save->lexeme = (int) (yylvp - yylvals);
10130c8de5b0SBaptiste Daroussin yyps->save = save;
10140c8de5b0SBaptiste Daroussin }
10150c8de5b0SBaptiste Daroussin if (yytable[yyn] == ctry)
10160c8de5b0SBaptiste Daroussin {
10170c8de5b0SBaptiste Daroussin #if YYDEBUG
10180c8de5b0SBaptiste Daroussin if (yydebug)
10190c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
10200c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyctable[ctry]);
10210c8de5b0SBaptiste Daroussin #endif
10220c8de5b0SBaptiste Daroussin if (yychar < 0)
10230c8de5b0SBaptiste Daroussin {
10240c8de5b0SBaptiste Daroussin yylvp++;
10250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10260c8de5b0SBaptiste Daroussin yylpp++;
10270c8de5b0SBaptiste Daroussin #endif
10280c8de5b0SBaptiste Daroussin yylexp++;
10290c8de5b0SBaptiste Daroussin }
10300c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM)
10310c8de5b0SBaptiste Daroussin goto yyoverflow;
10320c8de5b0SBaptiste Daroussin yystate = yyctable[ctry];
1033c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
10340c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
10350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10360c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc;
10370c8de5b0SBaptiste Daroussin #endif
10380c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10390c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag;
10400c8de5b0SBaptiste Daroussin goto yyloop;
10410c8de5b0SBaptiste Daroussin }
10420c8de5b0SBaptiste Daroussin else
10430c8de5b0SBaptiste Daroussin {
10440c8de5b0SBaptiste Daroussin yyn = yyctable[ctry];
10450c8de5b0SBaptiste Daroussin goto yyreduce;
10460c8de5b0SBaptiste Daroussin }
10470c8de5b0SBaptiste Daroussin } /* End of code dealing with conflicts */
10480c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
10490c8de5b0SBaptiste Daroussin if (((yyn = yysindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
10500c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
10510c8de5b0SBaptiste Daroussin {
10520c8de5b0SBaptiste Daroussin #if YYDEBUG
10530c8de5b0SBaptiste Daroussin if (yydebug)
10540c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, shifting to state %d\n",
10550c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yytable[yyn]);
10560c8de5b0SBaptiste Daroussin #endif
10570c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
10580c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
10590c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
10600c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
10610c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
10620c8de5b0SBaptiste Daroussin *++yystack.p_mark = yylloc;
10630c8de5b0SBaptiste Daroussin #endif
10640c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
10650c8de5b0SBaptiste Daroussin if (yyerrflag > 0) --yyerrflag;
10660c8de5b0SBaptiste Daroussin goto yyloop;
10670c8de5b0SBaptiste Daroussin }
10680c8de5b0SBaptiste Daroussin if (((yyn = yyrindex[yystate]) != 0) && (yyn += yychar) >= 0 &&
10690c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yychar)
10700c8de5b0SBaptiste Daroussin {
10710c8de5b0SBaptiste Daroussin yyn = yytable[yyn];
10720c8de5b0SBaptiste Daroussin goto yyreduce;
10730c8de5b0SBaptiste Daroussin }
10740c8de5b0SBaptiste Daroussin if (yyerrflag != 0) goto yyinrecovery;
10750c8de5b0SBaptiste Daroussin #if YYBTYACC
10760c8de5b0SBaptiste Daroussin
10770c8de5b0SBaptiste Daroussin yynewerrflag = 1;
10780c8de5b0SBaptiste Daroussin goto yyerrhandler;
1079c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
10800c8de5b0SBaptiste Daroussin
10810c8de5b0SBaptiste Daroussin yyerrlab:
1082c5b5d71aSJung-uk Kim /* explicit YYERROR from an action -- pop the rhs of the rule reduced
1083c5b5d71aSJung-uk Kim * before looking for error recovery */
1084c5b5d71aSJung-uk Kim yystack.s_mark -= yym;
1085c5b5d71aSJung-uk Kim yystate = *yystack.s_mark;
1086c5b5d71aSJung-uk Kim yystack.l_mark -= yym;
1087c5b5d71aSJung-uk Kim #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1088c5b5d71aSJung-uk Kim yystack.p_mark -= yym;
1089c5b5d71aSJung-uk Kim #endif
1090c5b5d71aSJung-uk Kim
10910c8de5b0SBaptiste Daroussin yynewerrflag = 0;
10920c8de5b0SBaptiste Daroussin yyerrhandler:
10930c8de5b0SBaptiste Daroussin while (yyps->save)
10940c8de5b0SBaptiste Daroussin {
10950c8de5b0SBaptiste Daroussin int ctry;
10960c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save;
10970c8de5b0SBaptiste Daroussin #if YYDEBUG
10980c8de5b0SBaptiste Daroussin if (yydebug)
10990c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\n",
11000c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyps->save->state,
11010c8de5b0SBaptiste Daroussin (int)(yylvp - yylvals - yyps->save->lexeme));
11020c8de5b0SBaptiste Daroussin #endif
11030c8de5b0SBaptiste Daroussin /* Memorize most forward-looking error state in case it's really an error. */
11040c8de5b0SBaptiste Daroussin if (yyerrctx == NULL || yyerrctx->lexeme < yylvp - yylvals)
11050c8de5b0SBaptiste Daroussin {
11060c8de5b0SBaptiste Daroussin /* Free old saved error context state */
11070c8de5b0SBaptiste Daroussin if (yyerrctx) yyFreeState(yyerrctx);
11080c8de5b0SBaptiste Daroussin /* Create and fill out new saved error context state */
11090c8de5b0SBaptiste Daroussin yyerrctx = yyNewState((unsigned)(yystack.s_mark - yystack.s_base + 1));
11100c8de5b0SBaptiste Daroussin if (yyerrctx == NULL) goto yyenomem;
11110c8de5b0SBaptiste Daroussin yyerrctx->save = yyps->save;
11120c8de5b0SBaptiste Daroussin yyerrctx->state = yystate;
11130c8de5b0SBaptiste Daroussin yyerrctx->errflag = yyerrflag;
11140c8de5b0SBaptiste Daroussin yyerrctx->yystack.s_mark = yyerrctx->yystack.s_base + (yystack.s_mark - yystack.s_base);
1115c5b5d71aSJung-uk Kim memcpy (yyerrctx->yystack.s_base, yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11160c8de5b0SBaptiste Daroussin yyerrctx->yystack.l_mark = yyerrctx->yystack.l_base + (yystack.l_mark - yystack.l_base);
111711fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.l_base, yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11180c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11190c8de5b0SBaptiste Daroussin yyerrctx->yystack.p_mark = yyerrctx->yystack.p_base + (yystack.p_mark - yystack.p_base);
112011fce282SBaptiste Daroussin memcpy (yyerrctx->yystack.p_base, yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11210c8de5b0SBaptiste Daroussin #endif
112211fce282SBaptiste Daroussin yyerrctx->lexeme = (int) (yylvp - yylvals);
11230c8de5b0SBaptiste Daroussin }
11240c8de5b0SBaptiste Daroussin yylvp = yylvals + save->lexeme;
11250c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11260c8de5b0SBaptiste Daroussin yylpp = yylpsns + save->lexeme;
11270c8de5b0SBaptiste Daroussin #endif
11280c8de5b0SBaptiste Daroussin yylexp = yylexemes + save->lexeme;
11290c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
11300c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (save->yystack.s_mark - save->yystack.s_base);
1131c5b5d71aSJung-uk Kim memcpy (yystack.s_base, save->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11320c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (save->yystack.l_mark - save->yystack.l_base);
113311fce282SBaptiste Daroussin memcpy (yystack.l_base, save->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11340c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11350c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (save->yystack.p_mark - save->yystack.p_base);
113611fce282SBaptiste Daroussin memcpy (yystack.p_base, save->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11370c8de5b0SBaptiste Daroussin #endif
11380c8de5b0SBaptiste Daroussin ctry = ++save->ctry;
11390c8de5b0SBaptiste Daroussin yystate = save->state;
11400c8de5b0SBaptiste Daroussin /* We tried shift, try reduce now */
11410c8de5b0SBaptiste Daroussin if ((yyn = yyctable[ctry]) >= 0) goto yyreduce;
11420c8de5b0SBaptiste Daroussin yyps->save = save->save;
11430c8de5b0SBaptiste Daroussin save->save = NULL;
11440c8de5b0SBaptiste Daroussin yyFreeState(save);
11450c8de5b0SBaptiste Daroussin
11460c8de5b0SBaptiste Daroussin /* Nothing left on the stack -- error */
11470c8de5b0SBaptiste Daroussin if (!yyps->save)
11480c8de5b0SBaptiste Daroussin {
11490c8de5b0SBaptiste Daroussin #if YYDEBUG
11500c8de5b0SBaptiste Daroussin if (yydebug)
11510c8de5b0SBaptiste Daroussin fprintf(stderr, "%sdebug[%d,trial]: trial parse FAILED, entering ERROR mode\n",
11520c8de5b0SBaptiste Daroussin YYPREFIX, yydepth);
11530c8de5b0SBaptiste Daroussin #endif
11540c8de5b0SBaptiste Daroussin /* Restore state as it was in the most forward-advanced error */
11550c8de5b0SBaptiste Daroussin yylvp = yylvals + yyerrctx->lexeme;
11560c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11570c8de5b0SBaptiste Daroussin yylpp = yylpsns + yyerrctx->lexeme;
11580c8de5b0SBaptiste Daroussin #endif
11590c8de5b0SBaptiste Daroussin yylexp = yylexemes + yyerrctx->lexeme;
11600c8de5b0SBaptiste Daroussin yychar = yylexp[-1];
11610c8de5b0SBaptiste Daroussin yylval = yylvp[-1];
11620c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11630c8de5b0SBaptiste Daroussin yylloc = yylpp[-1];
11640c8de5b0SBaptiste Daroussin #endif
11650c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yyerrctx->yystack.s_mark - yyerrctx->yystack.s_base);
1166c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yyerrctx->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
11670c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yyerrctx->yystack.l_mark - yyerrctx->yystack.l_base);
116811fce282SBaptiste Daroussin memcpy (yystack.l_base, yyerrctx->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
11690c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
11700c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yyerrctx->yystack.p_mark - yyerrctx->yystack.p_base);
117111fce282SBaptiste Daroussin memcpy (yystack.p_base, yyerrctx->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
11720c8de5b0SBaptiste Daroussin #endif
11730c8de5b0SBaptiste Daroussin yystate = yyerrctx->state;
11740c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
11750c8de5b0SBaptiste Daroussin yyerrctx = NULL;
11760c8de5b0SBaptiste Daroussin }
11770c8de5b0SBaptiste Daroussin yynewerrflag = 1;
11780c8de5b0SBaptiste Daroussin }
11790c8de5b0SBaptiste Daroussin if (yynewerrflag == 0) goto yyinrecovery;
11800c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
11810c8de5b0SBaptiste Daroussin
11820c8de5b0SBaptiste Daroussin YYERROR_CALL("syntax error");
11830c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1184b53bb29fSJung-uk Kim yyerror_loc_range[1] = yylloc; /* lookahead position is error start position */
11850c8de5b0SBaptiste Daroussin #endif
11860c8de5b0SBaptiste Daroussin
11870c8de5b0SBaptiste Daroussin #if !YYBTYACC
1188c5b5d71aSJung-uk Kim goto yyerrlab; /* redundant goto avoids 'unused label' warning */
11890c8de5b0SBaptiste Daroussin yyerrlab:
11900c8de5b0SBaptiste Daroussin #endif
11910c8de5b0SBaptiste Daroussin ++yynerrs;
11920c8de5b0SBaptiste Daroussin
11930c8de5b0SBaptiste Daroussin yyinrecovery:
11940c8de5b0SBaptiste Daroussin if (yyerrflag < 3)
11950c8de5b0SBaptiste Daroussin {
11960c8de5b0SBaptiste Daroussin yyerrflag = 3;
11970c8de5b0SBaptiste Daroussin for (;;)
11980c8de5b0SBaptiste Daroussin {
11990c8de5b0SBaptiste Daroussin if (((yyn = yysindex[*yystack.s_mark]) != 0) && (yyn += YYERRCODE) >= 0 &&
12000c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) YYERRCODE)
12010c8de5b0SBaptiste Daroussin {
12020c8de5b0SBaptiste Daroussin #if YYDEBUG
12030c8de5b0SBaptiste Daroussin if (yydebug)
12040c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery shifting to state %d\n",
12050c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark, yytable[yyn]);
12060c8de5b0SBaptiste Daroussin #endif
12070c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
12080c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
12090c8de5b0SBaptiste Daroussin *++yystack.s_mark = yytable[yyn];
12100c8de5b0SBaptiste Daroussin *++yystack.l_mark = yylval;
12110c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12120c8de5b0SBaptiste Daroussin /* lookahead position is error end position */
1213b53bb29fSJung-uk Kim yyerror_loc_range[2] = yylloc;
12140c8de5b0SBaptiste Daroussin YYLLOC_DEFAULT(yyloc, yyerror_loc_range, 2); /* position of error span */
12150c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
12160c8de5b0SBaptiste Daroussin #endif
12170c8de5b0SBaptiste Daroussin goto yyloop;
12180c8de5b0SBaptiste Daroussin }
12190c8de5b0SBaptiste Daroussin else
12200c8de5b0SBaptiste Daroussin {
12210c8de5b0SBaptiste Daroussin #if YYDEBUG
12220c8de5b0SBaptiste Daroussin if (yydebug)
12230c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: error recovery discarding state %d\n",
12240c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, *yystack.s_mark);
12250c8de5b0SBaptiste Daroussin #endif
12260c8de5b0SBaptiste Daroussin if (yystack.s_mark <= yystack.s_base) goto yyabort;
12270c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12280c8de5b0SBaptiste Daroussin /* the current TOS position is the error start position */
1229b53bb29fSJung-uk Kim yyerror_loc_range[1] = *yystack.p_mark;
12300c8de5b0SBaptiste Daroussin #endif
12310c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
12320c8de5b0SBaptiste Daroussin #if YYBTYACC
12330c8de5b0SBaptiste Daroussin if (!yytrial)
12340c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12350c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12360c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state",
12370c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark, yystack.p_mark);
12380c8de5b0SBaptiste Daroussin #else
12390c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding state",
12400c8de5b0SBaptiste Daroussin yystos[*yystack.s_mark], yystack.l_mark);
12410c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
12420c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
12430c8de5b0SBaptiste Daroussin --yystack.s_mark;
12440c8de5b0SBaptiste Daroussin --yystack.l_mark;
12450c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12460c8de5b0SBaptiste Daroussin --yystack.p_mark;
12470c8de5b0SBaptiste Daroussin #endif
12480c8de5b0SBaptiste Daroussin }
12490c8de5b0SBaptiste Daroussin }
12500c8de5b0SBaptiste Daroussin }
12510c8de5b0SBaptiste Daroussin else
12520c8de5b0SBaptiste Daroussin {
12530c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyabort;
12540c8de5b0SBaptiste Daroussin #if YYDEBUG
12550c8de5b0SBaptiste Daroussin if (yydebug)
12560c8de5b0SBaptiste Daroussin {
1257c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
12580c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, error recovery discarding token %d (%s)\n",
12590c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yychar, yys);
12600c8de5b0SBaptiste Daroussin }
12610c8de5b0SBaptiste Daroussin #endif
12620c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
12630c8de5b0SBaptiste Daroussin #if YYBTYACC
12640c8de5b0SBaptiste Daroussin if (!yytrial)
12650c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12660c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
12670c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval, &yylloc);
12680c8de5b0SBaptiste Daroussin #else
12690c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("error: discarding token", yychar, &yylval);
12700c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
12710c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
12720c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
12730c8de5b0SBaptiste Daroussin goto yyloop;
12740c8de5b0SBaptiste Daroussin }
12750c8de5b0SBaptiste Daroussin
12760c8de5b0SBaptiste Daroussin yyreduce:
12770c8de5b0SBaptiste Daroussin yym = yylen[yyn];
12780c8de5b0SBaptiste Daroussin #if YYDEBUG
12790c8de5b0SBaptiste Daroussin if (yydebug)
12800c8de5b0SBaptiste Daroussin {
12810c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, reducing by rule %d (%s)",
12820c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yyn, yyrule[yyn]);
12830c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
12840c8de5b0SBaptiste Daroussin #if YYBTYACC
12850c8de5b0SBaptiste Daroussin if (!yytrial)
12860c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
12870c8de5b0SBaptiste Daroussin if (yym > 0)
12880c8de5b0SBaptiste Daroussin {
12890c8de5b0SBaptiste Daroussin int i;
12900c8de5b0SBaptiste Daroussin fputc('<', stderr);
12910c8de5b0SBaptiste Daroussin for (i = yym; i > 0; i--)
12920c8de5b0SBaptiste Daroussin {
12930c8de5b0SBaptiste Daroussin if (i != yym) fputs(", ", stderr);
12940c8de5b0SBaptiste Daroussin fputs(YYSTYPE_TOSTRING(yystos[yystack.s_mark[1-i]],
12950c8de5b0SBaptiste Daroussin yystack.l_mark[1-i]), stderr);
12960c8de5b0SBaptiste Daroussin }
12970c8de5b0SBaptiste Daroussin fputc('>', stderr);
12980c8de5b0SBaptiste Daroussin }
12990c8de5b0SBaptiste Daroussin #endif
13000c8de5b0SBaptiste Daroussin fputc('\n', stderr);
13010c8de5b0SBaptiste Daroussin }
13020c8de5b0SBaptiste Daroussin #endif
13030c8de5b0SBaptiste Daroussin if (yym > 0)
13040c8de5b0SBaptiste Daroussin yyval = yystack.l_mark[1-yym];
13050c8de5b0SBaptiste Daroussin else
13060c8de5b0SBaptiste Daroussin memset(&yyval, 0, sizeof yyval);
13070c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
13080c8de5b0SBaptiste Daroussin
13090c8de5b0SBaptiste Daroussin /* Perform position reduction */
13100c8de5b0SBaptiste Daroussin memset(&yyloc, 0, sizeof(yyloc));
13110c8de5b0SBaptiste Daroussin #if YYBTYACC
13120c8de5b0SBaptiste Daroussin if (!yytrial)
13130c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
13140c8de5b0SBaptiste Daroussin {
1315b53bb29fSJung-uk Kim YYLLOC_DEFAULT(yyloc, &yystack.p_mark[-yym], yym);
13160c8de5b0SBaptiste Daroussin /* just in case YYERROR is invoked within the action, save
13170c8de5b0SBaptiste Daroussin the start of the rhs as the error start position */
1318b53bb29fSJung-uk Kim yyerror_loc_range[1] = yystack.p_mark[1-yym];
13190c8de5b0SBaptiste Daroussin }
13200c8de5b0SBaptiste Daroussin #endif
13210c8de5b0SBaptiste Daroussin
13220c8de5b0SBaptiste Daroussin switch (yyn)
13230c8de5b0SBaptiste Daroussin {
13240c8de5b0SBaptiste Daroussin case 3:
13250c8de5b0SBaptiste Daroussin #line 57 "calc1.y"
13260c8de5b0SBaptiste Daroussin {
13270c8de5b0SBaptiste Daroussin (void) printf("%15.8f\n", yystack.l_mark[-1].dval);
13280c8de5b0SBaptiste Daroussin }
13298e022d3cSDag-Erling Smørgrav #line 1330 "calc1.tab.c"
13300c8de5b0SBaptiste Daroussin break;
13310c8de5b0SBaptiste Daroussin case 4:
13320c8de5b0SBaptiste Daroussin #line 61 "calc1.y"
13330c8de5b0SBaptiste Daroussin {
13340c8de5b0SBaptiste Daroussin (void) printf("(%15.8f, %15.8f)\n", yystack.l_mark[-1].vval.lo, yystack.l_mark[-1].vval.hi);
13350c8de5b0SBaptiste Daroussin }
13368e022d3cSDag-Erling Smørgrav #line 1337 "calc1.tab.c"
13370c8de5b0SBaptiste Daroussin break;
13380c8de5b0SBaptiste Daroussin case 5:
13390c8de5b0SBaptiste Daroussin #line 65 "calc1.y"
13400c8de5b0SBaptiste Daroussin {
13410c8de5b0SBaptiste Daroussin dreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].dval;
13420c8de5b0SBaptiste Daroussin }
13438e022d3cSDag-Erling Smørgrav #line 1344 "calc1.tab.c"
13440c8de5b0SBaptiste Daroussin break;
13450c8de5b0SBaptiste Daroussin case 6:
13460c8de5b0SBaptiste Daroussin #line 69 "calc1.y"
13470c8de5b0SBaptiste Daroussin {
13480c8de5b0SBaptiste Daroussin vreg[yystack.l_mark[-3].ival] = yystack.l_mark[-1].vval;
13490c8de5b0SBaptiste Daroussin }
13508e022d3cSDag-Erling Smørgrav #line 1351 "calc1.tab.c"
13510c8de5b0SBaptiste Daroussin break;
13520c8de5b0SBaptiste Daroussin case 7:
13530c8de5b0SBaptiste Daroussin #line 73 "calc1.y"
13540c8de5b0SBaptiste Daroussin {
13550c8de5b0SBaptiste Daroussin yyerrok;
13560c8de5b0SBaptiste Daroussin }
13578e022d3cSDag-Erling Smørgrav #line 1358 "calc1.tab.c"
13580c8de5b0SBaptiste Daroussin break;
13590c8de5b0SBaptiste Daroussin case 9:
13600c8de5b0SBaptiste Daroussin #line 80 "calc1.y"
13610c8de5b0SBaptiste Daroussin {
13620c8de5b0SBaptiste Daroussin yyval.dval = dreg[yystack.l_mark[0].ival];
13630c8de5b0SBaptiste Daroussin }
13648e022d3cSDag-Erling Smørgrav #line 1365 "calc1.tab.c"
13650c8de5b0SBaptiste Daroussin break;
13660c8de5b0SBaptiste Daroussin case 10:
13670c8de5b0SBaptiste Daroussin #line 84 "calc1.y"
13680c8de5b0SBaptiste Daroussin {
13690c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval + yystack.l_mark[0].dval;
13700c8de5b0SBaptiste Daroussin }
13718e022d3cSDag-Erling Smørgrav #line 1372 "calc1.tab.c"
13720c8de5b0SBaptiste Daroussin break;
13730c8de5b0SBaptiste Daroussin case 11:
13740c8de5b0SBaptiste Daroussin #line 88 "calc1.y"
13750c8de5b0SBaptiste Daroussin {
13760c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval - yystack.l_mark[0].dval;
13770c8de5b0SBaptiste Daroussin }
13788e022d3cSDag-Erling Smørgrav #line 1379 "calc1.tab.c"
13790c8de5b0SBaptiste Daroussin break;
13800c8de5b0SBaptiste Daroussin case 12:
13810c8de5b0SBaptiste Daroussin #line 92 "calc1.y"
13820c8de5b0SBaptiste Daroussin {
13830c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval * yystack.l_mark[0].dval;
13840c8de5b0SBaptiste Daroussin }
13858e022d3cSDag-Erling Smørgrav #line 1386 "calc1.tab.c"
13860c8de5b0SBaptiste Daroussin break;
13870c8de5b0SBaptiste Daroussin case 13:
13880c8de5b0SBaptiste Daroussin #line 96 "calc1.y"
13890c8de5b0SBaptiste Daroussin {
13900c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-2].dval / yystack.l_mark[0].dval;
13910c8de5b0SBaptiste Daroussin }
13928e022d3cSDag-Erling Smørgrav #line 1393 "calc1.tab.c"
13930c8de5b0SBaptiste Daroussin break;
13940c8de5b0SBaptiste Daroussin case 14:
13950c8de5b0SBaptiste Daroussin #line 100 "calc1.y"
13960c8de5b0SBaptiste Daroussin {
13970c8de5b0SBaptiste Daroussin yyval.dval = -yystack.l_mark[0].dval;
13980c8de5b0SBaptiste Daroussin }
13998e022d3cSDag-Erling Smørgrav #line 1400 "calc1.tab.c"
14000c8de5b0SBaptiste Daroussin break;
14010c8de5b0SBaptiste Daroussin case 15:
14020c8de5b0SBaptiste Daroussin #line 104 "calc1.y"
14030c8de5b0SBaptiste Daroussin {
14040c8de5b0SBaptiste Daroussin yyval.dval = yystack.l_mark[-1].dval;
14050c8de5b0SBaptiste Daroussin }
14068e022d3cSDag-Erling Smørgrav #line 1407 "calc1.tab.c"
14070c8de5b0SBaptiste Daroussin break;
14080c8de5b0SBaptiste Daroussin case 16:
14090c8de5b0SBaptiste Daroussin #line 110 "calc1.y"
14100c8de5b0SBaptiste Daroussin {
14110c8de5b0SBaptiste Daroussin yyval.vval.hi = yyval.vval.lo = yystack.l_mark[0].dval;
14120c8de5b0SBaptiste Daroussin }
14138e022d3cSDag-Erling Smørgrav #line 1414 "calc1.tab.c"
14140c8de5b0SBaptiste Daroussin break;
14150c8de5b0SBaptiste Daroussin case 17:
14160c8de5b0SBaptiste Daroussin #line 114 "calc1.y"
14170c8de5b0SBaptiste Daroussin {
14180c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-3].dval;
14190c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-1].dval;
14200c8de5b0SBaptiste Daroussin if ( yyval.vval.lo > yyval.vval.hi )
14210c8de5b0SBaptiste Daroussin {
14220c8de5b0SBaptiste Daroussin (void) printf("interval out of order\n");
14230c8de5b0SBaptiste Daroussin YYERROR;
14240c8de5b0SBaptiste Daroussin }
14250c8de5b0SBaptiste Daroussin }
14268e022d3cSDag-Erling Smørgrav #line 1427 "calc1.tab.c"
14270c8de5b0SBaptiste Daroussin break;
14280c8de5b0SBaptiste Daroussin case 18:
14290c8de5b0SBaptiste Daroussin #line 124 "calc1.y"
14300c8de5b0SBaptiste Daroussin {
14310c8de5b0SBaptiste Daroussin yyval.vval = vreg[yystack.l_mark[0].ival];
14320c8de5b0SBaptiste Daroussin }
14338e022d3cSDag-Erling Smørgrav #line 1434 "calc1.tab.c"
14340c8de5b0SBaptiste Daroussin break;
14350c8de5b0SBaptiste Daroussin case 19:
14360c8de5b0SBaptiste Daroussin #line 128 "calc1.y"
14370c8de5b0SBaptiste Daroussin {
14380c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi + yystack.l_mark[0].vval.hi;
14390c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo + yystack.l_mark[0].vval.lo;
14400c8de5b0SBaptiste Daroussin }
14418e022d3cSDag-Erling Smørgrav #line 1442 "calc1.tab.c"
14420c8de5b0SBaptiste Daroussin break;
14430c8de5b0SBaptiste Daroussin case 20:
14440c8de5b0SBaptiste Daroussin #line 133 "calc1.y"
14450c8de5b0SBaptiste Daroussin {
14460c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.hi;
14470c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval + yystack.l_mark[0].vval.lo;
14480c8de5b0SBaptiste Daroussin }
14498e022d3cSDag-Erling Smørgrav #line 1450 "calc1.tab.c"
14500c8de5b0SBaptiste Daroussin break;
14510c8de5b0SBaptiste Daroussin case 21:
14520c8de5b0SBaptiste Daroussin #line 138 "calc1.y"
14530c8de5b0SBaptiste Daroussin {
14540c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].vval.hi - yystack.l_mark[0].vval.lo;
14550c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].vval.lo - yystack.l_mark[0].vval.hi;
14560c8de5b0SBaptiste Daroussin }
14578e022d3cSDag-Erling Smørgrav #line 1458 "calc1.tab.c"
14580c8de5b0SBaptiste Daroussin break;
14590c8de5b0SBaptiste Daroussin case 22:
14600c8de5b0SBaptiste Daroussin #line 143 "calc1.y"
14610c8de5b0SBaptiste Daroussin {
14620c8de5b0SBaptiste Daroussin yyval.vval.hi = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.lo;
14630c8de5b0SBaptiste Daroussin yyval.vval.lo = yystack.l_mark[-2].dval - yystack.l_mark[0].vval.hi;
14640c8de5b0SBaptiste Daroussin }
14658e022d3cSDag-Erling Smørgrav #line 1466 "calc1.tab.c"
14660c8de5b0SBaptiste Daroussin break;
14670c8de5b0SBaptiste Daroussin case 23:
14680c8de5b0SBaptiste Daroussin #line 148 "calc1.y"
14690c8de5b0SBaptiste Daroussin {
14700c8de5b0SBaptiste Daroussin yyval.vval = vmul( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
14710c8de5b0SBaptiste Daroussin }
14728e022d3cSDag-Erling Smørgrav #line 1473 "calc1.tab.c"
14730c8de5b0SBaptiste Daroussin break;
14740c8de5b0SBaptiste Daroussin case 24:
14750c8de5b0SBaptiste Daroussin #line 152 "calc1.y"
14760c8de5b0SBaptiste Daroussin {
14770c8de5b0SBaptiste Daroussin yyval.vval = vmul (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
14780c8de5b0SBaptiste Daroussin }
14798e022d3cSDag-Erling Smørgrav #line 1480 "calc1.tab.c"
14800c8de5b0SBaptiste Daroussin break;
14810c8de5b0SBaptiste Daroussin case 25:
14820c8de5b0SBaptiste Daroussin #line 156 "calc1.y"
14830c8de5b0SBaptiste Daroussin {
14840c8de5b0SBaptiste Daroussin if (dcheck(yystack.l_mark[0].vval)) YYERROR;
14850c8de5b0SBaptiste Daroussin yyval.vval = vdiv ( yystack.l_mark[-2].vval.lo, yystack.l_mark[-2].vval.hi, yystack.l_mark[0].vval );
14860c8de5b0SBaptiste Daroussin }
14878e022d3cSDag-Erling Smørgrav #line 1488 "calc1.tab.c"
14880c8de5b0SBaptiste Daroussin break;
14890c8de5b0SBaptiste Daroussin case 26:
14900c8de5b0SBaptiste Daroussin #line 161 "calc1.y"
14910c8de5b0SBaptiste Daroussin {
14920c8de5b0SBaptiste Daroussin if (dcheck ( yystack.l_mark[0].vval )) YYERROR;
14930c8de5b0SBaptiste Daroussin yyval.vval = vdiv (yystack.l_mark[-2].dval, yystack.l_mark[-2].dval, yystack.l_mark[0].vval );
14940c8de5b0SBaptiste Daroussin }
14958e022d3cSDag-Erling Smørgrav #line 1496 "calc1.tab.c"
14960c8de5b0SBaptiste Daroussin break;
14970c8de5b0SBaptiste Daroussin case 27:
14980c8de5b0SBaptiste Daroussin #line 166 "calc1.y"
14990c8de5b0SBaptiste Daroussin {
15000c8de5b0SBaptiste Daroussin yyval.vval.hi = -yystack.l_mark[0].vval.lo;
15010c8de5b0SBaptiste Daroussin yyval.vval.lo = -yystack.l_mark[0].vval.hi;
15020c8de5b0SBaptiste Daroussin }
15038e022d3cSDag-Erling Smørgrav #line 1504 "calc1.tab.c"
15040c8de5b0SBaptiste Daroussin break;
15050c8de5b0SBaptiste Daroussin case 28:
15060c8de5b0SBaptiste Daroussin #line 171 "calc1.y"
15070c8de5b0SBaptiste Daroussin {
15080c8de5b0SBaptiste Daroussin yyval.vval = yystack.l_mark[-1].vval;
15090c8de5b0SBaptiste Daroussin }
15108e022d3cSDag-Erling Smørgrav #line 1511 "calc1.tab.c"
15110c8de5b0SBaptiste Daroussin break;
15128e022d3cSDag-Erling Smørgrav #line 1513 "calc1.tab.c"
15130c8de5b0SBaptiste Daroussin default:
15140c8de5b0SBaptiste Daroussin break;
15150c8de5b0SBaptiste Daroussin }
15160c8de5b0SBaptiste Daroussin yystack.s_mark -= yym;
15170c8de5b0SBaptiste Daroussin yystate = *yystack.s_mark;
15180c8de5b0SBaptiste Daroussin yystack.l_mark -= yym;
15190c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15200c8de5b0SBaptiste Daroussin yystack.p_mark -= yym;
15210c8de5b0SBaptiste Daroussin #endif
15220c8de5b0SBaptiste Daroussin yym = yylhs[yyn];
15230c8de5b0SBaptiste Daroussin if (yystate == 0 && yym == 0)
15240c8de5b0SBaptiste Daroussin {
15250c8de5b0SBaptiste Daroussin #if YYDEBUG
15260c8de5b0SBaptiste Daroussin if (yydebug)
15270c8de5b0SBaptiste Daroussin {
15280c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
15290c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
15300c8de5b0SBaptiste Daroussin #if YYBTYACC
15310c8de5b0SBaptiste Daroussin if (!yytrial)
15320c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
15330c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[YYFINAL], yyval));
15340c8de5b0SBaptiste Daroussin #endif
15350c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state 0 to final state %d\n", YYFINAL);
15360c8de5b0SBaptiste Daroussin }
15370c8de5b0SBaptiste Daroussin #endif
15380c8de5b0SBaptiste Daroussin yystate = YYFINAL;
15390c8de5b0SBaptiste Daroussin *++yystack.s_mark = YYFINAL;
15400c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
15410c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15420c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
15430c8de5b0SBaptiste Daroussin #endif
15440c8de5b0SBaptiste Daroussin if (yychar < 0)
15450c8de5b0SBaptiste Daroussin {
15460c8de5b0SBaptiste Daroussin #if YYBTYACC
15470c8de5b0SBaptiste Daroussin do {
15480c8de5b0SBaptiste Daroussin if (yylvp < yylve)
15490c8de5b0SBaptiste Daroussin {
15500c8de5b0SBaptiste Daroussin /* we're currently re-reading tokens */
15510c8de5b0SBaptiste Daroussin yylval = *yylvp++;
15520c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15530c8de5b0SBaptiste Daroussin yylloc = *yylpp++;
15540c8de5b0SBaptiste Daroussin #endif
15550c8de5b0SBaptiste Daroussin yychar = *yylexp++;
15560c8de5b0SBaptiste Daroussin break;
15570c8de5b0SBaptiste Daroussin }
15580c8de5b0SBaptiste Daroussin if (yyps->save)
15590c8de5b0SBaptiste Daroussin {
15600c8de5b0SBaptiste Daroussin /* in trial mode; save scanner results for future parse attempts */
15610c8de5b0SBaptiste Daroussin if (yylvp == yylvlim)
15620c8de5b0SBaptiste Daroussin { /* Enlarge lexical value queue */
156311fce282SBaptiste Daroussin size_t p = (size_t) (yylvp - yylvals);
156411fce282SBaptiste Daroussin size_t s = (size_t) (yylvlim - yylvals);
15650c8de5b0SBaptiste Daroussin
15660c8de5b0SBaptiste Daroussin s += YYLVQUEUEGROWTH;
1567b53bb29fSJung-uk Kim if ((yylexemes = (YYINT *)realloc(yylexemes, s * sizeof(YYINT))) == NULL)
15680c8de5b0SBaptiste Daroussin goto yyenomem;
1569b53bb29fSJung-uk Kim if ((yylvals = (YYSTYPE *)realloc(yylvals, s * sizeof(YYSTYPE))) == NULL)
15700c8de5b0SBaptiste Daroussin goto yyenomem;
15710c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
1572b53bb29fSJung-uk Kim if ((yylpsns = (YYLTYPE *)realloc(yylpsns, s * sizeof(YYLTYPE))) == NULL)
15730c8de5b0SBaptiste Daroussin goto yyenomem;
15740c8de5b0SBaptiste Daroussin #endif
15750c8de5b0SBaptiste Daroussin yylvp = yylve = yylvals + p;
15760c8de5b0SBaptiste Daroussin yylvlim = yylvals + s;
15770c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15780c8de5b0SBaptiste Daroussin yylpp = yylpe = yylpsns + p;
15790c8de5b0SBaptiste Daroussin yylplim = yylpsns + s;
15800c8de5b0SBaptiste Daroussin #endif
15810c8de5b0SBaptiste Daroussin yylexp = yylexemes + p;
15820c8de5b0SBaptiste Daroussin }
15832aca18c7SJung-uk Kim *yylexp = (YYINT) YYLEX;
15840c8de5b0SBaptiste Daroussin *yylvp++ = yylval;
15850c8de5b0SBaptiste Daroussin yylve++;
15860c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
15870c8de5b0SBaptiste Daroussin *yylpp++ = yylloc;
15880c8de5b0SBaptiste Daroussin yylpe++;
15890c8de5b0SBaptiste Daroussin #endif
15900c8de5b0SBaptiste Daroussin yychar = *yylexp++;
15910c8de5b0SBaptiste Daroussin break;
15920c8de5b0SBaptiste Daroussin }
15930c8de5b0SBaptiste Daroussin /* normal operation, no conflict encountered */
15940c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
15950c8de5b0SBaptiste Daroussin yychar = YYLEX;
15960c8de5b0SBaptiste Daroussin #if YYBTYACC
15970c8de5b0SBaptiste Daroussin } while (0);
15980c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
15990c8de5b0SBaptiste Daroussin if (yychar < 0) yychar = YYEOF;
16000c8de5b0SBaptiste Daroussin #if YYDEBUG
16010c8de5b0SBaptiste Daroussin if (yydebug)
16020c8de5b0SBaptiste Daroussin {
1603c5b5d71aSJung-uk Kim if ((yys = yyname[YYTRANSLATE(yychar)]) == NULL) yys = yyname[YYUNDFTOKEN];
1604c5b5d71aSJung-uk Kim fprintf(stderr, "%s[%d]: state %d, reading token %d (%s)\n",
16050c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, YYFINAL, yychar, yys);
16060c8de5b0SBaptiste Daroussin }
16070c8de5b0SBaptiste Daroussin #endif
16080c8de5b0SBaptiste Daroussin }
16090c8de5b0SBaptiste Daroussin if (yychar == YYEOF) goto yyaccept;
16100c8de5b0SBaptiste Daroussin goto yyloop;
16110c8de5b0SBaptiste Daroussin }
16120c8de5b0SBaptiste Daroussin if (((yyn = yygindex[yym]) != 0) && (yyn += yystate) >= 0 &&
16130c8de5b0SBaptiste Daroussin yyn <= YYTABLESIZE && yycheck[yyn] == (YYINT) yystate)
16140c8de5b0SBaptiste Daroussin yystate = yytable[yyn];
16150c8de5b0SBaptiste Daroussin else
16160c8de5b0SBaptiste Daroussin yystate = yydgoto[yym];
16170c8de5b0SBaptiste Daroussin #if YYDEBUG
16180c8de5b0SBaptiste Daroussin if (yydebug)
16190c8de5b0SBaptiste Daroussin {
16200c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: after reduction, ", YYDEBUGSTR, yydepth);
16210c8de5b0SBaptiste Daroussin #ifdef YYSTYPE_TOSTRING
16220c8de5b0SBaptiste Daroussin #if YYBTYACC
16230c8de5b0SBaptiste Daroussin if (!yytrial)
16240c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16250c8de5b0SBaptiste Daroussin fprintf(stderr, "result is <%s>, ", YYSTYPE_TOSTRING(yystos[yystate], yyval));
16260c8de5b0SBaptiste Daroussin #endif
16270c8de5b0SBaptiste Daroussin fprintf(stderr, "shifting from state %d to state %d\n", *yystack.s_mark, yystate);
16280c8de5b0SBaptiste Daroussin }
16290c8de5b0SBaptiste Daroussin #endif
16300c8de5b0SBaptiste Daroussin if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack) == YYENOMEM) goto yyoverflow;
1631c5b5d71aSJung-uk Kim *++yystack.s_mark = (YYINT) yystate;
16320c8de5b0SBaptiste Daroussin *++yystack.l_mark = yyval;
16330c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16340c8de5b0SBaptiste Daroussin *++yystack.p_mark = yyloc;
16350c8de5b0SBaptiste Daroussin #endif
16360c8de5b0SBaptiste Daroussin goto yyloop;
16370c8de5b0SBaptiste Daroussin #if YYBTYACC
16380c8de5b0SBaptiste Daroussin
16390c8de5b0SBaptiste Daroussin /* Reduction declares that this path is valid. Set yypath and do a full parse */
16400c8de5b0SBaptiste Daroussin yyvalid:
16410c8de5b0SBaptiste Daroussin if (yypath) YYABORT;
16420c8de5b0SBaptiste Daroussin while (yyps->save)
16430c8de5b0SBaptiste Daroussin {
16440c8de5b0SBaptiste Daroussin YYParseState *save = yyps->save;
16450c8de5b0SBaptiste Daroussin yyps->save = save->save;
16460c8de5b0SBaptiste Daroussin save->save = yypath;
16470c8de5b0SBaptiste Daroussin yypath = save;
16480c8de5b0SBaptiste Daroussin }
16490c8de5b0SBaptiste Daroussin #if YYDEBUG
16500c8de5b0SBaptiste Daroussin if (yydebug)
16510c8de5b0SBaptiste Daroussin fprintf(stderr, "%s[%d]: state %d, CONFLICT trial successful, backtracking to state %d, %d tokens\n",
16520c8de5b0SBaptiste Daroussin YYDEBUGSTR, yydepth, yystate, yypath->state, (int)(yylvp - yylvals - yypath->lexeme));
16530c8de5b0SBaptiste Daroussin #endif
16540c8de5b0SBaptiste Daroussin if (yyerrctx)
16550c8de5b0SBaptiste Daroussin {
16560c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
16570c8de5b0SBaptiste Daroussin yyerrctx = NULL;
16580c8de5b0SBaptiste Daroussin }
16590c8de5b0SBaptiste Daroussin yylvp = yylvals + yypath->lexeme;
16600c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16610c8de5b0SBaptiste Daroussin yylpp = yylpsns + yypath->lexeme;
16620c8de5b0SBaptiste Daroussin #endif
16630c8de5b0SBaptiste Daroussin yylexp = yylexemes + yypath->lexeme;
16640c8de5b0SBaptiste Daroussin yychar = YYEMPTY;
16650c8de5b0SBaptiste Daroussin yystack.s_mark = yystack.s_base + (yypath->yystack.s_mark - yypath->yystack.s_base);
1666c5b5d71aSJung-uk Kim memcpy (yystack.s_base, yypath->yystack.s_base, (size_t) (yystack.s_mark - yystack.s_base + 1) * sizeof(YYINT));
16670c8de5b0SBaptiste Daroussin yystack.l_mark = yystack.l_base + (yypath->yystack.l_mark - yypath->yystack.l_base);
166811fce282SBaptiste Daroussin memcpy (yystack.l_base, yypath->yystack.l_base, (size_t) (yystack.l_mark - yystack.l_base + 1) * sizeof(YYSTYPE));
16690c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
16700c8de5b0SBaptiste Daroussin yystack.p_mark = yystack.p_base + (yypath->yystack.p_mark - yypath->yystack.p_base);
167111fce282SBaptiste Daroussin memcpy (yystack.p_base, yypath->yystack.p_base, (size_t) (yystack.p_mark - yystack.p_base + 1) * sizeof(YYLTYPE));
16720c8de5b0SBaptiste Daroussin #endif
16730c8de5b0SBaptiste Daroussin yystate = yypath->state;
16740c8de5b0SBaptiste Daroussin goto yyloop;
16750c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16760c8de5b0SBaptiste Daroussin
16770c8de5b0SBaptiste Daroussin yyoverflow:
16780c8de5b0SBaptiste Daroussin YYERROR_CALL("yacc stack overflow");
16790c8de5b0SBaptiste Daroussin #if YYBTYACC
16800c8de5b0SBaptiste Daroussin goto yyabort_nomem;
16810c8de5b0SBaptiste Daroussin yyenomem:
16820c8de5b0SBaptiste Daroussin YYERROR_CALL("memory exhausted");
16830c8de5b0SBaptiste Daroussin yyabort_nomem:
16840c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16850c8de5b0SBaptiste Daroussin yyresult = 2;
16860c8de5b0SBaptiste Daroussin goto yyreturn;
16870c8de5b0SBaptiste Daroussin
16880c8de5b0SBaptiste Daroussin yyabort:
16890c8de5b0SBaptiste Daroussin yyresult = 1;
16900c8de5b0SBaptiste Daroussin goto yyreturn;
16910c8de5b0SBaptiste Daroussin
16920c8de5b0SBaptiste Daroussin yyaccept:
16930c8de5b0SBaptiste Daroussin #if YYBTYACC
16940c8de5b0SBaptiste Daroussin if (yyps->save) goto yyvalid;
16950c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
16960c8de5b0SBaptiste Daroussin yyresult = 0;
16970c8de5b0SBaptiste Daroussin
16980c8de5b0SBaptiste Daroussin yyreturn:
16990c8de5b0SBaptiste Daroussin #if defined(YYDESTRUCT_CALL)
17000c8de5b0SBaptiste Daroussin if (yychar != YYEOF && yychar != YYEMPTY)
17010c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
17020c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval, &yylloc);
17030c8de5b0SBaptiste Daroussin #else
17040c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding token", yychar, &yylval);
17050c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
17060c8de5b0SBaptiste Daroussin
17070c8de5b0SBaptiste Daroussin {
17080c8de5b0SBaptiste Daroussin YYSTYPE *pv;
17090c8de5b0SBaptiste Daroussin #if defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED)
17100c8de5b0SBaptiste Daroussin YYLTYPE *pp;
17110c8de5b0SBaptiste Daroussin
17120c8de5b0SBaptiste Daroussin for (pv = yystack.l_base, pp = yystack.p_base; pv <= yystack.l_mark; ++pv, ++pp)
17130c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state",
17140c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv, pp);
17150c8de5b0SBaptiste Daroussin #else
17160c8de5b0SBaptiste Daroussin for (pv = yystack.l_base; pv <= yystack.l_mark; ++pv)
17170c8de5b0SBaptiste Daroussin YYDESTRUCT_CALL("cleanup: discarding state",
17180c8de5b0SBaptiste Daroussin yystos[*(yystack.s_base + (pv - yystack.l_base))], pv);
17190c8de5b0SBaptiste Daroussin #endif /* defined(YYLTYPE) || defined(YYLTYPE_IS_DECLARED) */
17200c8de5b0SBaptiste Daroussin }
17210c8de5b0SBaptiste Daroussin #endif /* defined(YYDESTRUCT_CALL) */
17220c8de5b0SBaptiste Daroussin
17230c8de5b0SBaptiste Daroussin #if YYBTYACC
17240c8de5b0SBaptiste Daroussin if (yyerrctx)
17250c8de5b0SBaptiste Daroussin {
17260c8de5b0SBaptiste Daroussin yyFreeState(yyerrctx);
17270c8de5b0SBaptiste Daroussin yyerrctx = NULL;
17280c8de5b0SBaptiste Daroussin }
17290c8de5b0SBaptiste Daroussin while (yyps)
17300c8de5b0SBaptiste Daroussin {
17310c8de5b0SBaptiste Daroussin YYParseState *save = yyps;
17320c8de5b0SBaptiste Daroussin yyps = save->save;
17330c8de5b0SBaptiste Daroussin save->save = NULL;
17340c8de5b0SBaptiste Daroussin yyFreeState(save);
17350c8de5b0SBaptiste Daroussin }
17360c8de5b0SBaptiste Daroussin while (yypath)
17370c8de5b0SBaptiste Daroussin {
17380c8de5b0SBaptiste Daroussin YYParseState *save = yypath;
17390c8de5b0SBaptiste Daroussin yypath = save->save;
17400c8de5b0SBaptiste Daroussin save->save = NULL;
17410c8de5b0SBaptiste Daroussin yyFreeState(save);
17420c8de5b0SBaptiste Daroussin }
17430c8de5b0SBaptiste Daroussin #endif /* YYBTYACC */
17440c8de5b0SBaptiste Daroussin yyfreestack(&yystack);
17450c8de5b0SBaptiste Daroussin return (yyresult);
17460c8de5b0SBaptiste Daroussin }
1747