⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gram.tab.cpp

📁 一个俄国人写的内存数据库系统
💻 CPP
📖 第 1 页 / 共 2 页
字号:
/*  A Bison parser, made from gram.y with Bison version GNU Bison version 1.24  */#define YYBISON 1  /* Identify Bison output.  */#define	ID	258#define	INTCONST	259#define	DBLCONST	260#define	CREATE	261#define	INSERT	262#define	DROP	263#define	OPEN	264#define	CLOSE	265#define	QUIT	266#define	SELECT	267#define	DELETE	268#define	WHERE	269#define	FROM	270#define	NL	271#define	ERROR	272#define	AND	273#define	OR	274#define	DEBUG	275#define	HELP	276#define	DUMP	277#define	opLE	278#define	opGE	279#define	opNE	280#define	NOT	281#line 1 "gram.y"#include <iostream.h>#ifndef UNIX#include <malloc.h>#endif#include "RT.h"#include "command.h"#define YYDEBUG 1void CommandPrompt();int yyerror(char *msg);int yylex();#line 15 "gram.y"typedef union {    RTkey *key;    char *string;    RToper oper;    GiSTpredicate *pred;    int number;    double dbl;} YYSTYPE;#ifndef YYLTYPEtypedef  struct yyltype    {      int timestamp;      int first_line;      int first_column;      int last_line;      int last_column;      char *text;   }  yyltype;#define YYLTYPE yyltype#endif#include <stdio.h>#ifndef __cplusplus#ifndef __STDC__#define const#endif#endif#define	YYFINAL		79#define	YYFLAG		-32768#define	YYNTBASE	34#define YYTRANSLATE(x) ((unsigned)(x) <= 281 ? yytranslate[x] : 42)static const char yytranslate[] = {     0,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,    33,     2,    23,    24,     2,     2,    25,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,    28,    27,    26,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,     1,     2,     3,     4,     5,     6,     7,     8,     9,    10,    11,    12,    13,    14,    15,    16,    17,    18,    19,    20,    21,    22,    29,    30,    31,    32};#if YYDEBUG != 0static const short yyprhs[] = {     0,     0,     1,     4,     9,    14,    18,    22,    28,    37,    43,    46,    49,    52,    57,    60,    62,    63,    65,    66,    69,    79,    81,    83,    87,    91,    95,    98,   102,   104,   106,   108};static const short yyrhs[] = {    -1,    34,    35,     0,     6,     3,     3,    16,     0,     9,     3,     3,    16,     0,     8,     3,    16,     0,    10,     3,    16,     0,    12,    15,     3,    37,    16,     0,     7,     3,    23,    38,    25,     4,    24,    16,     0,    13,    15,     3,    37,    16,     0,    11,    16,     0,    20,    16,     0,    21,    16,     0,    22,     3,    36,    16,     0,     1,    16,     0,    16,     0,     0,     4,     0,     0,    14,    40,     0,    23,    39,    25,    39,    25,    39,    25,    39,    24,     0,     4,     0,     5,     0,     3,    41,    38,     0,    40,    19,    40,     0,    40,    18,    40,     0,    32,    40,     0,    23,    40,    24,     0,    33,     0,    28,     0,    26,     0,    27,     0};#endif#if YYDEBUG != 0static const short yyrline[] = { 0,    47,    48,    53,    57,    61,    64,    67,    71,    75,    79,    81,    83,    85,    88,    90,    94,    96,   101,   103,   108,   113,   114,   118,   120,   122,   124,   126,   131,   132,   133,   134};static const char * const yytname[] = {   "$","error","$undefined.","ID","INTCONST","DBLCONST","CREATE","INSERT","DROP","OPEN","CLOSE","QUIT","SELECT","DELETE","WHERE","FROM","NL","ERROR","AND","OR","DEBUG","HELP","DUMP","'('","')'","','","'>'","'='","'<'","opLE","opGE","opNE","NOT","'&'","commands","command","dump_page","where_clause","key","dub","predicate","operator",""};#endifstatic const short yyr1[] = {     0,    34,    34,    35,    35,    35,    35,    35,    35,    35,    35,    35,    35,    35,    35,    35,    36,    36,    37,    37,    38,    39,    39,    40,    40,    40,    40,    40,    41,    41,    41,    41};static const short yyr2[] = {     0,     0,     2,     4,     4,     3,     3,     5,     8,     5,     2,     2,     2,     4,     2,     1,     0,     1,     0,     2,     9,     1,     1,     3,     3,     3,     2,     3,     1,     1,     1,     1};static const short yydefact[] = {     1,     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,    15,     0,     0,     0,     2,    14,     0,     0,     0,     0,     0,    10,     0,     0,    11,    12,    16,     0,     0,     5,     0,     6,    18,    18,    17,     0,     3,     0,     0,     4,     0,     0,     0,    13,    21,    22,     0,     0,     0,     0,     0,    19,     7,     9,     0,     0,    30,    31,    29,    28,     0,     0,    26,     0,     0,     0,     0,    23,    27,    25,    24,     0,     8,     0,     0,     0,    20,     0,     0};static const short yydefgoto[] = {     1,    15,    36,    42,    39,    47,    52,    61};static const short yypact[] = {-32768,     1,   -13,     3,    13,    27,    31,    37,    25,    28,    29,-32768,    26,    30,    42,-32768,-32768,    44,    33,    34,    45,    35,-32768,    46,    49,-32768,-32768,    50,    39,    36,-32768,    41,-32768,    47,    47,-32768,    48,-32768,    32,    38,-32768,    -3,    51,    52,-32768,-32768,-32768,    40,    54,    -2,    -3,    -3,    20,-32768,-32768,    32,    53,-32768,-32768,-32768,-32768,    36,     9,-32768,    -3,    -3,    55,    56,-32768,-32768,-32768,    57,    32,-32768,    58,    32,    60,-32768,    62,-32768};static const short yypgoto[] = {-32768,-32768,-32768,    19,    -1,   -40,   -46,-32768};#define	YYLAST		84static const short yytable[] = {    49,    78,     2,    16,    62,    63,    17,     3,     4,     5,     6,     7,     8,     9,    10,    66,    18,    11,    70,    71,    50,    12,    13,    14,    57,    58,    59,    64,    65,    51,    19,    60,    74,    69,    20,    76,    45,    46,    64,    65,    21,    22,    25,    23,    24,    27,    26,    28,    31,    33,    30,    32,    34,    43,    35,    37,    29,    40,    56,    38,    68,    41,    79,    48,    44,    55,     0,    53,    54,     0,     0,     0,    73,     0,     0,    64,     0,    67,     0,     0,    72,     0,     0,    75,    77};static const short yycheck[] = {     3,     0,     1,    16,    50,    51,     3,     6,     7,     8,     9,    10,    11,    12,    13,    55,     3,    16,    64,    65,    23,    20,    21,    22,    26,    27,    28,    18,    19,    32,     3,    33,    72,    24,     3,    75,     4,     5,    18,    19,     3,    16,    16,    15,    15,     3,    16,     3,     3,     3,    16,    16,     3,    34,     4,    16,    23,    16,     4,    23,    61,    14,     0,    25,    16,    25,    -1,    16,    16,    -1,    -1,    -1,    16,    -1,    -1,    18,    -1,    24,    -1,    -1,    25,    -1,    -1,    25,    24};/* -*-C-*-  Note some compilers choke on comments on `#line' lines.  */#line 3 "bison.simple"/* Skeleton output parser for bison,   Copyright (C) 1984, 1989, 1990 Free Software Foundation, Inc.   This program is free software; you can redistribute it and/or modify   it under the terms of the GNU General Public License as published by   the Free Software Foundation; either version 2, or (at your option)   any later version.   This program is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the   GNU General Public License for more details.   You should have received a copy of the GNU General Public License   along with this program; if not, write to the Free Software   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  *//* As a special exception, when this file is copied by Bison into a   Bison output file, you may use that output file without restriction.   This special exception was added by the Free Software Foundation   in version 1.24 of Bison.  */#ifdef __GNUC__#define alloca __builtin_alloca#else /* not __GNUC__ */#if HAVE_ALLOCA_H#include <alloca.h>#else /* not HAVE_ALLOCA_H */#ifdef _AIX #pragma alloca#else /* not _AIX */char *alloca ();#endif /* not _AIX */#endif /* not HAVE_ALLOCA_H */#endif /* not __GNUC__ */extern int yylex();extern void yyerror();#ifndef alloca#ifdef __GNUC__#define alloca __builtin_alloca#else /* not GNU C.  */#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi)#include <alloca.h>#else /* not sparc */#if defined (MSDOS) && !defined (__TURBOC__)#include <malloc.h>#else /* not MSDOS, or __TURBOC__ */#if defined(_AIX)#include <malloc.h> #pragma alloca#else /* not MSDOS, __TURBOC__, or _AIX */#ifdef __hpux#ifdef __cplusplusextern "C" {void *alloca (unsigned int);};#else /* not __cplusplus */void *alloca ();#endif /* not __cplusplus */#endif /* __hpux */#endif /* not _AIX */#endif /* not MSDOS, or __TURBOC__ */#endif /* not sparc.  */#endif /* not GNU C.  */#endif /* alloca not defined.  *//* This is the parser code that is written into each bison parser  when the %semantic_parser declaration is not specified in the grammar.  It was written by Richard Stallman by simplifying the hairy parser  used when %semantic_parser is specified.  *//* Note: there must be only one dollar sign in this file.   It is replaced by the list of actions, each action   as one case of the switch.  */#define yyerrok		(yyerrstatus = 0)#define yyclearin	(yychar = YYEMPTY)#define YYEMPTY		-2#define YYEOF		0#define YYACCEPT	return(0)#define YYABORT 	return(1)#define YYERROR		goto yyerrlab1/* Like YYERROR except do call yyerror.   This remains here temporarily to ease the   transition to the new meaning of YYERROR, for GCC.   Once GCC version 2 has supplanted version 1, this can go.  */#define YYFAIL		goto yyerrlab#define YYRECOVERING()  (!!yyerrstatus)#define YYBACKUP(token, value) \do								\  if (yychar == YYEMPTY && yylen == 1)				\    { yychar = (token), yylval = (value);			\      yychar1 = YYTRANSLATE (yychar);				\      YYPOPSTACK;						\      goto yybackup;						\    }								\  else								\    { yyerror ("syntax error: cannot back up"); YYERROR; }	\while (0)#define YYTERROR	1#define YYERRCODE	256#ifndef YYPURE#define YYLEX		yylex()#endif#ifdef YYPURE#ifdef YYLSP_NEEDED#ifdef YYLEX_PARAM#define YYLEX		yylex(&yylval, &yylloc, YYLEX_PARAM)#else#define YYLEX		yylex(&yylval, &yylloc)#endif#else /* not YYLSP_NEEDED */#ifdef YYLEX_PARAM#define YYLEX		yylex(&yylval, YYLEX_PARAM)#else#define YYLEX		yylex(&yylval)#endif#endif /* not YYLSP_NEEDED */#endif/* If nonreentrant, generate the variables here */#ifndef YYPUREint	yychar;			/*  the lookahead symbol		*/YYSTYPE	yylval;			/*  the semantic value of the		*/				/*  lookahead symbol			*/#ifdef YYLSP_NEEDEDYYLTYPE yylloc;			/*  location data for the lookahead	*/				/*  symbol				*/#endifint yynerrs;			/*  number of parse errors so far       */#endif  /* not YYPURE */#if YYDEBUG != 0int yydebug;			/*  nonzero means print parse trace	*//* Since this is uninitialized, it does not stop multiple parsers   from coexisting.  */#endif/*  YYINITDEPTH indicates the initial size of the parser's stacks	*/#ifndef	YYINITDEPTH#define YYINITDEPTH 200#endif/*  YYMAXDEPTH is the maximum size the stacks can grow to    (effective only if the built-in stack extension method is used).  */#if YYMAXDEPTH == 0#undef YYMAXDEPTH#endif#ifndef YYMAXDEPTH#define YYMAXDEPTH 10000#endif/* Prevent warning if -Wstrict-prototypes.  */#ifdef __GNUC__int yyparse (void);#endif#if __GNUC__ > 1		/* GNU C and GNU C++ define this.  */#define __yy_memcpy(FROM,TO,COUNT)	__builtin_memcpy(TO,FROM,COUNT)#else				/* not GNU C or C++ */#ifndef __cplusplus/* This is the most reliable way to avoid incompatibilities   in available built-in functions on various systems.  */static void__yy_memcpy (from, to, count)     char *from;     char *to;     int count;{  register char *f = from;  register char *t = to;  register int i = count;  while (i-- > 0)    *t++ = *f++;}#else /* __cplusplus *//* This is the most reliable way to avoid incompatibilities   in available built-in functions on various systems.  */static void__yy_memcpy (char *from, char *to, int count){  register char *f = from;  register char *t = to;  register int i = count;  while (i-- > 0)    *t++ = *f++;}#endif#endif#line 192 "bison.simple"/* The user can define YYPARSE_PARAM as the name of an argument to be passed   into yyparse.  The argument should have type void *.   It should actually point to an object.   Grammar actions can access the variable by casting it   to the proper pointer type.  */#ifdef YYPARSE_PARAM#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;#else#define YYPARSE_PARAM#define YYPARSE_PARAM_DECL#endifintyyparse(YYPARSE_PARAM)     YYPARSE_PARAM_DECL{  register int yystate;  register int yyn;  register short *yyssp;  register YYSTYPE *yyvsp;  int yyerrstatus;	/*  number of tokens to shift before error messages enabled */  int yychar1 = 0;		/*  lookahead token as an internal (translated) token number */  short	yyssa[YYINITDEPTH];	/*  the state stack			*/  YYSTYPE yyvsa[YYINITDEPTH];	/*  the semantic value stack		*/  short *yyss = yyssa;		/*  refer to the stacks thru separate pointers */  YYSTYPE *yyvs = yyvsa;	/*  to allow yyoverflow to reallocate them elsewhere */#ifdef YYLSP_NEEDED  YYLTYPE yylsa[YYINITDEPTH];	/*  the location stack			*/  YYLTYPE *yyls = yylsa;  YYLTYPE *yylsp;#define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--)#else#define YYPOPSTACK   (yyvsp--, yyssp--)#endif  int yystacksize = YYINITDEPTH;#ifdef YYPURE  int yychar;  YYSTYPE yylval;  int yynerrs;#ifdef YYLSP_NEEDED  YYLTYPE yylloc;#endif#endif  YYSTYPE yyval;		/*  the variable used to return		*/				/*  semantic values from the action	*/				/*  routines				*/  int yylen;#if YYDEBUG != 0  if (yydebug)    fprintf(stderr, "Starting parse\n");#endif  yystate = 0;  yyerrstatus = 0;  yynerrs = 0;  yychar = YYEMPTY;		/* Cause a token to be read.  */  /* Initialize stack pointers.     Waste one element of value and location stack     so that they stay on the same level as the state stack.     The wasted elements are never initialized.  */  yyssp = yyss - 1;  yyvsp = yyvs;#ifdef YYLSP_NEEDED  yylsp = yyls;#endif/* Push a new state, which is found in  yystate  .  *//* In all cases, when you get here, the value and location stacks   have just been pushed. so pushing a state here evens the stacks.  */yynewstate:  *++yyssp = yystate;  if (yyssp >= yyss + yystacksize - 1)    {      /* Give user a chance to reallocate the stack */      /* Use copies of these so that the &'s don't force the real ones into memory. */      YYSTYPE *yyvs1 = yyvs;      short *yyss1 = yyss;#ifdef YYLSP_NEEDED      YYLTYPE *yyls1 = yyls;#endif      /* Get the current used size of the three stacks, in elements.  */      int size = yyssp - yyss + 1;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -