[test-suite] r257683 - Pre-generate Burg's YACC file.

Justin Lebar via llvm-commits llvm-commits at lists.llvm.org
Wed Jan 13 14:00:25 PST 2016


Author: jlebar
Date: Wed Jan 13 16:00:24 2016
New Revision: 257683

URL: http://llvm.org/viewvc/llvm-project?rev=257683&view=rev
Log:
Pre-generate Burg's YACC file.

Summary:
Without this patch, ninja test-suite dies with

  CMake Error at MultiSource/Applications/Burg/CMakeLists.txt:17 (add_yacc_parser):
    Unknown CMake command "add_yacc_parser".

Reviewers: rengolin, cmatthews, jmolloy, beanz

Subscribers: llvm-commits

Differential Revision: http://reviews.llvm.org/D16130

Added:
    test-suite/trunk/MultiSource/Applications/Burg/README-LLVM
    test-suite/trunk/MultiSource/Applications/Burg/y.tab.c
    test-suite/trunk/MultiSource/Applications/Burg/y.tab.h
Modified:
    test-suite/trunk/MultiSource/Applications/Burg/CMakeLists.txt
    test-suite/trunk/MultiSource/Applications/Burg/Makefile

Modified: test-suite/trunk/MultiSource/Applications/Burg/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Applications/Burg/CMakeLists.txt?rev=257683&r1=257682&r2=257683&view=diff
==============================================================================
--- test-suite/trunk/MultiSource/Applications/Burg/CMakeLists.txt (original)
+++ test-suite/trunk/MultiSource/Applications/Burg/CMakeLists.txt Wed Jan 13 16:00:24 2016
@@ -2,11 +2,9 @@ set(PROG burg)
 set(CPPFLAGS -DDEBUG)
 list(APPEND CFLAGS -std=gnu89)
 set(LDFLAGS -lstdc++)
-set(ExtraSource ${CMAKE_CURRENT_BINARY_DIR}/y.tab.c)
 set(STDIN_FILENAME ${CMAKE_CURRENT_SOURCE_DIR}/sample.gr)
 file(GLOB TMP1 ${CMAKE_CURRENT_SOURCE_DIR}/*.c)
 set(Source ${ExtraSource} ${TMP1})
 
 include_directories(${CMAKE_CURRENT_BINARY_DIR})
-add_yacc_parser(burg_parser gram.y ${CMAKE_CURRENT_BINARY_DIR}/y.tab.c ${CMAKE_CURRENT_BINARY_DIR}/y.tab.h)
-    llvm_multisource()
+llvm_multisource()

Modified: test-suite/trunk/MultiSource/Applications/Burg/Makefile
URL: http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Applications/Burg/Makefile?rev=257683&r1=257682&r2=257683&view=diff
==============================================================================
--- test-suite/trunk/MultiSource/Applications/Burg/Makefile (original)
+++ test-suite/trunk/MultiSource/Applications/Burg/Makefile Wed Jan 13 16:00:24 2016
@@ -5,8 +5,6 @@ CPPFLAGS = -DDEBUG
 CFLAGS  += -std=gnu89
 LDFLAGS  = -lstdc++
 
-ExtraSource := y.tab.c
-
 STDIN_FILENAME = $(PROJ_SRC_DIR)/sample.gr
 
 include $(LEVEL)/Makefile.config
@@ -15,18 +13,6 @@ Source  := $(ExtraSource) $(wildcard $(P
 
 include	$(LEVEL)/MultiSource/Makefile.multisrc
 
-#
-# JTC -
-#	This is stupid.  I bet we'll yacc twice because of this, but for now it
-#	seems to work.  Ideally, these yacc rules should be in a master rule
-#	file for the test suite, separate from the LLVM build rules.
-# 
-y.tab.h:: gram.y
-	$(YACC) -d $<
-
-y.tab.c: gram.y
-	$(YACC) -d $<
-
 lex.c: y.tab.h
 
 src:

Added: test-suite/trunk/MultiSource/Applications/Burg/README-LLVM
URL: http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Applications/Burg/README-LLVM?rev=257683&view=auto
==============================================================================
--- test-suite/trunk/MultiSource/Applications/Burg/README-LLVM (added)
+++ test-suite/trunk/MultiSource/Applications/Burg/README-LLVM Wed Jan 13 16:00:24 2016
@@ -0,0 +1 @@
+y.tab.c and y.tab.h were generated from gram.y using yacc 1.9 20140101.

Added: test-suite/trunk/MultiSource/Applications/Burg/y.tab.c
URL: http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Applications/Burg/y.tab.c?rev=257683&view=auto
==============================================================================
--- test-suite/trunk/MultiSource/Applications/Burg/y.tab.c (added)
+++ test-suite/trunk/MultiSource/Applications/Burg/y.tab.c Wed Jan 13 16:00:24 2016
@@ -0,0 +1,615 @@
+#ifndef lint
+static const char yysccsid[] = "@(#)yaccpar	1.9 (Berkeley) 02/21/93";
+#endif
+
+#define YYBYACC 1
+#define YYMAJOR 1
+#define YYMINOR 9
+#define YYPATCH 20140101
+
+#define YYEMPTY        (-1)
+#define yyclearin      (yychar = YYEMPTY)
+#define yyerrok        (yyerrflag = 0)
+#define YYRECOVERING() (yyerrflag != 0)
+
+#define YYPREFIX "yy"
+
+#define YYPURE 0
+
+#line 2 "gram.y"
+char rcsid_gram[] = "$Id$";
+
+#include <stdio.h>
+#include "b.h"
+#include "fe.h"
+#line 9 "gram.y"
+#ifdef YYSTYPE
+#undef  YYSTYPE_IS_DECLARED
+#define YYSTYPE_IS_DECLARED 1
+#endif
+#ifndef YYSTYPE_IS_DECLARED
+#define YYSTYPE_IS_DECLARED 1
+typedef union {
+	int y_int;
+	char *y_string;
+	Arity y_arity;
+	Binding y_binding;
+	PatternAST y_patternAST;
+	RuleAST y_ruleAST;
+	List y_list;
+	IntList y_intlist;
+} YYSTYPE;
+#endif /* !YYSTYPE_IS_DECLARED */
+#line 43 "y.tab.c"
+
+/* compatibility with bison */
+#ifdef YYPARSE_PARAM
+/* compatibility with FreeBSD */
+# ifdef YYPARSE_PARAM_TYPE
+#  define YYPARSE_DECL() yyparse(YYPARSE_PARAM_TYPE YYPARSE_PARAM)
+# else
+#  define YYPARSE_DECL() yyparse(void *YYPARSE_PARAM)
+# endif
+#else
+# define YYPARSE_DECL() yyparse(void)
+#endif
+
+/* Parameters sent to lex. */
+#ifdef YYLEX_PARAM
+# define YYLEX_DECL() yylex(void *YYLEX_PARAM)
+# define YYLEX yylex(YYLEX_PARAM)
+#else
+# define YYLEX_DECL() yylex(void)
+# define YYLEX yylex()
+#endif
+
+/* Parameters sent to yyerror. */
+#ifndef YYERROR_DECL
+#define YYERROR_DECL() yyerror(const char *s)
+#endif
+#ifndef YYERROR_CALL
+#define YYERROR_CALL(msg) yyerror(msg)
+#endif
+
+extern int YYPARSE_DECL();
+
+#define ERROR 257
+#define K_TERM 258
+#define K_GRAM 259
+#define K_START 260
+#define K_PPERCENT 261
+#define INT 262
+#define ID 263
+#define YYERRCODE 256
+static const short yylhs[] = {                           -1,
+    0,    0,   11,    7,    7,    1,    1,    1,   10,   10,
+    9,    9,    2,    8,    8,    5,    6,    6,    6,    3,
+    3,    4,    4,    4,
+};
+static const short yylen[] = {                            2,
+    1,    2,    3,    0,    2,    2,    2,    2,    0,    2,
+    0,    2,    3,    0,    2,    7,    1,    4,    6,    0,
+    4,    0,    3,    2,
+};
+static const short yydefred[] = {                         4,
+    0,    0,    0,   11,    9,    0,   14,    5,    2,    0,
+    0,    8,    0,    0,   12,   10,    0,   15,    0,    0,
+   13,    0,    0,    0,    0,    0,    0,   18,    0,    0,
+    0,    0,    0,   16,   19,    0,    0,    0,   24,    0,
+   21,   23,
+};
+static const short yydgoto[] = {                          1,
+    8,   15,   31,   38,   18,   23,    2,   13,   10,   11,
+    3,
+};
+static const short yysindex[] = {                         0,
+    0, -247, -252,    0,    0, -244,    0,    0,    0, -242,
+ -236,    0, -234,  -41,    0,    0,  -28,    0, -231, -230,
+    0,  -12,  -29, -230, -228,  -37,   -5,    0, -230, -226,
+  -22,   -3,  -44,    0,    0,  -44, -223,   -1,    0,  -44,
+    0,    0,
+};
+static const short yyrindex[] = {                         0,
+    0,    0,   41,    0,    0,    0,    0,    0,    0, -243,
+ -235,    0,    1,    0,    0,    0,    0,    0,    0,    0,
+    0,  -39,    0,    0,    0,    0,  -17,    0,    0,    0,
+    0,    0,    2,    0,    0,    2,    0,    0,    0,    2,
+    0,    0,
+};
+static const short yygindex[] = {                         0,
+    0,    0,    0,  -30,    0,  -21,    0,    0,    0,    0,
+    0,
+};
+#define YYTABLESIZE 262
+static const short yytable[] = {                         37,
+    3,   17,   26,   28,   17,   39,   29,   32,    9,   42,
+    4,    5,    6,    7,    6,    6,    6,    6,   12,   19,
+   14,   17,    7,    7,    7,    7,   16,   24,   17,   20,
+   21,   25,   22,   27,   30,   33,   34,   35,   40,   41,
+    1,   20,   22,    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,    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,    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,    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,    0,    0,    0,    0,    0,    0,    0,
+    0,    0,    0,    0,    0,    0,    0,   36,    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,    0,    0,
+    0,    3,
+};
+static const short yycheck[] = {                         44,
+    0,   41,   24,   41,   44,   36,   44,   29,  261,   40,
+  258,  259,  260,  261,  258,  259,  260,  261,  263,   61,
+  263,   61,  258,  259,  260,  261,  263,   40,  263,   58,
+  262,   61,  263,  262,   40,  262,   59,   41,  262,   41,
+    0,   59,   41,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,  262,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,   -1,
+   -1,  261,
+};
+#define YYFINAL 1
+#ifndef YYDEBUG
+#define YYDEBUG 0
+#endif
+#define YYMAXTOKEN 263
+#define YYTRANSLATE(a) ((a) > YYMAXTOKEN ? (YYMAXTOKEN + 1) : (a))
+#if YYDEBUG
+static const char *yyname[] = {
+
+"end-of-file",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,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,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,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,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,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,0,0,0,0,0,0,0,0,0,0,"ERROR",
+"K_TERM","K_GRAM","K_START","K_PPERCENT","INT","ID","illegal-symbol",
+};
+static const char *yyrule[] = {
+"$accept : full",
+"full : spec",
+"full : spec K_PPERCENT",
+"spec : decls K_PPERCENT rules",
+"decls :",
+"decls : decls decl",
+"decl : K_TERM bindinglist",
+"decl : K_GRAM grammarlist",
+"decl : K_START ID",
+"grammarlist :",
+"grammarlist : grammarlist ID",
+"bindinglist :",
+"bindinglist : bindinglist binding",
+"binding : ID '=' INT",
+"rules :",
+"rules : rules rule",
+"rule : ID ':' pattern '=' INT cost ';'",
+"pattern : ID",
+"pattern : ID '(' pattern ')'",
+"pattern : ID '(' pattern ',' pattern ')'",
+"cost :",
+"cost : '(' INT costtail ')'",
+"costtail :",
+"costtail : ',' INT costtail",
+"costtail : INT costtail",
+
+};
+#endif
+
+int      yydebug;
+int      yynerrs;
+
+int      yyerrflag;
+int      yychar;
+YYSTYPE  yyval;
+YYSTYPE  yylval;
+
+/* define the initial stack-sizes */
+#ifdef YYSTACKSIZE
+#undef YYMAXDEPTH
+#define YYMAXDEPTH  YYSTACKSIZE
+#else
+#ifdef YYMAXDEPTH
+#define YYSTACKSIZE YYMAXDEPTH
+#else
+#define YYSTACKSIZE 10000
+#define YYMAXDEPTH  10000
+#endif
+#endif
+
+#define YYINITSTACKSIZE 200
+
+typedef struct {
+    unsigned stacksize;
+    short    *s_base;
+    short    *s_mark;
+    short    *s_last;
+    YYSTYPE  *l_base;
+    YYSTYPE  *l_mark;
+} YYSTACKDATA;
+/* variables for the parser stack */
+static YYSTACKDATA yystack;
+
+#if YYDEBUG
+#include <stdio.h>		/* needed for printf */
+#endif
+
+#include <stdlib.h>	/* needed for malloc, etc */
+#include <string.h>	/* needed for memset */
+
+/* allocate initial stack or double stack size, up to YYMAXDEPTH */
+static int yygrowstack(YYSTACKDATA *data)
+{
+    int i;
+    unsigned newsize;
+    short *newss;
+    YYSTYPE *newvs;
+
+    if ((newsize = data->stacksize) == 0)
+        newsize = YYINITSTACKSIZE;
+    else if (newsize >= YYMAXDEPTH)
+        return -1;
+    else if ((newsize *= 2) > YYMAXDEPTH)
+        newsize = YYMAXDEPTH;
+
+    i = (int) (data->s_mark - data->s_base);
+    newss = (short *)realloc(data->s_base, newsize * sizeof(*newss));
+    if (newss == 0)
+        return -1;
+
+    data->s_base = newss;
+    data->s_mark = newss + i;
+
+    newvs = (YYSTYPE *)realloc(data->l_base, newsize * sizeof(*newvs));
+    if (newvs == 0)
+        return -1;
+
+    data->l_base = newvs;
+    data->l_mark = newvs + i;
+
+    data->stacksize = newsize;
+    data->s_last = data->s_base + newsize - 1;
+    return 0;
+}
+
+#if YYPURE || defined(YY_NO_LEAKS)
+static void yyfreestack(YYSTACKDATA *data)
+{
+    free(data->s_base);
+    free(data->l_base);
+    memset(data, 0, sizeof(*data));
+}
+#else
+#define yyfreestack(data) /* nothing */
+#endif
+
+#define YYABORT  goto yyabort
+#define YYREJECT goto yyabort
+#define YYACCEPT goto yyaccept
+#define YYERROR  goto yyerrlab
+
+int
+YYPARSE_DECL()
+{
+    int yym, yyn, yystate;
+#if YYDEBUG
+    const char *yys;
+
+    if ((yys = getenv("YYDEBUG")) != 0)
+    {
+        yyn = *yys;
+        if (yyn >= '0' && yyn <= '9')
+            yydebug = yyn - '0';
+    }
+#endif
+
+    yynerrs = 0;
+    yyerrflag = 0;
+    yychar = YYEMPTY;
+    yystate = 0;
+
+#if YYPURE
+    memset(&yystack, 0, sizeof(yystack));
+#endif
+
+    if (yystack.s_base == NULL && yygrowstack(&yystack)) goto yyoverflow;
+    yystack.s_mark = yystack.s_base;
+    yystack.l_mark = yystack.l_base;
+    yystate = 0;
+    *yystack.s_mark = 0;
+
+yyloop:
+    if ((yyn = yydefred[yystate]) != 0) goto yyreduce;
+    if (yychar < 0)
+    {
+        if ((yychar = YYLEX) < 0) yychar = 0;
+#if YYDEBUG
+        if (yydebug)
+        {
+            yys = yyname[YYTRANSLATE(yychar)];
+            printf("%sdebug: state %d, reading %d (%s)\n",
+                    YYPREFIX, yystate, yychar, yys);
+        }
+#endif
+    }
+    if ((yyn = yysindex[yystate]) && (yyn += yychar) >= 0 &&
+            yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
+    {
+#if YYDEBUG
+        if (yydebug)
+            printf("%sdebug: state %d, shifting to state %d\n",
+                    YYPREFIX, yystate, yytable[yyn]);
+#endif
+        if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack))
+        {
+            goto yyoverflow;
+        }
+        yystate = yytable[yyn];
+        *++yystack.s_mark = yytable[yyn];
+        *++yystack.l_mark = yylval;
+        yychar = YYEMPTY;
+        if (yyerrflag > 0)  --yyerrflag;
+        goto yyloop;
+    }
+    if ((yyn = yyrindex[yystate]) && (yyn += yychar) >= 0 &&
+            yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
+    {
+        yyn = yytable[yyn];
+        goto yyreduce;
+    }
+    if (yyerrflag) goto yyinrecovery;
+
+    yyerror("syntax error");
+
+    goto yyerrlab;
+
+yyerrlab:
+    ++yynerrs;
+
+yyinrecovery:
+    if (yyerrflag < 3)
+    {
+        yyerrflag = 3;
+        for (;;)
+        {
+            if ((yyn = yysindex[*yystack.s_mark]) && (yyn += YYERRCODE) >= 0 &&
+                    yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE)
+            {
+#if YYDEBUG
+                if (yydebug)
+                    printf("%sdebug: state %d, error recovery shifting\
+ to state %d\n", YYPREFIX, *yystack.s_mark, yytable[yyn]);
+#endif
+                if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack))
+                {
+                    goto yyoverflow;
+                }
+                yystate = yytable[yyn];
+                *++yystack.s_mark = yytable[yyn];
+                *++yystack.l_mark = yylval;
+                goto yyloop;
+            }
+            else
+            {
+#if YYDEBUG
+                if (yydebug)
+                    printf("%sdebug: error recovery discarding state %d\n",
+                            YYPREFIX, *yystack.s_mark);
+#endif
+                if (yystack.s_mark <= yystack.s_base) goto yyabort;
+                --yystack.s_mark;
+                --yystack.l_mark;
+            }
+        }
+    }
+    else
+    {
+        if (yychar == 0) goto yyabort;
+#if YYDEBUG
+        if (yydebug)
+        {
+            yys = yyname[YYTRANSLATE(yychar)];
+            printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
+                    YYPREFIX, yystate, yychar, yys);
+        }
+#endif
+        yychar = YYEMPTY;
+        goto yyloop;
+    }
+
+yyreduce:
+#if YYDEBUG
+    if (yydebug)
+        printf("%sdebug: state %d, reducing by rule %d (%s)\n",
+                YYPREFIX, yystate, yyn, yyrule[yyn]);
+#endif
+    yym = yylen[yyn];
+    if (yym)
+        yyval = yystack.l_mark[1-yym];
+    else
+        memset(&yyval, 0, sizeof yyval);
+    switch (yyn)
+    {
+case 2:
+#line 44 "gram.y"
+	{ yyfinished(); }
+break;
+case 3:
+#line 48 "gram.y"
+	{ doSpec(yystack.l_mark[-2].y_list, yystack.l_mark[0].y_list); }
+break;
+case 4:
+#line 51 "gram.y"
+	{ yyval.y_list = 0; }
+break;
+case 5:
+#line 52 "gram.y"
+	{ yyval.y_list = newList(yystack.l_mark[0].y_arity, yystack.l_mark[-1].y_list); }
+break;
+case 6:
+#line 55 "gram.y"
+	{ yyval.y_arity = newArity(-1, yystack.l_mark[0].y_list); }
+break;
+case 7:
+#line 56 "gram.y"
+	{ yyval.y_arity = 0; doGram(yystack.l_mark[0].y_list); }
+break;
+case 8:
+#line 57 "gram.y"
+	{ yyval.y_arity = 0; doStart(yystack.l_mark[0].y_string); }
+break;
+case 9:
+#line 60 "gram.y"
+	{ yyval.y_list = 0; }
+break;
+case 10:
+#line 61 "gram.y"
+	{ yyval.y_list = newList(yystack.l_mark[0].y_string, yystack.l_mark[-1].y_list); }
+break;
+case 11:
+#line 64 "gram.y"
+	{ yyval.y_list = 0; }
+break;
+case 12:
+#line 65 "gram.y"
+	{ yyval.y_list = newList(yystack.l_mark[0].y_binding, yystack.l_mark[-1].y_list); }
+break;
+case 13:
+#line 68 "gram.y"
+	{ yyval.y_binding = newBinding(yystack.l_mark[-2].y_string, yystack.l_mark[0].y_int); }
+break;
+case 14:
+#line 71 "gram.y"
+	{ yyval.y_list = 0; }
+break;
+case 15:
+#line 72 "gram.y"
+	{ yyval.y_list = newList(yystack.l_mark[0].y_ruleAST, yystack.l_mark[-1].y_list); }
+break;
+case 16:
+#line 75 "gram.y"
+	{ yyval.y_ruleAST = newRuleAST(yystack.l_mark[-6].y_string, yystack.l_mark[-4].y_patternAST, yystack.l_mark[-2].y_int, yystack.l_mark[-1].y_intlist); }
+break;
+case 17:
+#line 78 "gram.y"
+	{ yyval.y_patternAST = newPatternAST(yystack.l_mark[0].y_string, 0); }
+break;
+case 18:
+#line 79 "gram.y"
+	{ yyval.y_patternAST = newPatternAST(yystack.l_mark[-3].y_string, newList(yystack.l_mark[-1].y_patternAST,0)); }
+break;
+case 19:
+#line 80 "gram.y"
+	{ yyval.y_patternAST = newPatternAST(yystack.l_mark[-5].y_string, newList(yystack.l_mark[-3].y_patternAST, newList(yystack.l_mark[-1].y_patternAST, 0))); }
+break;
+case 20:
+#line 83 "gram.y"
+	{ yyval.y_intlist = 0; }
+break;
+case 21:
+#line 84 "gram.y"
+	{ yyval.y_intlist = newIntList(yystack.l_mark[-2].y_int, yystack.l_mark[-1].y_intlist); }
+break;
+case 22:
+#line 87 "gram.y"
+	{ yyval.y_intlist = 0; }
+break;
+case 23:
+#line 88 "gram.y"
+	{ yyval.y_intlist = newIntList(yystack.l_mark[-1].y_int, yystack.l_mark[0].y_intlist); }
+break;
+case 24:
+#line 89 "gram.y"
+	{ yyval.y_intlist = newIntList(yystack.l_mark[-1].y_int, yystack.l_mark[0].y_intlist); }
+break;
+#line 555 "y.tab.c"
+    }
+    yystack.s_mark -= yym;
+    yystate = *yystack.s_mark;
+    yystack.l_mark -= yym;
+    yym = yylhs[yyn];
+    if (yystate == 0 && yym == 0)
+    {
+#if YYDEBUG
+        if (yydebug)
+            printf("%sdebug: after reduction, shifting from state 0 to\
+ state %d\n", YYPREFIX, YYFINAL);
+#endif
+        yystate = YYFINAL;
+        *++yystack.s_mark = YYFINAL;
+        *++yystack.l_mark = yyval;
+        if (yychar < 0)
+        {
+            if ((yychar = YYLEX) < 0) yychar = 0;
+#if YYDEBUG
+            if (yydebug)
+            {
+                yys = yyname[YYTRANSLATE(yychar)];
+                printf("%sdebug: state %d, reading %d (%s)\n",
+                        YYPREFIX, 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("%sdebug: after reduction, shifting from state %d \
+to state %d\n", YYPREFIX, *yystack.s_mark, yystate);
+#endif
+    if (yystack.s_mark >= yystack.s_last && yygrowstack(&yystack))
+    {
+        goto yyoverflow;
+    }
+    *++yystack.s_mark = (short) yystate;
+    *++yystack.l_mark = yyval;
+    goto yyloop;
+
+yyoverflow:
+    yyerror("yacc stack overflow");
+
+yyabort:
+    yyfreestack(&yystack);
+    return (1);
+
+yyaccept:
+    yyfreestack(&yystack);
+    return (0);
+}

Added: test-suite/trunk/MultiSource/Applications/Burg/y.tab.h
URL: http://llvm.org/viewvc/llvm-project/test-suite/trunk/MultiSource/Applications/Burg/y.tab.h?rev=257683&view=auto
==============================================================================
--- test-suite/trunk/MultiSource/Applications/Burg/y.tab.h (added)
+++ test-suite/trunk/MultiSource/Applications/Burg/y.tab.h Wed Jan 13 16:00:24 2016
@@ -0,0 +1,25 @@
+#define ERROR 257
+#define K_TERM 258
+#define K_GRAM 259
+#define K_START 260
+#define K_PPERCENT 261
+#define INT 262
+#define ID 263
+#ifdef YYSTYPE
+#undef  YYSTYPE_IS_DECLARED
+#define YYSTYPE_IS_DECLARED 1
+#endif
+#ifndef YYSTYPE_IS_DECLARED
+#define YYSTYPE_IS_DECLARED 1
+typedef union {
+	int y_int;
+	char *y_string;
+	Arity y_arity;
+	Binding y_binding;
+	PatternAST y_patternAST;
+	RuleAST y_ruleAST;
+	List y_list;
+	IntList y_intlist;
+} YYSTYPE;
+#endif /* !YYSTYPE_IS_DECLARED */
+extern YYSTYPE yylval;




More information about the llvm-commits mailing list