mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-22 23:23:02 +01:00
862 lines
27 KiB
C
862 lines
27 KiB
C
/*
|
|
** This file generated automatically from
|
|
*/
|
|
|
|
#include "defs.h"
|
|
/* The banner used here should be replaced with an #ident directive */
|
|
/* if the target C compiler supports #ident directives. */
|
|
/* */
|
|
/* If the skeleton is changed, the banner should be changed so that */
|
|
/* the altered version can easily be distinguished from the original. */
|
|
|
|
char *banner[] =
|
|
{
|
|
"#line 8 \"btyaccpa.ske\"",
|
|
"",
|
|
"//",
|
|
"// @(#)btyaccpar, based on byacc 1.8 (Berkeley)",
|
|
"//",
|
|
"#define YYBTYACC 1",
|
|
"",
|
|
"#include <stdio.h>",
|
|
"#include <stdlib.h>",
|
|
"#include <string.h>",
|
|
"",
|
|
"typedef int Yshort;",
|
|
"",
|
|
0
|
|
};
|
|
|
|
char *tables[] =
|
|
{
|
|
"#line 21 \"btyaccpa.ske\"",
|
|
"",
|
|
"#define _C_ \"C\"",
|
|
"",
|
|
"extern _C_ Yshort yylhs[];",
|
|
"extern _C_ Yshort yylen[];",
|
|
"extern _C_ Yshort yydefred[];",
|
|
"extern _C_ Yshort yydgoto[];",
|
|
"extern _C_ Yshort yysindex[];",
|
|
"extern _C_ Yshort yyrindex[];",
|
|
"extern _C_ Yshort yycindex[];",
|
|
"extern _C_ Yshort yygindex[];",
|
|
"extern _C_ Yshort yytable[];",
|
|
"extern _C_ Yshort yycheck[];",
|
|
"extern _C_ Yshort yyctable[];",
|
|
"",
|
|
"#if YYDEBUG",
|
|
"extern _C_ char *yyname[];",
|
|
"extern _C_ char *yyrule[];",
|
|
"#endif",
|
|
"",
|
|
0
|
|
};
|
|
|
|
char *header[] =
|
|
{
|
|
"#line 42 \"btyaccpa.ske\"",
|
|
"",
|
|
"//",
|
|
"// YYPOSN is user-defined text position type.",
|
|
"//",
|
|
"#ifndef YYPOSN",
|
|
"#define YYPOSN int",
|
|
"#endif",
|
|
"",
|
|
"#ifdef YYREDUCEPOSNFUNC",
|
|
"#define YYCALLREDUCEPOSN(e) \\",
|
|
"\tif(reduce_posn) { \\",
|
|
"\t YYREDUCEPOSNFUNC(yyps->pos, &(yyps->psp)[1-yym], &(yyps->vsp)[1-yym], \\",
|
|
"\t\t\t yym, yyps->psp - yyps->ps, yychar, yyposn, e); \\",
|
|
"\t reduce_posn = 0; \\",
|
|
"\t}",
|
|
"",
|
|
"#ifndef YYCALLREDUCEPOSNARG",
|
|
"#define YYCALLREDUCEPOSNARG yyps->val",
|
|
"#endif",
|
|
"",
|
|
"",
|
|
"#define YYPOSNARG(n) ((yyps->psp)[1-yym+(n)-1])",
|
|
"#define YYPOSNOUT (yyps->pos)",
|
|
"#endif",
|
|
"",
|
|
"// If delete function is not defined by the user, do not deletions.",
|
|
"#ifndef YYDELETEVAL",
|
|
"#define YYDELETEVAL(v) ",
|
|
"#endif",
|
|
"",
|
|
"// If delete function is not defined by the user, do not deletions.",
|
|
"#ifndef YYDELETEPOSN",
|
|
"#define YYDELETEPOSN(v) ",
|
|
"#endif",
|
|
"",
|
|
"#define yyclearin (yychar=(-1))",
|
|
"",
|
|
"#define yyerrok (yyps->errflag=0)",
|
|
"",
|
|
"#ifndef YYSTACKGROWTH",
|
|
"#define YYSTACKGROWTH 16",
|
|
"#endif",
|
|
"",
|
|
"#ifndef YYDEFSTACKSIZE",
|
|
"#define YYDEFSTACKSIZE 12",
|
|
"#endif",
|
|
"",
|
|
"#ifdef YYDEBUG",
|
|
"int yydebug;",
|
|
"#endif",
|
|
"",
|
|
"int yynerrs;",
|
|
"",
|
|
"/* These value/posn are taken from the lexer */",
|
|
"YYSTYPE yylval;",
|
|
"YYPOSN yyposn;",
|
|
"",
|
|
"/* These value/posn of the root non-terminal are returned to the caller */",
|
|
"YYSTYPE yyretlval;",
|
|
"YYPOSN yyretposn;",
|
|
"",
|
|
"#define YYABORT goto yyabort",
|
|
"#define YYACCEPT goto yyaccept",
|
|
"#define YYERROR goto yyerrlab",
|
|
"#define YYVALID do { if (yyps->save) goto yyvalid; } while(0)",
|
|
"#define YYVALID_NESTED do { if (yyps->save && \\",
|
|
" yyps->save->save==0) goto yyvalid; } while(0)",
|
|
"",
|
|
"struct yyparsestate {",
|
|
" yyparsestate *save; // Previously saved parser state",
|
|
" int state;",
|
|
" int errflag;",
|
|
" Yshort *ssp; // state stack pointer",
|
|
" YYSTYPE *vsp; // value stack pointer",
|
|
" YYPOSN *psp; // position stack pointer",
|
|
" YYSTYPE val; // value as returned by actions",
|
|
" YYPOSN pos; // position as returned by universal action",
|
|
" Yshort *ss; // state stack base",
|
|
" YYSTYPE *vs; // values stack base",
|
|
" YYPOSN *ps; // position stack base",
|
|
" int lexeme; // index of the conflict lexeme in the lexical queue",
|
|
" unsigned int stacksize; // current maximum stack size",
|
|
" Yshort ctry; // index in yyctable[] for this conflict",
|
|
"};",
|
|
"",
|
|
"// Current parser state",
|
|
"static yyparsestate *yyps=0;",
|
|
"",
|
|
"// yypath!=NULL: do the full parse, starting at *yypath parser state.",
|
|
"static yyparsestate *yypath=0;",
|
|
"",
|
|
"// Base of the lexical value queue",
|
|
"static YYSTYPE *yylvals=0;",
|
|
"",
|
|
"// Current posistion at lexical value queue",
|
|
"static YYSTYPE *yylvp=0;",
|
|
"",
|
|
"// End position of lexical value queue",
|
|
"static YYSTYPE *yylve=0;",
|
|
"",
|
|
"// The last allocated position at the lexical value queue",
|
|
"static YYSTYPE *yylvlim=0;",
|
|
"",
|
|
"// Base of the lexical position queue",
|
|
"static YYPOSN *yylpsns=0;",
|
|
"",
|
|
"// Current posistion at lexical position queue",
|
|
"static YYPOSN *yylpp=0;",
|
|
"",
|
|
"// End position of lexical position queue",
|
|
"static YYPOSN *yylpe=0;",
|
|
"",
|
|
"// The last allocated position at the lexical position queue",
|
|
"static YYPOSN *yylplim=0;",
|
|
"",
|
|
"// Current position at lexical token queue",
|
|
"static Yshort *yylexp=0;",
|
|
"",
|
|
"static Yshort *yylexemes=0;",
|
|
"",
|
|
"//",
|
|
"// For use in generated program",
|
|
"//",
|
|
"#define yytrial (yyps->save)",
|
|
"#define yyvsp (yyps->vsp)",
|
|
"#define yyval (yyps->val)",
|
|
"#define yydepth (yyps->ssp - yyps->ss)",
|
|
"",
|
|
"",
|
|
"//",
|
|
"// Local prototypes.",
|
|
"//",
|
|
"int yyparse(void);",
|
|
"",
|
|
"int YYLex1();",
|
|
"int yyexpand();",
|
|
"void YYSCopy(YYSTYPE *to, YYSTYPE *from, int size);",
|
|
"void YYPCopy(YYPOSN *to, YYPOSN *from, int size);",
|
|
"void YYMoreStack(yyparsestate *yyps);",
|
|
"yyparsestate *YYNewState(int size);",
|
|
"void YYFreeState(yyparsestate *p);",
|
|
"",
|
|
"",
|
|
0
|
|
};
|
|
|
|
char *body[] =
|
|
{
|
|
"#line 186 \"btyaccpa.ske\"",
|
|
"",
|
|
"",
|
|
"//",
|
|
"// Parser function",
|
|
"//",
|
|
"int yyparse() {",
|
|
" int yym, yyn, yystate, yychar, yynewerrflag;",
|
|
" yyparsestate *yyerrctx = NULL;",
|
|
" int reduce_posn;",
|
|
"",
|
|
"#if YYDEBUG",
|
|
" char *yys;",
|
|
" ",
|
|
" if ((yys = getenv(\"YYDEBUG\"))) {",
|
|
" yyn = *yys;",
|
|
" if (yyn >= '0' && yyn <= '9')",
|
|
" yydebug = yyn - '0'; ",
|
|
" }",
|
|
"#endif",
|
|
" ",
|
|
" yyps = YYNewState(YYDEFSTACKSIZE);",
|
|
" yyps->save = 0;",
|
|
" yynerrs = 0;",
|
|
" yyps->errflag = 0;",
|
|
" yychar = (-1);",
|
|
" ",
|
|
" yyps->ssp = yyps->ss;",
|
|
" yyps->vsp = yyps->vs;",
|
|
" yyps->psp = yyps->ps;",
|
|
" *(yyps->ssp) = yystate = 0;",
|
|
" ",
|
|
"",
|
|
" //",
|
|
" // Main parsing loop",
|
|
" //",
|
|
" yyloop:",
|
|
" if ((yyn = yydefred[yystate])) {",
|
|
" goto yyreduce;",
|
|
" }",
|
|
"",
|
|
" //",
|
|
" // Read one token",
|
|
" //",
|
|
" if (yychar < 0) {",
|
|
" if ((yychar = YYLex1()) < 0) yychar = 0;",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" yys = 0;",
|
|
" if (yychar <= YYMAXTOKEN) yys = yyname[yychar];",
|
|
" if (!yys) yys = \"illegal-symbol\";",
|
|
" printf(\"yydebug[%d,%d]: state %d, reading %d (%s)\", ",
|
|
"\t yydepth, (int)yytrial, yystate, yychar, yys);",
|
|
"#ifdef YYDBPR",
|
|
" printf(\"<\");",
|
|
" YYDBPR(yylval);",
|
|
" printf(\">\");",
|
|
"#endif",
|
|
" printf(\"\\n\"); ",
|
|
" }",
|
|
"#endif",
|
|
" }",
|
|
"",
|
|
" //",
|
|
" // Do we have a conflict?",
|
|
" //",
|
|
" if ((yyn = yycindex[yystate]) &&",
|
|
" (yyn += yychar) >= 0 &&",
|
|
" yyn <= YYTABLESIZE &&",
|
|
" yycheck[yyn] == yychar) {",
|
|
" int ctry;",
|
|
"",
|
|
" if (yypath) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d,%d]: CONFLICT in state %d: following successful trial parse\\n\", ",
|
|
"\t yydepth, (int)yytrial, yystate);",
|
|
" }",
|
|
"#endif",
|
|
" // Switch to the next conflict context",
|
|
" yyparsestate *save = yypath;",
|
|
" yypath = save->save;",
|
|
" ctry = save->ctry;",
|
|
" if (save->state != yystate) ",
|
|
" goto yyabort;",
|
|
" YYFreeState(save); ",
|
|
"",
|
|
" } else {",
|
|
"",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d,%d]: CONFLICT in state %d. \", ",
|
|
"\t yydepth, (int)yytrial, yystate);",
|
|
" if(yyps->save) {",
|
|
" printf(\"ALREADY in conflict. Continue trial parse.\");",
|
|
" } else {",
|
|
" printf(\"Start trial parse.\");",
|
|
" }",
|
|
" printf(\"\\n\");",
|
|
" }",
|
|
"#endif",
|
|
" yyparsestate *save = YYNewState(yyps->ssp - yyps->ss);",
|
|
" save->save = yyps->save;",
|
|
" save->state = yystate;",
|
|
" save->errflag = yyps->errflag;",
|
|
" save->ssp = save->ss + (yyps->ssp - yyps->ss);",
|
|
" save->vsp = save->vs + (yyps->vsp - yyps->vs);",
|
|
" save->psp = save->ps + (yyps->psp - yyps->ps);",
|
|
" memcpy (save->ss, yyps->ss, (yyps->ssp - yyps->ss + 1)*sizeof(Yshort));",
|
|
" YYSCopy(save->vs, yyps->vs, (yyps->ssp - yyps->ss + 1));",
|
|
" YYPCopy(save->ps, yyps->ps, (yyps->ssp - yyps->ss + 1));",
|
|
" ctry = yytable[yyn];",
|
|
" if (yyctable[ctry] == -1) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug && yychar >= 0)",
|
|
" printf(\"yydebug[%d]: backtracking 1 token\\n\", ",
|
|
"\t\t (int)yytrial);",
|
|
"#endif",
|
|
" ctry++; ",
|
|
" }",
|
|
" save->ctry = ctry;",
|
|
" if (!yyps->save) {",
|
|
" // If this is a first conflict in the stack, start saving lexemes",
|
|
" if (!yylexemes) {",
|
|
" yylexemes = new Yshort[YYSTACKGROWTH];",
|
|
" yylvals = new YYSTYPE[YYSTACKGROWTH];",
|
|
" yylvlim = yylvals + YYSTACKGROWTH; ",
|
|
" yylpsns = new YYPOSN[YYSTACKGROWTH];",
|
|
" yylplim = yylpsns + YYSTACKGROWTH; ",
|
|
" }",
|
|
" if (yylvp == yylve) {",
|
|
" yylvp = yylve = yylvals;",
|
|
"\t yylpp = yylpe = yylpsns;",
|
|
" yylexp = yylexemes;",
|
|
" if (yychar >= 0) {",
|
|
" *yylve++ = yylval;",
|
|
" *yylpe++ = yyposn;",
|
|
" *yylexp = yychar;",
|
|
" yychar = -1; ",
|
|
" } ",
|
|
" } ",
|
|
" }",
|
|
" if (yychar >= 0) {",
|
|
" yylvp--, yylpp--, yylexp--;",
|
|
" yychar = -1; ",
|
|
" }",
|
|
" save->lexeme = yylvp - yylvals;",
|
|
" yyps->save = save; ",
|
|
" }",
|
|
" if (yytable[yyn] == ctry) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: state %d, shifting to state %d\\n\",",
|
|
" yydepth, (int)yytrial, yystate, yyctable[ctry]);",
|
|
"#endif",
|
|
" if (yychar < 0)",
|
|
" yylvp++, yylpp++, yylexp++;",
|
|
" yychar = -1;",
|
|
" if (yyps->errflag > 0) --yyps->errflag;",
|
|
" yystate = yyctable[ctry];",
|
|
" goto yyshift; ",
|
|
" } else {",
|
|
" yyn = yyctable[ctry];",
|
|
" goto yyreduce; ",
|
|
" } ",
|
|
" }",
|
|
"",
|
|
" //",
|
|
" // Is action a shift?",
|
|
" //",
|
|
" if ((yyn = yysindex[yystate]) &&",
|
|
" (yyn += yychar) >= 0 &&",
|
|
" yyn <= YYTABLESIZE &&",
|
|
" yycheck[yyn] == yychar) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: state %d, shifting to state %d\\n\",",
|
|
" yydepth, (int)yytrial, yystate, yytable[yyn]);",
|
|
"#endif",
|
|
" yychar = (-1);",
|
|
" if (yyps->errflag > 0) --yyps->errflag;",
|
|
" yystate = yytable[yyn];",
|
|
" yyshift:",
|
|
" if (yyps->ssp >= yyps->ss + yyps->stacksize - 1) {",
|
|
" YYMoreStack(yyps);",
|
|
" }",
|
|
" *++(yyps->ssp) = yystate;",
|
|
" *++(yyps->vsp) = yylval;",
|
|
" *++(yyps->psp) = yyposn;",
|
|
" goto yyloop;",
|
|
" }",
|
|
" if ((yyn = yyrindex[yystate]) &&",
|
|
" (yyn += yychar) >= 0 &&",
|
|
" yyn <= YYTABLESIZE &&",
|
|
" yycheck[yyn] == yychar) {",
|
|
" yyn = yytable[yyn];",
|
|
" goto yyreduce;",
|
|
" }",
|
|
"",
|
|
" //",
|
|
" // Action: error",
|
|
" //",
|
|
" if (yyps->errflag) goto yyinrecovery;",
|
|
" yynewerrflag = 1;",
|
|
" goto yyerrhandler;",
|
|
"yyerrlab:",
|
|
" yynewerrflag = 0;",
|
|
"yyerrhandler:",
|
|
" while (yyps->save) { ",
|
|
" int ctry; ",
|
|
" yyparsestate *save = yyps->save;",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: ERROR in state %d, CONFLICT BACKTRACKING to state %d, %d tokens\\n\",",
|
|
" yydepth, (int)yytrial, yystate, yyps->save->state, yylvp - yylvals - yyps->save->lexeme);",
|
|
"#endif",
|
|
" // Memorize most forward-looking error state in case",
|
|
" // it's really an error.",
|
|
" if(yyerrctx==NULL || yyerrctx->lexeme<yylvp-yylvals) {",
|
|
" // Free old saved error context state",
|
|
" if(yyerrctx) YYFreeState(yyerrctx);",
|
|
" // Create and fill out new saved error context state",
|
|
" yyerrctx = YYNewState(yyps->ssp - yyps->ss);",
|
|
" yyerrctx->save = yyps->save;",
|
|
" yyerrctx->state = yystate;",
|
|
" yyerrctx->errflag = yyps->errflag;",
|
|
" yyerrctx->ssp = yyerrctx->ss + (yyps->ssp - yyps->ss);",
|
|
" yyerrctx->vsp = yyerrctx->vs + (yyps->vsp - yyps->vs);",
|
|
" yyerrctx->psp = yyerrctx->ps + (yyps->psp - yyps->ps);",
|
|
" memcpy (yyerrctx->ss, yyps->ss, (yyps->ssp - yyps->ss + 1)*sizeof(Yshort));",
|
|
" YYSCopy(yyerrctx->vs, yyps->vs, (yyps->ssp - yyps->ss + 1));",
|
|
" YYPCopy(yyerrctx->ps, yyps->ps, (yyps->ssp - yyps->ss + 1));",
|
|
" yyerrctx->lexeme = yylvp - yylvals;",
|
|
" }",
|
|
" yylvp = yylvals + save->lexeme;",
|
|
" yylpp = yylpsns + save->lexeme;",
|
|
" yylexp = yylexemes + save->lexeme;",
|
|
" yychar = -1;",
|
|
" yyps->ssp = yyps->ss + (save->ssp - save->ss);",
|
|
" yyps->vsp = yyps->vs + (save->vsp - save->vs);",
|
|
" yyps->psp = yyps->ps + (save->psp - save->ps);",
|
|
" memcpy (yyps->ss, save->ss, (yyps->ssp - yyps->ss + 1) * sizeof(Yshort));",
|
|
" YYSCopy(yyps->vs, save->vs, yyps->vsp - yyps->vs + 1);",
|
|
" YYPCopy(yyps->ps, save->ps, yyps->psp - yyps->ps + 1);",
|
|
" ctry = ++save->ctry;",
|
|
" yystate = save->state;",
|
|
" // We tried shift, try reduce now",
|
|
" if ((yyn = yyctable[ctry]) >= 0) {",
|
|
" goto yyreduce;",
|
|
" }",
|
|
" yyps->save = save->save;",
|
|
" YYFreeState(save);",
|
|
" //",
|
|
" // Nothing left on the stack -- error",
|
|
" //",
|
|
" if (!yyps->save) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d]: trial parse FAILED, entering ERROR mode\\n\", ",
|
|
"\t (int)yytrial);",
|
|
" }",
|
|
"#endif",
|
|
" // Restore state as it was in the most forward-advanced error",
|
|
" yylvp = yylvals + yyerrctx->lexeme;",
|
|
" yylpp = yylpsns + yyerrctx->lexeme;",
|
|
" yylexp = yylexemes + yyerrctx->lexeme;",
|
|
" yychar = yylexp[-1];",
|
|
" yylval = yylvp[-1];",
|
|
" yyposn = yylpp[-1];",
|
|
" yyps->ssp = yyps->ss + (yyerrctx->ssp - yyerrctx->ss);",
|
|
" yyps->vsp = yyps->vs + (yyerrctx->vsp - yyerrctx->vs);",
|
|
" yyps->psp = yyps->ps + (yyerrctx->psp - yyerrctx->ps);",
|
|
" memcpy (yyps->ss, yyerrctx->ss, (yyps->ssp - yyps->ss + 1) * sizeof(Yshort));",
|
|
" YYSCopy(yyps->vs, yyerrctx->vs, yyps->vsp - yyps->vs + 1);",
|
|
" YYPCopy(yyps->ps, yyerrctx->ps, yyps->psp - yyps->ps + 1);",
|
|
" yystate = yyerrctx->state;",
|
|
" YYFreeState(yyerrctx);",
|
|
" yyerrctx = NULL;",
|
|
" }",
|
|
" yynewerrflag = 1; ",
|
|
" }",
|
|
" if (yynewerrflag) {",
|
|
"#ifdef YYERROR_DETAILED",
|
|
" yyerror_detailed(\"syntax error\", yychar, yylval, yyposn);",
|
|
"#else",
|
|
" yyerror(\"syntax error\");",
|
|
"#endif",
|
|
" }",
|
|
" ++yynerrs;",
|
|
" yyinrecovery:",
|
|
" if (yyps->errflag < 3) {",
|
|
" yyps->errflag = 3;",
|
|
" for (;;) {",
|
|
" if ((yyn = yysindex[*(yyps->ssp)]) && ",
|
|
"\t (yyn += YYERRCODE) >= 0 &&",
|
|
" yyn <= YYTABLESIZE && ",
|
|
"\t yycheck[yyn] == YYERRCODE) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: state %d, ERROR recovery shifts to state %d\\n\",",
|
|
" yydepth, (int)yytrial, *(yyps->ssp), yytable[yyn]);",
|
|
"#endif",
|
|
" /* Use label yyerrlab, so that compiler does not warn */",
|
|
" if(yyps->errflag != yyps->errflag) goto yyerrlab;",
|
|
" yystate = yytable[yyn];",
|
|
" goto yyshift; ",
|
|
" } else {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: ERROR recovery discards state %d\\n\",",
|
|
" yydepth, (int)yytrial, *(yyps->ssp));",
|
|
"#endif",
|
|
" if (yyps->ssp <= yyps->ss) {",
|
|
"\t goto yyabort;",
|
|
"\t}",
|
|
"\tif(!yytrial) {",
|
|
"\t YYDELETEVAL(yyps->vsp[0],1);",
|
|
"\t YYDELETEPOSN(yyps->psp[0],1);",
|
|
"\t}",
|
|
" --(yyps->ssp);",
|
|
" --(yyps->vsp);",
|
|
" --(yyps->psp);",
|
|
" }",
|
|
" }",
|
|
" } else {",
|
|
" if (yychar == 0) goto yyabort;",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" yys = 0;",
|
|
" if (yychar <= YYMAXTOKEN) yys = yyname[yychar];",
|
|
" if (!yys) yys = \"illegal-symbol\";",
|
|
" printf(\"yydebug[%d,%d]: state %d, ERROR recovery discards token %d (%s)\\n\",",
|
|
" yydepth, (int)yytrial, yystate, yychar, yys); ",
|
|
" }",
|
|
"#endif",
|
|
" if(!yytrial) {",
|
|
" YYDELETEVAL(yylval,0);",
|
|
" YYDELETEPOSN(yyposn,0);",
|
|
" }",
|
|
" yychar = (-1);",
|
|
" goto yyloop;",
|
|
" }",
|
|
"",
|
|
" //",
|
|
" // Reduce the rule",
|
|
" //",
|
|
"yyreduce:",
|
|
" yym = yylen[yyn];",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d,%d]: state %d, reducing by rule %d (%s)\",",
|
|
" yydepth, (int)yytrial, yystate, yyn, yyrule[yyn]);",
|
|
"#ifdef YYDBPR",
|
|
" if (yym) {",
|
|
" int i;",
|
|
" printf(\"<\");",
|
|
" for (i=yym; i>0; i--) {",
|
|
" if (i!=yym) printf(\", \");",
|
|
" YYDBPR((yyps->vsp)[1-i]);",
|
|
" }",
|
|
" printf(\">\");",
|
|
" }",
|
|
"#endif",
|
|
" printf(\"\\n\");",
|
|
" }",
|
|
"#endif",
|
|
" if (yyps->ssp + 1 - yym >= yyps->ss + yyps->stacksize) {",
|
|
" YYMoreStack(yyps);",
|
|
" }",
|
|
"",
|
|
" /* \"$$ = NULL\" default action */",
|
|
" memset(&yyps->val, 0, sizeof(yyps->val));",
|
|
"",
|
|
" /* default reduced position is NULL -- no position at all.",
|
|
" no position will be assigned at trial time and if no position handling is present */",
|
|
" memset(&yyps->pos, 0, sizeof(yyps->pos));",
|
|
"",
|
|
" reduce_posn = TRUE;",
|
|
"",
|
|
" switch (yyn) {",
|
|
"",
|
|
0
|
|
};
|
|
|
|
char *trailer[] =
|
|
{
|
|
"#line 567 \"btyaccpa.ske\"",
|
|
"",
|
|
" default:",
|
|
" break;",
|
|
" }",
|
|
"",
|
|
"#if YYDEBUG && defined(YYDBPR)",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d]: after reduction, result is \", yytrial);",
|
|
" YYDBPR(yyps->val);",
|
|
" printf(\"\\n\");",
|
|
" }",
|
|
"#endif",
|
|
"",
|
|
" // Perform user-defined position reduction",
|
|
"#ifdef YYREDUCEPOSNFUNC",
|
|
" if(!yytrial) {",
|
|
" YYCALLREDUCEPOSN(YYREDUCEPOSNFUNCARG);",
|
|
" }",
|
|
"#endif",
|
|
"",
|
|
" yyps->ssp -= yym;",
|
|
" yystate = *(yyps->ssp);",
|
|
" yyps->vsp -= yym;",
|
|
" yyps->psp -= yym;",
|
|
"",
|
|
" yym = yylhs[yyn];",
|
|
" if (yystate == 0 && yym == 0) {",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" printf(\"yydebug[%d,%d]: after reduction, shifting from state 0 to state %d\\n\", ",
|
|
"\t yydepth, (int)yytrial, YYFINAL);",
|
|
" }",
|
|
"#endif",
|
|
" yystate = YYFINAL;",
|
|
" *++(yyps->ssp) = YYFINAL;",
|
|
" *++(yyps->vsp) = yyps->val;",
|
|
" yyretlval = yyps->val;\t// return value of root non-terminal to yylval",
|
|
" *++(yyps->psp) = yyps->pos;",
|
|
" yyretposn = yyps->pos;\t// return value of root position to yyposn",
|
|
" if (yychar < 0) {",
|
|
" if ((yychar = YYLex1()) < 0) {",
|
|
" yychar = 0;",
|
|
" }",
|
|
"#if YYDEBUG",
|
|
" if (yydebug) {",
|
|
" yys = 0;",
|
|
" if (yychar <= YYMAXTOKEN) yys = yyname[yychar];",
|
|
" if (!yys) yys = \"illegal-symbol\";",
|
|
" printf(\"yydebug[%d,%d]: state %d, reading %d (%s)\\n\", ",
|
|
"\t yydepth, (int)yytrial, YYFINAL, yychar, yys); ",
|
|
" }",
|
|
"#endif",
|
|
" }",
|
|
" if (yychar == 0) goto yyaccept;",
|
|
" goto yyloop;",
|
|
" }",
|
|
"",
|
|
" if ((yyn = yygindex[yym]) && (yyn += yystate) >= 0 &&",
|
|
" yyn <= YYTABLESIZE && yycheck[yyn] == yystate) {",
|
|
" yystate = yytable[yyn];",
|
|
" } else {",
|
|
" yystate = yydgoto[yym];",
|
|
" }",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: after reduction, shifting from state %d to state %d\\n\",",
|
|
" yydepth, (int)yytrial, *(yyps->ssp), yystate);",
|
|
"#endif",
|
|
" if (yyps->ssp >= yyps->ss + yyps->stacksize - 1) {",
|
|
" YYMoreStack(yyps);",
|
|
" }",
|
|
" *++(yyps->ssp) = yystate;",
|
|
" *++(yyps->vsp) = yyps->val;",
|
|
" *++(yyps->psp) = yyps->pos;",
|
|
" goto yyloop;",
|
|
"",
|
|
"",
|
|
" //",
|
|
" // Reduction declares that this path is valid.",
|
|
" // Set yypath and do a full parse",
|
|
" //",
|
|
"yyvalid:",
|
|
" if (yypath) {",
|
|
" goto yyabort;",
|
|
" }",
|
|
" while (yyps->save) {",
|
|
" yyparsestate *save = yyps->save;",
|
|
" yyps->save = save->save;",
|
|
" save->save = yypath;",
|
|
" yypath = save;",
|
|
" }",
|
|
"#if YYDEBUG",
|
|
" if (yydebug)",
|
|
" printf(\"yydebug[%d,%d]: CONFLICT trial successful, backtracking to state %d, %d tokens\\n\",",
|
|
" yydepth, (int)yytrial, yypath->state, yylvp - yylvals - yypath->lexeme);",
|
|
"#endif",
|
|
" if(yyerrctx) {",
|
|
" YYFreeState(yyerrctx); yyerrctx = NULL;",
|
|
" }",
|
|
" yychar = -1;",
|
|
" yyps->ssp = yyps->ss + (yypath->ssp - yypath->ss);",
|
|
" yyps->vsp = yyps->vs + (yypath->vsp - yypath->vs);",
|
|
" yyps->psp = yyps->ps + (yypath->psp - yypath->ps);",
|
|
" memcpy (yyps->ss, yypath->ss, (yyps->ssp - yyps->ss + 1) * sizeof(Yshort));",
|
|
" YYSCopy(yyps->vs, yypath->vs, yyps->vsp - yyps->vs + 1);",
|
|
" YYPCopy(yyps->ps, yypath->ps, yyps->psp - yyps->ps + 1);",
|
|
" yylvp = yylvals + yypath->lexeme;",
|
|
" yylpp = yylpsns + yypath->lexeme;",
|
|
" yylexp = yylexemes + yypath->lexeme;",
|
|
" yystate = yypath->state;",
|
|
" goto yyloop;",
|
|
"",
|
|
"",
|
|
"yyabort:",
|
|
" if(yyerrctx) {",
|
|
" YYFreeState(yyerrctx); yyerrctx = NULL;",
|
|
" }",
|
|
"",
|
|
" YYSTYPE *pv;",
|
|
" for(pv=yyps->vs; pv<yyps->vsp; pv++) {",
|
|
" YYDELETEVAL(*pv,2);",
|
|
" }",
|
|
"",
|
|
" YYPOSN *pp;",
|
|
" for(pp=yyps->ps; pp<yyps->psp; pp++) {",
|
|
" YYDELETEPOSN(*pp,2);",
|
|
" }",
|
|
"",
|
|
" while (yyps) {",
|
|
" yyparsestate *save = yyps;",
|
|
" yyps = save->save;",
|
|
" YYFreeState(save);",
|
|
" }",
|
|
" while (yypath) {",
|
|
" yyparsestate *save = yypath;",
|
|
" yypath = save->save;",
|
|
" YYFreeState(save); ",
|
|
" }",
|
|
" return (1);",
|
|
"",
|
|
"",
|
|
"yyaccept:",
|
|
" if (yyps->save) goto yyvalid;",
|
|
" if(yyerrctx) {",
|
|
" YYFreeState(yyerrctx); yyerrctx = NULL;",
|
|
" }",
|
|
" while (yyps) {",
|
|
" yyparsestate *save = yyps;",
|
|
" yyps = save->save;",
|
|
" YYFreeState(save);",
|
|
" }",
|
|
" while (yypath) {",
|
|
" yyparsestate *save = yypath;",
|
|
" yypath = save->save;",
|
|
" YYFreeState(save); ",
|
|
" }",
|
|
" return (0);",
|
|
"}",
|
|
"",
|
|
"",
|
|
"int YYLex1() {",
|
|
" if(yylvp<yylve) {",
|
|
" yylval = *yylvp++;",
|
|
" yyposn = *yylpp++;",
|
|
" return *yylexp++;",
|
|
" } else {",
|
|
" if(yyps->save) {",
|
|
" if(yylvp==yylvlim) {",
|
|
"\tyyexpand();",
|
|
" }",
|
|
" *yylexp = yylex();",
|
|
" *yylvp++ = yylval;",
|
|
" yylve++;",
|
|
" *yylpp++ = yyposn;",
|
|
" yylpe++;",
|
|
" return *yylexp++;",
|
|
" } else {",
|
|
" return yylex();",
|
|
" }",
|
|
" }",
|
|
"}",
|
|
"",
|
|
"int yyexpand() {",
|
|
" int p = yylvp-yylvals;",
|
|
" int s = yylvlim-yylvals;",
|
|
" s += YYSTACKGROWTH;",
|
|
" { Yshort *tl = yylexemes; ",
|
|
" YYSTYPE *tv = yylvals;",
|
|
" YYPOSN *tp = yylpsns;",
|
|
" yylvals = new YYSTYPE[s];",
|
|
" yylpsns = new YYPOSN[s];",
|
|
" yylexemes = new Yshort[s];",
|
|
" memcpy(yylexemes, tl, (s-YYSTACKGROWTH)*sizeof(Yshort));",
|
|
" YYSCopy(yylvals, tv, s-YYSTACKGROWTH);",
|
|
" YYPCopy(yylpsns, tp, s-YYSTACKGROWTH);",
|
|
" delete[] tl;",
|
|
" delete[] tv;",
|
|
" delete[] tp;",
|
|
" }",
|
|
" yylvp = yylve = yylvals + p;",
|
|
" yylvlim = yylvals + s;",
|
|
" yylpp = yylpe = yylpsns + p;",
|
|
" yylplim = yylpsns + s;",
|
|
" yylexp = yylexemes + p;",
|
|
" return 0;",
|
|
"}",
|
|
"",
|
|
"void YYSCopy(YYSTYPE *to, YYSTYPE *from, int size) {",
|
|
" int i; ",
|
|
" for (i = size-1; i >= 0; i--) {",
|
|
" to[i] = from[i];",
|
|
" }",
|
|
"}",
|
|
"",
|
|
"void YYPCopy(YYPOSN *to, YYPOSN *from, int size) {",
|
|
" int i; ",
|
|
" for (i = size-1; i >= 0; i--) {",
|
|
" to[i] = from[i];",
|
|
" }",
|
|
"}",
|
|
"",
|
|
"void YYMoreStack(yyparsestate *yyps) {",
|
|
" int p = yyps->ssp - yyps->ss; ",
|
|
" Yshort *tss = yyps->ss;",
|
|
" YYSTYPE *tvs = yyps->vs;",
|
|
" YYPOSN *tps = yyps->ps;",
|
|
" yyps->ss = new Yshort [yyps->stacksize + YYSTACKGROWTH]; ",
|
|
" yyps->vs = new YYSTYPE[yyps->stacksize + YYSTACKGROWTH]; ",
|
|
" yyps->ps = new YYPOSN [yyps->stacksize + YYSTACKGROWTH]; ",
|
|
" memcpy(yyps->ss, tss, yyps->stacksize * sizeof(Yshort)); ",
|
|
" YYSCopy(yyps->vs, tvs, yyps->stacksize); ",
|
|
" YYPCopy(yyps->ps, tps, yyps->stacksize); ",
|
|
" yyps->stacksize += YYSTACKGROWTH; ",
|
|
" delete[] tss;",
|
|
" delete[] tvs;",
|
|
" delete[] tps;",
|
|
" yyps->ssp = yyps->ss + p; ",
|
|
" yyps->vsp = yyps->vs + p; ",
|
|
" yyps->psp = yyps->ps + p; ",
|
|
"}",
|
|
"",
|
|
"yyparsestate *YYNewState(int size) {",
|
|
" yyparsestate *p = new yyparsestate;",
|
|
" p->stacksize = size+4;",
|
|
" p->ss = new Yshort [size + 4];",
|
|
" p->vs = new YYSTYPE[size + 4];",
|
|
" p->ps = new YYPOSN [size + 4];",
|
|
" memset(&p->vs[0], 0, (size+4)*sizeof(YYSTYPE));",
|
|
" memset(&p->ps[0], 0, (size+4)*sizeof(YYPOSN));",
|
|
" return p;",
|
|
"}",
|
|
"",
|
|
"void YYFreeState(yyparsestate *p) {",
|
|
" delete[] p->ss;",
|
|
" delete[] p->vs;",
|
|
" delete[] p->ps;",
|
|
" delete p;",
|
|
"}",
|
|
0
|
|
};
|
|
|
|
struct section section_list[] = {
|
|
{ "banner", &banner[0] },
|
|
{ "tables", &tables[0] },
|
|
{ "header", &header[0] },
|
|
{ "body", &body[0] },
|
|
{ "trailer", &trailer[0] },
|
|
{ 0, 0 } };
|