* src/parse-gram.y (rules_or_grammar_declaration): Add an error

recovery rule, and forbid extensions when --yacc.
(gram_error): Use complain_at.
* src/reader.c (reader): Exit if there were parse errors.
This commit is contained in:
Akim Demaille
2002-07-09 14:48:01 +00:00
parent c5f5043618
commit b275314e2d
5 changed files with 209 additions and 174 deletions

View File

@@ -1,3 +1,10 @@
2002-07-09 Akim Demaille <akim@epita.fr>
* src/parse-gram.y (rules_or_grammar_declaration): Add an error
recovery rule, and forbid extensions when --yacc.
(gram_error): Use complain_at.
* src/reader.c (reader): Exit if there were parse errors.
2002-07-09 Akim Demaille <akim@epita.fr> 2002-07-09 Akim Demaille <akim@epita.fr>
* tests/synclines.at (AT_SYNCLINES_COMPILE): New. * tests/synclines.at (AT_SYNCLINES_COMPILE): New.

View File

@@ -57,6 +57,7 @@
#line 31 "parse-gram.y" #line 31 "parse-gram.y"
#include "system.h" #include "system.h"
#include "complain.h"
#include "muscle_tab.h" #include "muscle_tab.h"
#include "files.h" #include "files.h"
#include "getargs.h" #include "getargs.h"
@@ -224,7 +225,7 @@ braced_code_t current_braced_code = action_braced_code;
#endif #endif
#ifndef YYSTYPE #ifndef YYSTYPE
#line 88 "parse-gram.y" #line 89 "parse-gram.y"
typedef union { typedef union {
symbol_t *symbol; symbol_t *symbol;
symbol_list_t *list; symbol_list_t *list;
@@ -232,8 +233,8 @@ typedef union {
char *string; char *string;
associativity assoc; associativity assoc;
} yystype; } yystype;
/* Line 187 of /home/lrde/prof/akim/src/bison/data/yacc.c. */ /* Line 187 of /usr/local/share/bison/yacc.c. */
#line 237 "parse-gram.c" #line 238 "parse-gram.c"
# define YYSTYPE yystype # define YYSTYPE yystype
# define YYSTYPE_IS_TRIVIAL 1 # define YYSTYPE_IS_TRIVIAL 1
#endif #endif
@@ -253,8 +254,8 @@ typedef struct yyltype
/* Copy the second part of user declarations. */ /* Copy the second part of user declarations. */
/* Line 207 of /home/lrde/prof/akim/src/bison/data/yacc.c. */ /* Line 207 of /usr/local/share/bison/yacc.c. */
#line 258 "parse-gram.c" #line 259 "parse-gram.c"
#if ! defined (yyoverflow) || YYERROR_VERBOSE #if ! defined (yyoverflow) || YYERROR_VERBOSE
@@ -348,16 +349,16 @@ union yyalloc
/* YYFINAL -- State number of the termination state. */ /* YYFINAL -- State number of the termination state. */
#define YYFINAL 3 #define YYFINAL 3
#define YYFLAG -32768 #define YYFLAG -32768
#define YYLAST 125 #define YYLAST 127
/* YYNTOKENS -- Number of terminals. */ /* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 45 #define YYNTOKENS 45
/* YYNNTS -- Number of nonterminals. */ /* YYNNTS -- Number of nonterminals. */
#define YYNNTS 28 #define YYNNTS 28
/* YYNRULES -- Number of rules. */ /* YYNRULES -- Number of rules. */
#define YYNRULES 74 #define YYNRULES 75
/* YYNRULES -- Number of states. */ /* YYNRULES -- Number of states. */
#define YYNSTATES 106 #define YYNSTATES 108
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2 #define YYUNDEFTOK 2
@@ -411,9 +412,9 @@ static const unsigned char yyprhs[] =
53, 55, 57, 59, 61, 63, 66, 69, 70, 75, 53, 55, 57, 59, 61, 63, 66, 69, 70, 75,
76, 81, 82, 86, 87, 91, 95, 99, 101, 103, 76, 81, 82, 86, 87, 91, 95, 99, 101, 103,
105, 106, 108, 110, 113, 115, 117, 120, 123, 127, 105, 106, 108, 110, 113, 115, 117, 120, 123, 127,
129, 132, 134, 137, 139, 142, 143, 149, 151, 155, 129, 132, 134, 137, 139, 142, 145, 146, 152, 154,
156, 159, 162, 166, 170, 174, 176, 178, 180, 182, 158, 159, 162, 165, 169, 173, 177, 179, 181, 183,
184, 186, 187, 190, 191 185, 187, 189, 190, 193, 194
}; };
/* YYRHS -- A `-1'-separated list of the rules' RHS. */ /* YYRHS -- A `-1'-separated list of the rules' RHS. */
@@ -433,25 +434,25 @@ static const signed char yyrhs[] =
58, 67, -1, 35, -1, 40, -1, 40, 5, -1, 58, 67, -1, 35, -1, 40, -1, 40, 5, -1,
40, 69, -1, 40, 5, 69, -1, 59, -1, 60, 40, 69, -1, 40, 5, 69, -1, 59, -1, 60,
59, -1, 62, -1, 61, 62, -1, 63, -1, 49, 59, -1, 62, -1, 61, 62, -1, 63, -1, 49,
37, -1, -1, 40, 38, 64, 65, 37, -1, 66, 37, -1, 1, 37, -1, -1, 40, 38, 64, 65,
-1, 65, 39, 66, -1, -1, 66, 67, -1, 66, 37, -1, 66, -1, 65, 39, 66, -1, -1, 66,
68, -1, 66, 17, 67, -1, 66, 18, 5, -1, 67, -1, 66, 68, -1, 66, 17, 67, -1, 66,
66, 19, 35, -1, 40, -1, 69, -1, 4, -1, 18, 5, -1, 66, 19, 35, -1, 40, -1, 69,
44, -1, 3, -1, 3, -1, -1, 41, 43, -1, -1, 4, -1, 44, -1, 3, -1, 3, -1, -1,
-1, 37, -1 41, 43, -1, -1, 37, -1
}; };
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */ /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
static const unsigned short yyrline[] = static const unsigned short yyrline[] =
{ {
0, 158, 158, 171, 173, 176, 178, 179, 180, 181, 0, 159, 159, 172, 174, 177, 179, 180, 181, 182,
182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192,
192, 193, 194, 197, 199, 200, 204, 211, 210, 221, 193, 194, 195, 198, 200, 201, 205, 212, 211, 222,
220, 233, 232, 238, 238, 243, 252, 267, 269, 270, 221, 234, 233, 239, 239, 244, 253, 268, 270, 271,
273, 275, 280, 282, 286, 291, 296, 302, 308, 318, 274, 276, 281, 283, 287, 292, 297, 303, 309, 319,
321, 330, 332, 338, 340, 344, 343, 348, 350, 353, 322, 331, 333, 339, 341, 346, 353, 352, 357, 359,
356, 358, 360, 362, 364, 368, 370, 371, 374, 380, 362, 365, 367, 369, 371, 373, 377, 379, 380, 383,
389, 397, 402, 408, 410 389, 398, 406, 411, 417, 419
}; };
#endif #endif
@@ -498,9 +499,9 @@ static const unsigned char yyr1[] =
48, 48, 48, 49, 49, 49, 49, 50, 49, 51, 48, 48, 48, 49, 49, 49, 49, 50, 49, 51,
49, 53, 52, 54, 52, 52, 55, 56, 56, 56, 49, 53, 52, 54, 52, 52, 55, 56, 56, 56,
57, 57, 58, 58, 59, 59, 59, 59, 59, 60, 57, 57, 58, 58, 59, 59, 59, 59, 59, 60,
60, 61, 61, 62, 62, 64, 63, 65, 65, 66, 60, 61, 61, 62, 62, 62, 64, 63, 65, 65,
66, 66, 66, 66, 66, 67, 67, 67, 68, 69, 66, 66, 66, 66, 66, 66, 67, 67, 67, 68,
70, 71, 71, 72, 72 69, 70, 71, 71, 72, 72
}; };
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */ /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
@@ -511,9 +512,9 @@ static const unsigned char yyr2[] =
1, 1, 1, 1, 1, 2, 2, 0, 4, 0, 1, 1, 1, 1, 1, 2, 2, 0, 4, 0,
4, 0, 3, 0, 3, 3, 3, 1, 1, 1, 4, 0, 3, 0, 3, 3, 3, 1, 1, 1,
0, 1, 1, 2, 1, 1, 2, 2, 3, 1, 0, 1, 1, 2, 1, 1, 2, 2, 3, 1,
2, 1, 2, 1, 2, 0, 5, 1, 3, 0, 2, 1, 2, 1, 2, 2, 0, 5, 1, 3,
2, 2, 3, 3, 3, 1, 1, 1, 1, 1, 0, 2, 2, 3, 3, 3, 1, 1, 1, 1,
1, 0, 2, 0, 1 1, 1, 0, 2, 0, 1
}; };
/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
@@ -524,47 +525,47 @@ static const short yydefact[] =
3, 0, 0, 0, 33, 31, 0, 27, 29, 0, 3, 0, 0, 0, 33, 31, 0, 27, 29, 0,
37, 38, 39, 0, 0, 21, 10, 0, 0, 0, 37, 38, 39, 0, 0, 21, 10, 0, 0, 0,
0, 17, 18, 9, 22, 7, 13, 15, 0, 20, 0, 17, 18, 9, 22, 7, 13, 15, 0, 20,
0, 6, 73, 5, 24, 23, 40, 0, 0, 0, 0, 6, 74, 5, 24, 23, 40, 0, 0, 0,
0, 0, 26, 11, 69, 67, 65, 25, 66, 0, 0, 0, 26, 11, 70, 68, 66, 25, 67, 0,
0, 0, 70, 0, 19, 0, 0, 71, 51, 53, 0, 0, 71, 0, 19, 0, 0, 0, 0, 51,
74, 4, 41, 0, 44, 45, 49, 34, 32, 35, 53, 75, 4, 41, 0, 44, 45, 49, 34, 32,
42, 0, 0, 16, 12, 14, 8, 55, 54, 0, 35, 42, 0, 0, 16, 12, 14, 8, 55, 56,
52, 2, 36, 46, 47, 50, 43, 28, 30, 59, 54, 0, 52, 2, 36, 46, 47, 50, 43, 28,
72, 48, 0, 57, 56, 59, 0, 0, 0, 68, 30, 60, 73, 48, 0, 58, 57, 60, 0, 0,
60, 61, 58, 62, 63, 64 0, 69, 61, 62, 59, 63, 64, 65
}; };
/* YYPGOTO[NTERM-NUM]. */ /* YYPGOTO[NTERM-NUM]. */
static const short yydefgoto[] = static const short yydefgoto[] =
{ {
-1, 1, 2, 32, 56, 40, 41, 34, 38, 37, -1, 1, 2, 32, 57, 40, 41, 34, 38, 37,
35, 36, 63, 69, 66, 67, 57, 58, 59, 89, 35, 36, 64, 70, 67, 68, 58, 59, 60, 91,
92, 93, 70, 101, 48, 53, 81, 61 94, 95, 71, 103, 48, 53, 83, 62
}; };
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */ STATE-NUM. */
static const short yypact[] = static const short yypact[] =
{ {
-32768, 7, 83,-32768,-32768,-32768, -23,-32768,-32768, 3, -32768, 35, 85,-32768,-32768,-32768, 2,-32768,-32768, -5,
-32768,-32768,-32768, 43, 0,-32768,-32768, 13, 14, 15, -32768,-32768,-32768, 31, 0,-32768,-32768, 18, 21, 22,
51,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 51,-32768, 59,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 59,-32768,
23,-32768, 19,-32768,-32768,-32768, 22, -29, -29, 0, 37,-32768, 26,-32768,-32768,-32768, 29, -19, -19, 0,
17, 18,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 51, 23, 24,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 59,
51, 51,-32768, 51,-32768, 20, 27, 12,-32768,-32768, 59, 59,-32768, 59,-32768, 28, 33, 32, 1,-32768,
-32768,-32768,-32768, 0,-32768, 5,-32768, -29, -29, 0, -32768,-32768,-32768,-32768, 0,-32768, 17,-32768, -19, -19,
-32768, 0, 0,-32768,-32768,-32768,-32768,-32768,-32768, 28, 0,-32768, 0, 0,-32768,-32768,-32768,-32768,-32768,-32768,
-32768,-32768, 0, 56,-32768,-32768,-32768, 0, 0,-32768, -32768, 30,-32768,-32768, 0, 63,-32768,-32768,-32768, 0,
-32768,-32768, 4, -2,-32768,-32768, 0, 55, 35,-32768, 0,-32768,-32768,-32768, -8, 15,-32768,-32768, 0, 67,
-32768,-32768, -2,-32768,-32768,-32768 39,-32768,-32768,-32768, 15,-32768,-32768,-32768
}; };
/* YYPGOTO[NTERM-NUM]. */ /* YYPGOTO[NTERM-NUM]. */
static const short yypgoto[] = static const short yypgoto[] =
{ {
-32768,-32768,-32768,-32768, 70,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768, 76,-32768,-32768,-32768,-32768,-32768,
-32768,-32768,-32768, -58, -22, 37,-32768, 21,-32768,-32768, -32768,-32768,-32768, -12, -45, 41,-32768, 25,-32768,-32768,
-32768, -19, -14,-32768, -56, 16,-32768,-32768 -32768, -17, -14,-32768, -60, -23,-32768,-32768
}; };
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
@@ -572,36 +573,36 @@ static const short yypgoto[] =
number is the opposite. If zero, do what YYDEFACT says. */ number is the opposite. If zero, do what YYDEFACT says. */
static const short yytable[] = static const short yytable[] =
{ {
47, 44, 45, 44, 45, 82, 64, 3, 44, 84, 47, -72, 55, 44, 45, 54, 86, 4, 5, 6,
83, 65, 39, 87, 88, 96, 97, 98, 4, 5, 7, 8, 9, 10, 11, 12, 65, 14, 44, 45,
6, 7, 8, 9, 10, 11, 12, 91, 14, 4, 44, 66, 85, 87, 87, 93, 74, 75, 76, 96,
5, 6, 7, 8, 9, 10, 11, 12, 46, 14, 77, 97, 98, 99, 100, 3, 43, 39, 55, 42,
46, 94, 99, 95, 54, 85, 85, 42, 43, 49, 46, 56, 81, 4, 5, 6, 7, 8, 9, 10,
50, 51, 55, 79, 52, 86, 60, 62, 77, 44, 11, 12, 84, 14, 49, 46, 88, 50, 51, 101,
104, 71, 72, 55, 78, 73, 74, 75, 86, 76, 89, 90, 52, 61, 63, 78, 44, 72, 73, 80,
105, 90, 33, 86, 86, 68, 102, 0, 80, 100, 88, 79, 106, 92, 107, 88, 88, 56, 33, 69,
0, 0, 103, 0, 0, 0, 0, 0, 100, 4, 104, 102, 0, 82, 105, 0, 0, 0, 0, 0,
5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 102, 4, 5, 6, 7, 8, 9, 10, 11, 12,
0, 0, 0, 15, 16, 17, 18, 19, 20, 21, 13, 14, 0, 0, 0, 15, 16, 17, 18, 19,
22, 23, 24, 25, 26, 27, 28, 29, 0, 0, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29,
0, 0, 0, 0, 30, 31 0, 0, 0, 0, 0, 0, 30, 31
}; };
static const short yycheck[] = static const short yycheck[] =
{ {
14, 3, 4, 3, 4, 63, 35, 0, 3, 65, 14, 0, 1, 3, 4, 28, 66, 6, 7, 8,
5, 40, 35, 71, 72, 17, 18, 19, 6, 7, 9, 10, 11, 12, 13, 14, 35, 16, 3, 4,
8, 9, 10, 11, 12, 13, 14, 83, 16, 6, 3, 40, 5, 68, 69, 85, 49, 50, 51, 37,
7, 8, 9, 10, 11, 12, 13, 14, 40, 16, 53, 39, 17, 18, 19, 0, 5, 35, 1, 44,
40, 37, 44, 39, 28, 67, 68, 44, 5, 36, 40, 40, 41, 6, 7, 8, 9, 10, 11, 12,
36, 36, 40, 41, 3, 69, 37, 35, 38, 3, 13, 14, 64, 16, 36, 40, 70, 36, 36, 44,
5, 44, 44, 40, 37, 49, 50, 51, 82, 53, 72, 73, 3, 37, 35, 37, 3, 44, 44, 37,
35, 43, 2, 87, 88, 38, 95, -1, 57, 93, 84, 38, 5, 43, 35, 89, 90, 40, 2, 38,
-1, -1, 96, -1, -1, -1, -1, -1, 102, 6, 97, 95, -1, 58, 98, -1, -1, -1, -1, -1,
7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 104, 6, 7, 8, 9, 10, 11, 12, 13, 14,
-1, -1, -1, 20, 21, 22, 23, 24, 25, 26, 15, 16, -1, -1, -1, 20, 21, 22, 23, 24,
27, 28, 29, 30, 31, 32, 33, 34, -1, -1, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
-1, -1, -1, -1, 41, 42 -1, -1, -1, -1, -1, -1, 41, 42
}; };
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
@@ -613,12 +614,12 @@ static const unsigned char yystos[] =
25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
41, 42, 48, 49, 52, 55, 56, 54, 53, 35, 41, 42, 48, 49, 52, 55, 56, 54, 53, 35,
50, 51, 44, 5, 3, 4, 40, 67, 69, 36, 50, 51, 44, 5, 3, 4, 40, 67, 69, 36,
36, 36, 3, 70, 70, 40, 49, 61, 62, 63, 36, 36, 3, 70, 70, 1, 40, 49, 61, 62,
37, 72, 35, 57, 35, 40, 59, 60, 60, 58, 63, 37, 72, 35, 57, 35, 40, 59, 60, 60,
67, 44, 44, 70, 70, 70, 70, 38, 37, 41, 58, 67, 44, 44, 70, 70, 70, 70, 37, 38,
62, 71, 58, 5, 69, 59, 67, 58, 58, 64, 37, 41, 62, 71, 58, 5, 69, 59, 67, 58,
43, 69, 65, 66, 37, 39, 17, 18, 19, 44, 58, 64, 43, 69, 65, 66, 37, 39, 17, 18,
67, 68, 66, 67, 5, 35 19, 44, 67, 68, 66, 67, 5, 35
}; };
#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
@@ -1134,7 +1135,7 @@ yyreduce:
switch (yyn) switch (yyn)
{ {
case 2: case 2:
#line 160 "parse-gram.y" #line 161 "parse-gram.y"
{ {
yycontrol->errcode = 0; yycontrol->errcode = 0;
epilogue_set (yyvsp[0].string, yylsp[0]); epilogue_set (yyvsp[0].string, yylsp[0]);
@@ -1142,99 +1143,99 @@ yyreduce:
break; break;
case 6: case 6:
#line 178 "parse-gram.y" #line 179 "parse-gram.y"
{ prologue_augment (yyvsp[0].string, yylsp[0]); } { prologue_augment (yyvsp[0].string, yylsp[0]); }
break; break;
case 7: case 7:
#line 179 "parse-gram.y" #line 180 "parse-gram.y"
{ debug_flag = 1; } { debug_flag = 1; }
break; break;
case 8: case 8:
#line 180 "parse-gram.y" #line 181 "parse-gram.y"
{ muscle_insert (yyvsp[-1].string, yyvsp[0].string); } { muscle_insert (yyvsp[-1].string, yyvsp[0].string); }
break; break;
case 9: case 9:
#line 181 "parse-gram.y" #line 182 "parse-gram.y"
{ defines_flag = 1; } { defines_flag = 1; }
break; break;
case 10: case 10:
#line 182 "parse-gram.y" #line 183 "parse-gram.y"
{ error_verbose = 1; } { error_verbose = 1; }
break; break;
case 11: case 11:
#line 183 "parse-gram.y" #line 184 "parse-gram.y"
{ expected_conflicts = yyvsp[0].integer; } { expected_conflicts = yyvsp[0].integer; }
break; break;
case 12: case 12:
#line 184 "parse-gram.y" #line 185 "parse-gram.y"
{ spec_file_prefix = yyvsp[0].string; } { spec_file_prefix = yyvsp[0].string; }
break; break;
case 13: case 13:
#line 185 "parse-gram.y" #line 186 "parse-gram.y"
{ locations_flag = 1; } { locations_flag = 1; }
break; break;
case 14: case 14:
#line 186 "parse-gram.y" #line 187 "parse-gram.y"
{ spec_name_prefix = yyvsp[0].string; } { spec_name_prefix = yyvsp[0].string; }
break; break;
case 15: case 15:
#line 187 "parse-gram.y" #line 188 "parse-gram.y"
{ no_lines_flag = 1; } { no_lines_flag = 1; }
break; break;
case 16: case 16:
#line 188 "parse-gram.y" #line 189 "parse-gram.y"
{ spec_outfile = yyvsp[0].string; } { spec_outfile = yyvsp[0].string; }
break; break;
case 17: case 17:
#line 189 "parse-gram.y" #line 190 "parse-gram.y"
{ pure_parser = 1; } { pure_parser = 1; }
break; break;
case 18: case 18:
#line 190 "parse-gram.y" #line 191 "parse-gram.y"
{ glr_parser = 1; } { glr_parser = 1; }
break; break;
case 19: case 19:
#line 191 "parse-gram.y" #line 192 "parse-gram.y"
{ skeleton = yyvsp[0].string; } { skeleton = yyvsp[0].string; }
break; break;
case 20: case 20:
#line 192 "parse-gram.y" #line 193 "parse-gram.y"
{ token_table_flag = 1; } { token_table_flag = 1; }
break; break;
case 21: case 21:
#line 193 "parse-gram.y" #line 194 "parse-gram.y"
{ report_flag = 1; } { report_flag = 1; }
break; break;
case 22: case 22:
#line 194 "parse-gram.y" #line 195 "parse-gram.y"
{ yacc_flag = 1; } { yacc_flag = 1; }
break; break;
case 25: case 25:
#line 201 "parse-gram.y" #line 202 "parse-gram.y"
{ {
grammar_start_symbol_set (yyvsp[0].symbol, yylsp[0]); grammar_start_symbol_set (yyvsp[0].symbol, yylsp[0]);
} }
break; break;
case 26: case 26:
#line 205 "parse-gram.y" #line 206 "parse-gram.y"
{ {
typed = 1; typed = 1;
MUSCLE_INSERT_INT ("stype_line", yylsp[0].first_line); MUSCLE_INSERT_INT ("stype_line", yylsp[0].first_line);
@@ -1243,12 +1244,12 @@ yyreduce:
break; break;
case 27: case 27:
#line 211 "parse-gram.y" #line 212 "parse-gram.y"
{ current_braced_code = destructor_braced_code; } { current_braced_code = destructor_braced_code; }
break; break;
case 28: case 28:
#line 213 "parse-gram.y" #line 214 "parse-gram.y"
{ {
symbol_list_t *list; symbol_list_t *list;
for (list = yyvsp[0].list; list; list = list->next) for (list = yyvsp[0].list; list; list = list->next)
@@ -1259,12 +1260,12 @@ yyreduce:
break; break;
case 29: case 29:
#line 221 "parse-gram.y" #line 222 "parse-gram.y"
{ current_braced_code = printer_braced_code; } { current_braced_code = printer_braced_code; }
break; break;
case 30: case 30:
#line 223 "parse-gram.y" #line 224 "parse-gram.y"
{ {
symbol_list_t *list; symbol_list_t *list;
for (list = yyvsp[0].list; list; list = list->next) for (list = yyvsp[0].list; list; list = list->next)
@@ -1275,12 +1276,12 @@ yyreduce:
break; break;
case 31: case 31:
#line 233 "parse-gram.y" #line 234 "parse-gram.y"
{ current_class = nterm_sym; } { current_class = nterm_sym; }
break; break;
case 32: case 32:
#line 234 "parse-gram.y" #line 235 "parse-gram.y"
{ {
current_class = unknown_sym; current_class = unknown_sym;
current_type = NULL; current_type = NULL;
@@ -1288,12 +1289,12 @@ yyreduce:
break; break;
case 33: case 33:
#line 238 "parse-gram.y" #line 239 "parse-gram.y"
{ current_class = token_sym; } { current_class = token_sym; }
break; break;
case 34: case 34:
#line 239 "parse-gram.y" #line 240 "parse-gram.y"
{ {
current_class = unknown_sym; current_class = unknown_sym;
current_type = NULL; current_type = NULL;
@@ -1301,7 +1302,7 @@ yyreduce:
break; break;
case 35: case 35:
#line 244 "parse-gram.y" #line 245 "parse-gram.y"
{ {
symbol_list_t *list; symbol_list_t *list;
for (list = yyvsp[0].list; list; list = list->next) for (list = yyvsp[0].list; list; list = list->next)
@@ -1311,7 +1312,7 @@ yyreduce:
break; break;
case 36: case 36:
#line 254 "parse-gram.y" #line 255 "parse-gram.y"
{ {
symbol_list_t *list; symbol_list_t *list;
++current_prec; ++current_prec;
@@ -1326,49 +1327,49 @@ yyreduce:
break; break;
case 37: case 37:
#line 268 "parse-gram.y" #line 269 "parse-gram.y"
{ yyval.assoc = left_assoc; } { yyval.assoc = left_assoc; }
break; break;
case 38: case 38:
#line 269 "parse-gram.y" #line 270 "parse-gram.y"
{ yyval.assoc = right_assoc; } { yyval.assoc = right_assoc; }
break; break;
case 39: case 39:
#line 270 "parse-gram.y" #line 271 "parse-gram.y"
{ yyval.assoc = non_assoc; } { yyval.assoc = non_assoc; }
break; break;
case 40: case 40:
#line 274 "parse-gram.y" #line 275 "parse-gram.y"
{ current_type = NULL;} { current_type = NULL;}
break; break;
case 41: case 41:
#line 275 "parse-gram.y" #line 276 "parse-gram.y"
{ current_type = yyvsp[0].string; } { current_type = yyvsp[0].string; }
break; break;
case 42: case 42:
#line 281 "parse-gram.y" #line 282 "parse-gram.y"
{ yyval.list = symbol_list_new (yyvsp[0].symbol, yylsp[0]); } { yyval.list = symbol_list_new (yyvsp[0].symbol, yylsp[0]); }
break; break;
case 43: case 43:
#line 282 "parse-gram.y" #line 283 "parse-gram.y"
{ yyval.list = symbol_list_prepend (yyvsp[-1].list, yyvsp[0].symbol, yylsp[0]); } { yyval.list = symbol_list_prepend (yyvsp[-1].list, yyvsp[0].symbol, yylsp[0]); }
break; break;
case 44: case 44:
#line 288 "parse-gram.y" #line 289 "parse-gram.y"
{ {
current_type = yyvsp[0].string; current_type = yyvsp[0].string;
} }
break; break;
case 45: case 45:
#line 292 "parse-gram.y" #line 293 "parse-gram.y"
{ {
symbol_class_set (yyvsp[0].symbol, current_class, yylsp[0]); symbol_class_set (yyvsp[0].symbol, current_class, yylsp[0]);
symbol_type_set (yyvsp[0].symbol, current_type, yylsp[0]); symbol_type_set (yyvsp[0].symbol, current_type, yylsp[0]);
@@ -1376,7 +1377,7 @@ yyreduce:
break; break;
case 46: case 46:
#line 297 "parse-gram.y" #line 298 "parse-gram.y"
{ {
symbol_class_set (yyvsp[-1].symbol, current_class, yylsp[-1]); symbol_class_set (yyvsp[-1].symbol, current_class, yylsp[-1]);
symbol_type_set (yyvsp[-1].symbol, current_type, yylsp[-1]); symbol_type_set (yyvsp[-1].symbol, current_type, yylsp[-1]);
@@ -1385,7 +1386,7 @@ yyreduce:
break; break;
case 47: case 47:
#line 303 "parse-gram.y" #line 304 "parse-gram.y"
{ {
symbol_class_set (yyvsp[-1].symbol, current_class, yylsp[-1]); symbol_class_set (yyvsp[-1].symbol, current_class, yylsp[-1]);
symbol_type_set (yyvsp[-1].symbol, current_type, yylsp[-1]); symbol_type_set (yyvsp[-1].symbol, current_type, yylsp[-1]);
@@ -1394,7 +1395,7 @@ yyreduce:
break; break;
case 48: case 48:
#line 309 "parse-gram.y" #line 310 "parse-gram.y"
{ {
symbol_class_set (yyvsp[-2].symbol, current_class, yylsp[-2]); symbol_class_set (yyvsp[-2].symbol, current_class, yylsp[-2]);
symbol_type_set (yyvsp[-2].symbol, current_type, yylsp[-2]); symbol_type_set (yyvsp[-2].symbol, current_type, yylsp[-2]);
@@ -1404,110 +1405,125 @@ yyreduce:
break; break;
case 49: case 49:
#line 320 "parse-gram.y" #line 321 "parse-gram.y"
{;} {;}
break; break;
case 50: case 50:
#line 322 "parse-gram.y" #line 323 "parse-gram.y"
{;} {;}
break; break;
case 54:
#line 342 "parse-gram.y"
{
if (yacc_flag)
complain_at (yyloc, _("POSIX forbids declarations in the grammar"));
}
break;
case 55: case 55:
#line 344 "parse-gram.y" #line 347 "parse-gram.y"
{ current_lhs = yyvsp[-1].symbol; current_lhs_location = yylsp[-1]; } {
yyerrok;
}
break; break;
case 56: case 56:
#line 345 "parse-gram.y" #line 353 "parse-gram.y"
{;} { current_lhs = yyvsp[-1].symbol; current_lhs_location = yylsp[-1]; }
break; break;
case 57: case 57:
#line 349 "parse-gram.y" #line 354 "parse-gram.y"
{ grammar_rule_end (yylsp[0]); } {;}
break; break;
case 58: case 58:
#line 350 "parse-gram.y" #line 358 "parse-gram.y"
{ grammar_rule_end (yylsp[0]); } { grammar_rule_end (yylsp[0]); }
break; break;
case 59: case 59:
#line 355 "parse-gram.y" #line 359 "parse-gram.y"
{ grammar_rule_begin (current_lhs, current_lhs_location); } { grammar_rule_end (yylsp[0]); }
break; break;
case 60: case 60:
#line 357 "parse-gram.y" #line 364 "parse-gram.y"
{ grammar_current_rule_symbol_append (yyvsp[0].symbol, yylsp[0]); } { grammar_rule_begin (current_lhs, current_lhs_location); }
break; break;
case 61: case 61:
#line 359 "parse-gram.y" #line 366 "parse-gram.y"
{ grammar_current_rule_action_append (yyvsp[0].string, yylsp[0]); } { grammar_current_rule_symbol_append (yyvsp[0].symbol, yylsp[0]); }
break; break;
case 62: case 62:
#line 361 "parse-gram.y" #line 368 "parse-gram.y"
{ grammar_current_rule_prec_set (yyvsp[0].symbol, yylsp[0]); } { grammar_current_rule_action_append (yyvsp[0].string, yylsp[0]); }
break; break;
case 63: case 63:
#line 363 "parse-gram.y" #line 370 "parse-gram.y"
{ grammar_current_rule_dprec_set (yyvsp[0].integer, yylsp[0]); } { grammar_current_rule_prec_set (yyvsp[0].symbol, yylsp[0]); }
break; break;
case 64: case 64:
#line 365 "parse-gram.y" #line 372 "parse-gram.y"
{ grammar_current_rule_merge_set (yyvsp[0].string, yylsp[0]); } { grammar_current_rule_dprec_set (yyvsp[0].integer, yylsp[0]); }
break; break;
case 65: case 65:
#line 369 "parse-gram.y" #line 374 "parse-gram.y"
{ yyval.symbol = yyvsp[0].symbol; } { grammar_current_rule_merge_set (yyvsp[0].string, yylsp[0]); }
break; break;
case 66: case 66:
#line 370 "parse-gram.y" #line 378 "parse-gram.y"
{ yyval.symbol = yyvsp[0].symbol; } { yyval.symbol = yyvsp[0].symbol; }
break; break;
case 67: case 67:
#line 371 "parse-gram.y" #line 379 "parse-gram.y"
{ yyval.symbol = symbol_get (yyvsp[0].string, yylsp[0]); } { yyval.symbol = yyvsp[0].symbol; }
break; break;
case 68: case 68:
#line 376 "parse-gram.y" #line 380 "parse-gram.y"
{ yyval.string = yyvsp[0].string; } { yyval.symbol = symbol_get (yyvsp[0].string, yylsp[0]); }
break; break;
case 69: case 69:
#line 382 "parse-gram.y" #line 385 "parse-gram.y"
{ yyval.string = yyvsp[0].string; }
break;
case 70:
#line 391 "parse-gram.y"
{ {
yyval.symbol = symbol_get (yyvsp[0].string, yylsp[0]); yyval.symbol = symbol_get (yyvsp[0].string, yylsp[0]);
symbol_class_set (yyval.symbol, token_sym, yylsp[0]); symbol_class_set (yyval.symbol, token_sym, yylsp[0]);
} }
break; break;
case 70: case 71:
#line 391 "parse-gram.y" #line 400 "parse-gram.y"
{ {
yyval.string = yyvsp[0].string + 1; yyval.string = yyvsp[0].string + 1;
yyval.string[strlen (yyval.string) - 1] = '\0'; yyval.string[strlen (yyval.string) - 1] = '\0';
} }
break; break;
case 71: case 72:
#line 399 "parse-gram.y" #line 408 "parse-gram.y"
{ {
yyval.string = xstrdup (""); yyval.string = xstrdup ("");
} }
break; break;
case 72: case 73:
#line 403 "parse-gram.y" #line 412 "parse-gram.y"
{ {
yyval.string = yyvsp[0].string; yyval.string = yyvsp[0].string;
} }
@@ -1516,8 +1532,8 @@ yyreduce:
} }
/* Line 955 of /home/lrde/prof/akim/src/bison/data/yacc.c. */ /* Line 955 of /usr/local/share/bison/yacc.c. */
#line 1521 "parse-gram.c" #line 1537 "parse-gram.c"
yyvsp -= yylen; yyvsp -= yylen;
yyssp -= yylen; yyssp -= yylen;
@@ -1788,7 +1804,7 @@ yysymprint (FILE* yyout, int yytype,
} }
#endif /* YYDEBUG. */ #endif /* YYDEBUG. */
#line 412 "parse-gram.y" #line 421 "parse-gram.y"
/*------------------------------------------------------------------. /*------------------------------------------------------------------.
| When debugging the parser, display tokens' locations and values. | | When debugging the parser, display tokens' locations and values. |
@@ -1833,7 +1849,6 @@ void
gram_error (gram_control_t *control ATTRIBUTE_UNUSED, gram_error (gram_control_t *control ATTRIBUTE_UNUSED,
location_t *yylloc, const char *msg) location_t *yylloc, const char *msg)
{ {
LOCATION_PRINT (stderr, *yylloc); complain_at (*yylloc, "%s", msg);
fprintf (stderr, ": %s\n", msg);
} }

View File

@@ -128,7 +128,7 @@
#ifndef YYSTYPE #ifndef YYSTYPE
#line 88 "parse-gram.y" #line 89 "parse-gram.y"
typedef union { typedef union {
symbol_t *symbol; symbol_t *symbol;
symbol_list_t *list; symbol_list_t *list;
@@ -136,7 +136,7 @@ typedef union {
char *string; char *string;
associativity assoc; associativity assoc;
} yystype; } yystype;
/* Line 1271 of /home/lrde/prof/akim/src/bison/data/yacc.c. */ /* Line 1271 of /usr/local/share/bison/yacc.c. */
#line 141 "y.tab.h" #line 141 "y.tab.h"
# define YYSTYPE yystype # define YYSTYPE yystype
#endif #endif

View File

@@ -30,6 +30,7 @@
%{ %{
#include "system.h" #include "system.h"
#include "complain.h"
#include "muscle_tab.h" #include "muscle_tab.h"
#include "files.h" #include "files.h"
#include "getargs.h" #include "getargs.h"
@@ -338,6 +339,14 @@ grammar:
rules_or_grammar_declaration: rules_or_grammar_declaration:
rules rules
| grammar_declaration ";" | grammar_declaration ";"
{
if (yacc_flag)
complain_at (@$, _("POSIX forbids declarations in the grammar"));
}
| error ";"
{
yyerrok;
}
; ;
rules: rules:
@@ -453,6 +462,5 @@ void
gram_error (gram_control_t *control ATTRIBUTE_UNUSED, gram_error (gram_control_t *control ATTRIBUTE_UNUSED,
location_t *yylloc, const char *msg) location_t *yylloc, const char *msg)
{ {
LOCATION_PRINT (stderr, *yylloc); complain_at (*yylloc, "%s", msg);
fprintf (stderr, ": %s\n", msg);
} }

View File

@@ -502,6 +502,11 @@ reader (void)
scanner_initialize (); scanner_initialize ();
gram_parse (&gram_control); gram_parse (&gram_control);
/* If something went wrong during the parsing, don't try to
continue. */
if (complain_message_count)
exit (1);
/* Grammar has been read. Do some checking */ /* Grammar has been read. Do some checking */
if (nrules == 0) if (nrules == 0)
fatal (_("no rules in the input grammar")); fatal (_("no rules in the input grammar"));