* src/parse-gram.y: Use %printer instead of YYPRINT.

This commit is contained in:
Akim Demaille
2005-07-12 13:54:41 +00:00
parent 2cbd078f51
commit 82b248ada6
4 changed files with 193 additions and 176 deletions

View File

@@ -1,3 +1,7 @@
2005-07-12 Akim Demaille <akim@epita.fr>
* src/parse-gram.y: Use %printer instead of YYPRINT.
2005-07-12 Akim Demaille <akim@epita.fr> 2005-07-12 Akim Demaille <akim@epita.fr>
* src/symtab.h, src/symtab.c (symbol_print): New. * src/symtab.h, src/symtab.c (symbol_print): New.

View File

@@ -166,7 +166,7 @@
/* Copy the first part of user declarations. */ /* Copy the first part of user declarations. */
#line 1 "parse-gram.y" #line 1 "../../src/parse-gram.y"
/* Bison Grammar Parser -*- C -*- /* Bison Grammar Parser -*- C -*-
Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc. Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
@@ -215,10 +215,6 @@ static YYLTYPE lloc_default (YYLTYPE const *, int);
gram_error (&yylloc, Msg) gram_error (&yylloc, Msg)
static void gram_error (location const *, char const *); static void gram_error (location const *, char const *);
#define YYPRINT(File, Type, Value) \
print_token_value (File, Type, &Value)
static void print_token_value (FILE *, int, YYSTYPE const *);
static void add_param (char const *, char *, location); static void add_param (char const *, char *, location);
symbol_class current_class = unknown_sym; symbol_class current_class = unknown_sym;
@@ -243,7 +239,7 @@ int current_prec = 0;
#endif #endif
#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED) #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
#line 82 "parse-gram.y" #line 79 "../../src/parse-gram.y"
typedef union YYSTYPE { typedef union YYSTYPE {
symbol *symbol; symbol *symbol;
symbol_list *list; symbol_list *list;
@@ -253,7 +249,7 @@ typedef union YYSTYPE {
uniqstr uniqstr; uniqstr uniqstr;
} YYSTYPE; } YYSTYPE;
/* Line 191 of yacc.c. */ /* Line 191 of yacc.c. */
#line 257 "parse-gram.c" #line 253 "../../src/parse-gram.c"
# define yystype YYSTYPE /* obsolescent; will be withdrawn */ # define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1 # define YYSTYPE_IS_DECLARED 1
# define YYSTYPE_IS_TRIVIAL 1 # define YYSTYPE_IS_TRIVIAL 1
@@ -277,7 +273,7 @@ typedef struct YYLTYPE
/* Line 214 of yacc.c. */ /* Line 214 of yacc.c. */
#line 281 "parse-gram.c" #line 277 "../../src/parse-gram.c"
#if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__)
# define YYSIZE_T __SIZE_TYPE__ # define YYSIZE_T __SIZE_TYPE__
@@ -516,14 +512,14 @@ static const yysigned_char yyrhs[] =
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */ /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
static const unsigned short int yyrline[] = static const unsigned short int yyrline[] =
{ {
0, 175, 175, 183, 185, 189, 190, 191, 192, 193, 0, 188, 188, 196, 198, 202, 203, 204, 205, 206,
194, 195, 196, 197, 198, 203, 207, 208, 209, 210, 207, 208, 209, 210, 211, 216, 220, 221, 222, 223,
211, 212, 213, 214, 215, 216, 217, 218, 219, 223, 224, 225, 226, 227, 228, 229, 230, 231, 232, 236,
224, 225, 229, 235, 242, 249, 253, 260, 260, 265, 237, 238, 242, 248, 255, 262, 266, 273, 273, 278,
265, 270, 280, 295, 296, 297, 301, 302, 308, 309, 278, 283, 293, 308, 309, 310, 314, 315, 321, 322,
314, 318, 323, 329, 335, 346, 347, 356, 357, 363, 327, 331, 336, 342, 348, 359, 360, 369, 370, 376,
364, 369, 376, 376, 380, 381, 382, 387, 388, 390, 377, 382, 389, 389, 393, 394, 395, 400, 401, 403,
392, 394, 396, 401, 402, 406, 412, 421, 426, 428 405, 407, 409, 414, 415, 419, 425, 434, 439, 441
}; };
#endif #endif
@@ -1000,6 +996,96 @@ yysymprint (yyoutput, yytype, yyvaluep, yylocationp)
# endif # endif
switch (yytype) switch (yytype)
{ {
case 3: /* "\"string\"" */
#line 165 "../../src/parse-gram.y"
{ fprintf (stderr, "\"%s\"", (yyvaluep->chars)); };
#line 1003 "../../src/parse-gram.c"
break;
case 4: /* "\"integer\"" */
#line 178 "../../src/parse-gram.y"
{ fprintf (stderr, "%d", (yyvaluep->integer)); };
#line 1008 "../../src/parse-gram.c"
break;
case 8: /* "\"%destructor {...}\"" */
#line 167 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1013 "../../src/parse-gram.c"
break;
case 9: /* "\"%printer {...}\"" */
#line 171 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1018 "../../src/parse-gram.c"
break;
case 10: /* "\"%union {...}\"" */
#line 172 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1023 "../../src/parse-gram.c"
break;
case 26: /* "\"%initial-action {...}\"" */
#line 168 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1028 "../../src/parse-gram.c"
break;
case 27: /* "\"%lex-param {...}\"" */
#line 169 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1033 "../../src/parse-gram.c"
break;
case 34: /* "\"%parse-param {...}\"" */
#line 170 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1038 "../../src/parse-gram.c"
break;
case 41: /* "\"type\"" */
#line 176 "../../src/parse-gram.y"
{ fprintf (stderr, "<%s>", (yyvaluep->uniqstr)); };
#line 1043 "../../src/parse-gram.c"
break;
case 45: /* "\"identifier\"" */
#line 180 "../../src/parse-gram.y"
{ fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
#line 1048 "../../src/parse-gram.c"
break;
case 46: /* "\"identifier:\"" */
#line 182 "../../src/parse-gram.y"
{ fprintf (stderr, "%s:", (yyvaluep->symbol)->tag); };
#line 1053 "../../src/parse-gram.c"
break;
case 48: /* "\"%{...%}\"" */
#line 174 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1058 "../../src/parse-gram.c"
break;
case 49: /* "\"epilogue\"" */
#line 174 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1063 "../../src/parse-gram.c"
break;
case 50: /* "\"{...}\"" */
#line 173 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1068 "../../src/parse-gram.c"
break;
case 71: /* "symbol" */
#line 180 "../../src/parse-gram.y"
{ fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
#line 1073 "../../src/parse-gram.c"
break;
case 72: /* "action" */
#line 173 "../../src/parse-gram.y"
{ fprintf (stderr, "{\n%s\n}", (yyvaluep->chars)); };
#line 1078 "../../src/parse-gram.c"
break;
case 73: /* "string_as_id" */
#line 180 "../../src/parse-gram.y"
{ fprintf (stderr, "%s", (yyvaluep->symbol)->tag); };
#line 1083 "../../src/parse-gram.c"
break;
case 74: /* "string_content" */
#line 165 "../../src/parse-gram.y"
{ fprintf (stderr, "\"%s\"", (yyvaluep->chars)); };
#line 1088 "../../src/parse-gram.c"
break;
default: default:
break; break;
} }
@@ -1163,7 +1249,7 @@ YYLTYPE yylloc;
/* User initialization code. */ /* User initialization code. */
#line 72 "parse-gram.y" #line 69 "../../src/parse-gram.y"
{ {
/* Bison's grammar can initial empty locations, hence a default /* Bison's grammar can initial empty locations, hence a default
location is needed. */ location is needed. */
@@ -1172,7 +1258,7 @@ YYLTYPE yylloc;
yylloc.start.column = yylloc.end.column = 0; yylloc.start.column = yylloc.end.column = 0;
} }
/* Line 870 of yacc.c. */ /* Line 870 of yacc.c. */
#line 1176 "parse-gram.c" #line 1262 "../../src/parse-gram.c"
yylsp[0] = yylloc; yylsp[0] = yylloc;
goto yysetstate; goto yysetstate;
@@ -1361,47 +1447,47 @@ yyreduce:
switch (yyn) switch (yyn)
{ {
case 6: case 6:
#line 190 "parse-gram.y" #line 203 "../../src/parse-gram.y"
{ prologue_augment ((yyvsp[0].chars), (yylsp[0])); } { prologue_augment ((yyvsp[0].chars), (yylsp[0])); }
break; break;
case 7: case 7:
#line 191 "parse-gram.y" #line 204 "../../src/parse-gram.y"
{ debug_flag = true; } { debug_flag = true; }
break; break;
case 8: case 8:
#line 192 "parse-gram.y" #line 205 "../../src/parse-gram.y"
{ muscle_insert ((yyvsp[-1].chars), (yyvsp[0].chars)); } { muscle_insert ((yyvsp[-1].chars), (yyvsp[0].chars)); }
break; break;
case 9: case 9:
#line 193 "parse-gram.y" #line 206 "../../src/parse-gram.y"
{ defines_flag = true; } { defines_flag = true; }
break; break;
case 10: case 10:
#line 194 "parse-gram.y" #line 207 "../../src/parse-gram.y"
{ error_verbose = true; } { error_verbose = true; }
break; break;
case 11: case 11:
#line 195 "parse-gram.y" #line 208 "../../src/parse-gram.y"
{ expected_sr_conflicts = (yyvsp[0].integer); } { expected_sr_conflicts = (yyvsp[0].integer); }
break; break;
case 12: case 12:
#line 196 "parse-gram.y" #line 209 "../../src/parse-gram.y"
{ expected_rr_conflicts = (yyvsp[0].integer); } { expected_rr_conflicts = (yyvsp[0].integer); }
break; break;
case 13: case 13:
#line 197 "parse-gram.y" #line 210 "../../src/parse-gram.y"
{ spec_file_prefix = (yyvsp[0].chars); } { spec_file_prefix = (yyvsp[0].chars); }
break; break;
case 14: case 14:
#line 199 "parse-gram.y" #line 212 "../../src/parse-gram.y"
{ {
nondeterministic_parser = true; nondeterministic_parser = true;
glr_parser = true; glr_parser = true;
@@ -1409,81 +1495,81 @@ yyreduce:
break; break;
case 15: case 15:
#line 204 "parse-gram.y" #line 217 "../../src/parse-gram.y"
{ {
muscle_code_grow ("initial_action", (yyvsp[0].chars), (yylsp[0])); muscle_code_grow ("initial_action", (yyvsp[0].chars), (yylsp[0]));
} }
break; break;
case 16: case 16:
#line 207 "parse-gram.y" #line 220 "../../src/parse-gram.y"
{ add_param ("lex_param", (yyvsp[0].chars), (yylsp[0])); } { add_param ("lex_param", (yyvsp[0].chars), (yylsp[0])); }
break; break;
case 17: case 17:
#line 208 "parse-gram.y" #line 221 "../../src/parse-gram.y"
{ locations_flag = true; } { locations_flag = true; }
break; break;
case 18: case 18:
#line 209 "parse-gram.y" #line 222 "../../src/parse-gram.y"
{ spec_name_prefix = (yyvsp[0].chars); } { spec_name_prefix = (yyvsp[0].chars); }
break; break;
case 19: case 19:
#line 210 "parse-gram.y" #line 223 "../../src/parse-gram.y"
{ no_lines_flag = true; } { no_lines_flag = true; }
break; break;
case 20: case 20:
#line 211 "parse-gram.y" #line 224 "../../src/parse-gram.y"
{ nondeterministic_parser = true; } { nondeterministic_parser = true; }
break; break;
case 21: case 21:
#line 212 "parse-gram.y" #line 225 "../../src/parse-gram.y"
{ spec_outfile = (yyvsp[0].chars); } { spec_outfile = (yyvsp[0].chars); }
break; break;
case 22: case 22:
#line 213 "parse-gram.y" #line 226 "../../src/parse-gram.y"
{ add_param ("parse_param", (yyvsp[0].chars), (yylsp[0])); } { add_param ("parse_param", (yyvsp[0].chars), (yylsp[0])); }
break; break;
case 23: case 23:
#line 214 "parse-gram.y" #line 227 "../../src/parse-gram.y"
{ pure_parser = true; } { pure_parser = true; }
break; break;
case 24: case 24:
#line 215 "parse-gram.y" #line 228 "../../src/parse-gram.y"
{ skeleton = (yyvsp[0].chars); } { skeleton = (yyvsp[0].chars); }
break; break;
case 25: case 25:
#line 216 "parse-gram.y" #line 229 "../../src/parse-gram.y"
{ token_table_flag = true; } { token_table_flag = true; }
break; break;
case 26: case 26:
#line 217 "parse-gram.y" #line 230 "../../src/parse-gram.y"
{ report_flag = report_states; } { report_flag = report_states; }
break; break;
case 27: case 27:
#line 218 "parse-gram.y" #line 231 "../../src/parse-gram.y"
{ yacc_flag = true; } { yacc_flag = true; }
break; break;
case 31: case 31:
#line 226 "parse-gram.y" #line 239 "../../src/parse-gram.y"
{ {
grammar_start_symbol_set ((yyvsp[0].symbol), (yylsp[0])); grammar_start_symbol_set ((yyvsp[0].symbol), (yylsp[0]));
} }
break; break;
case 32: case 32:
#line 230 "parse-gram.y" #line 243 "../../src/parse-gram.y"
{ {
typed = true; typed = true;
MUSCLE_INSERT_INT ("stype_line", (yylsp[0]).start.line); MUSCLE_INSERT_INT ("stype_line", (yylsp[0]).start.line);
@@ -1492,7 +1578,7 @@ yyreduce:
break; break;
case 33: case 33:
#line 236 "parse-gram.y" #line 249 "../../src/parse-gram.y"
{ {
symbol_list *list; symbol_list *list;
for (list = (yyvsp[0].list); list; list = list->next) for (list = (yyvsp[0].list); list; list = list->next)
@@ -1502,7 +1588,7 @@ yyreduce:
break; break;
case 34: case 34:
#line 243 "parse-gram.y" #line 256 "../../src/parse-gram.y"
{ {
symbol_list *list; symbol_list *list;
for (list = (yyvsp[0].list); list; list = list->next) for (list = (yyvsp[0].list); list; list = list->next)
@@ -1512,26 +1598,26 @@ yyreduce:
break; break;
case 35: case 35:
#line 250 "parse-gram.y" #line 263 "../../src/parse-gram.y"
{ {
default_prec = true; default_prec = true;
} }
break; break;
case 36: case 36:
#line 254 "parse-gram.y" #line 267 "../../src/parse-gram.y"
{ {
default_prec = false; default_prec = false;
} }
break; break;
case 37: case 37:
#line 260 "parse-gram.y" #line 273 "../../src/parse-gram.y"
{ current_class = nterm_sym; } { current_class = nterm_sym; }
break; break;
case 38: case 38:
#line 261 "parse-gram.y" #line 274 "../../src/parse-gram.y"
{ {
current_class = unknown_sym; current_class = unknown_sym;
current_type = NULL; current_type = NULL;
@@ -1539,12 +1625,12 @@ yyreduce:
break; break;
case 39: case 39:
#line 265 "parse-gram.y" #line 278 "../../src/parse-gram.y"
{ current_class = token_sym; } { current_class = token_sym; }
break; break;
case 40: case 40:
#line 266 "parse-gram.y" #line 279 "../../src/parse-gram.y"
{ {
current_class = unknown_sym; current_class = unknown_sym;
current_type = NULL; current_type = NULL;
@@ -1552,7 +1638,7 @@ yyreduce:
break; break;
case 41: case 41:
#line 271 "parse-gram.y" #line 284 "../../src/parse-gram.y"
{ {
symbol_list *list; symbol_list *list;
for (list = (yyvsp[0].list); list; list = list->next) for (list = (yyvsp[0].list); list; list = list->next)
@@ -1562,7 +1648,7 @@ yyreduce:
break; break;
case 42: case 42:
#line 281 "parse-gram.y" #line 294 "../../src/parse-gram.y"
{ {
symbol_list *list; symbol_list *list;
++current_prec; ++current_prec;
@@ -1577,49 +1663,49 @@ yyreduce:
break; break;
case 43: case 43:
#line 295 "parse-gram.y" #line 308 "../../src/parse-gram.y"
{ (yyval.assoc) = left_assoc; } { (yyval.assoc) = left_assoc; }
break; break;
case 44: case 44:
#line 296 "parse-gram.y" #line 309 "../../src/parse-gram.y"
{ (yyval.assoc) = right_assoc; } { (yyval.assoc) = right_assoc; }
break; break;
case 45: case 45:
#line 297 "parse-gram.y" #line 310 "../../src/parse-gram.y"
{ (yyval.assoc) = non_assoc; } { (yyval.assoc) = non_assoc; }
break; break;
case 46: case 46:
#line 301 "parse-gram.y" #line 314 "../../src/parse-gram.y"
{ current_type = NULL; } { current_type = NULL; }
break; break;
case 47: case 47:
#line 302 "parse-gram.y" #line 315 "../../src/parse-gram.y"
{ current_type = (yyvsp[0].uniqstr); } { current_type = (yyvsp[0].uniqstr); }
break; break;
case 48: case 48:
#line 308 "parse-gram.y" #line 321 "../../src/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 49: case 49:
#line 309 "parse-gram.y" #line 322 "../../src/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 50: case 50:
#line 315 "parse-gram.y" #line 328 "../../src/parse-gram.y"
{ {
current_type = (yyvsp[0].uniqstr); current_type = (yyvsp[0].uniqstr);
} }
break; break;
case 51: case 51:
#line 319 "parse-gram.y" #line 332 "../../src/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]));
@@ -1627,7 +1713,7 @@ yyreduce:
break; break;
case 52: case 52:
#line 324 "parse-gram.y" #line 337 "../../src/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]));
@@ -1636,7 +1722,7 @@ yyreduce:
break; break;
case 53: case 53:
#line 330 "parse-gram.y" #line 343 "../../src/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]));
@@ -1645,7 +1731,7 @@ yyreduce:
break; break;
case 54: case 54:
#line 336 "parse-gram.y" #line 349 "../../src/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]));
@@ -1655,7 +1741,7 @@ yyreduce:
break; break;
case 60: case 60:
#line 365 "parse-gram.y" #line 378 "../../src/parse-gram.y"
{ {
if (yacc_flag) if (yacc_flag)
complain_at ((yyloc), _("POSIX forbids declarations in the grammar")); complain_at ((yyloc), _("POSIX forbids declarations in the grammar"));
@@ -1663,74 +1749,74 @@ yyreduce:
break; break;
case 61: case 61:
#line 370 "parse-gram.y" #line 383 "../../src/parse-gram.y"
{ {
yyerrok; yyerrok;
} }
break; break;
case 62: case 62:
#line 376 "parse-gram.y" #line 389 "../../src/parse-gram.y"
{ current_lhs = (yyvsp[0].symbol); current_lhs_location = (yylsp[0]); } { current_lhs = (yyvsp[0].symbol); current_lhs_location = (yylsp[0]); }
break; break;
case 64: case 64:
#line 380 "parse-gram.y" #line 393 "../../src/parse-gram.y"
{ grammar_rule_end ((yylsp[0])); } { grammar_rule_end ((yylsp[0])); }
break; break;
case 65: case 65:
#line 381 "parse-gram.y" #line 394 "../../src/parse-gram.y"
{ grammar_rule_end ((yylsp[0])); } { grammar_rule_end ((yylsp[0])); }
break; break;
case 67: case 67:
#line 387 "parse-gram.y" #line 400 "../../src/parse-gram.y"
{ grammar_rule_begin (current_lhs, current_lhs_location); } { grammar_rule_begin (current_lhs, current_lhs_location); }
break; break;
case 68: case 68:
#line 389 "parse-gram.y" #line 402 "../../src/parse-gram.y"
{ grammar_current_rule_symbol_append ((yyvsp[0].symbol), (yylsp[0])); } { grammar_current_rule_symbol_append ((yyvsp[0].symbol), (yylsp[0])); }
break; break;
case 69: case 69:
#line 391 "parse-gram.y" #line 404 "../../src/parse-gram.y"
{ grammar_current_rule_action_append ((yyvsp[0].chars), (yylsp[0])); } { grammar_current_rule_action_append ((yyvsp[0].chars), (yylsp[0])); }
break; break;
case 70: case 70:
#line 393 "parse-gram.y" #line 406 "../../src/parse-gram.y"
{ grammar_current_rule_prec_set ((yyvsp[0].symbol), (yylsp[0])); } { grammar_current_rule_prec_set ((yyvsp[0].symbol), (yylsp[0])); }
break; break;
case 71: case 71:
#line 395 "parse-gram.y" #line 408 "../../src/parse-gram.y"
{ grammar_current_rule_dprec_set ((yyvsp[0].integer), (yylsp[0])); } { grammar_current_rule_dprec_set ((yyvsp[0].integer), (yylsp[0])); }
break; break;
case 72: case 72:
#line 397 "parse-gram.y" #line 410 "../../src/parse-gram.y"
{ grammar_current_rule_merge_set ((yyvsp[0].uniqstr), (yylsp[0])); } { grammar_current_rule_merge_set ((yyvsp[0].uniqstr), (yylsp[0])); }
break; break;
case 73: case 73:
#line 401 "parse-gram.y" #line 414 "../../src/parse-gram.y"
{ (yyval.symbol) = (yyvsp[0].symbol); } { (yyval.symbol) = (yyvsp[0].symbol); }
break; break;
case 74: case 74:
#line 402 "parse-gram.y" #line 415 "../../src/parse-gram.y"
{ (yyval.symbol) = (yyvsp[0].symbol); } { (yyval.symbol) = (yyvsp[0].symbol); }
break; break;
case 75: case 75:
#line 407 "parse-gram.y" #line 420 "../../src/parse-gram.y"
{ (yyval.chars) = (yyvsp[0].chars); } { (yyval.chars) = (yyvsp[0].chars); }
break; break;
case 76: case 76:
#line 413 "parse-gram.y" #line 426 "../../src/parse-gram.y"
{ {
(yyval.symbol) = symbol_get (quotearg_style (c_quoting_style, (yyvsp[0].chars)), (yylsp[0])); (yyval.symbol) = symbol_get (quotearg_style (c_quoting_style, (yyvsp[0].chars)), (yylsp[0]));
symbol_class_set ((yyval.symbol), token_sym, (yylsp[0])); symbol_class_set ((yyval.symbol), token_sym, (yylsp[0]));
@@ -1738,12 +1824,12 @@ yyreduce:
break; break;
case 77: case 77:
#line 422 "parse-gram.y" #line 435 "../../src/parse-gram.y"
{ (yyval.chars) = (yyvsp[0].chars); } { (yyval.chars) = (yyvsp[0].chars); }
break; break;
case 79: case 79:
#line 429 "parse-gram.y" #line 442 "../../src/parse-gram.y"
{ {
muscle_code_grow ("epilogue", (yyvsp[0].chars), (yylsp[0])); muscle_code_grow ("epilogue", (yyvsp[0].chars), (yylsp[0]));
scanner_last_string_free (); scanner_last_string_free ();
@@ -1755,7 +1841,7 @@ yyreduce:
} }
/* Line 1066 of yacc.c. */ /* Line 1066 of yacc.c. */
#line 1759 "parse-gram.c" #line 1845 "../../src/parse-gram.c"
yyvsp -= yylen; yyvsp -= yylen;
yyssp -= yylen; yyssp -= yylen;
@@ -2032,7 +2118,7 @@ yyreturn:
} }
#line 435 "parse-gram.y" #line 448 "../../src/parse-gram.y"
@@ -2117,49 +2203,6 @@ add_param (char const *type, char *decl, location loc)
scanner_last_string_free (); scanner_last_string_free ();
} }
/*----------------------------------------------------.
| When debugging the parser, display tokens' values. |
`----------------------------------------------------*/
static void
print_token_value (FILE *file, int type, YYSTYPE const *value)
{
fputc (' ', file);
switch (type)
{
case ID:
fprintf (file, " = %s", value->symbol->tag);
break;
case INT:
fprintf (file, " = %d", value->integer);
break;
case STRING:
fprintf (file, " = \"%s\"", value->chars);
break;
case TYPE:
fprintf (file, " = <%s>", value->uniqstr);
break;
case BRACED_CODE:
case PERCENT_DESTRUCTOR:
case PERCENT_LEX_PARAM:
case PERCENT_PARSE_PARAM:
case PERCENT_PRINTER:
case PERCENT_UNION:
case PROLOGUE:
case EPILOGUE:
fprintf (file, " = {{ %s }}", value->chars);
break;
default:
fprintf (file, "unknown token type");
break;
}
}
static void static void
gram_error (location const *loc, char const *msg) gram_error (location const *loc, char const *msg)
{ {

View File

@@ -134,7 +134,7 @@
#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED) #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
#line 82 "parse-gram.y" #line 79 "../../src/parse-gram.y"
typedef union YYSTYPE { typedef union YYSTYPE {
symbol *symbol; symbol *symbol;
symbol_list *list; symbol_list *list;
@@ -144,7 +144,7 @@ typedef union YYSTYPE {
uniqstr uniqstr; uniqstr uniqstr;
} YYSTYPE; } YYSTYPE;
/* Line 1389 of yacc.c. */ /* Line 1389 of yacc.c. */
#line 148 "parse-gram.h" #line 148 "../../src/parse-gram.h"
# define yystype YYSTYPE /* obsolescent; will be withdrawn */ # define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1 # define YYSTYPE_IS_DECLARED 1
# define YYSTYPE_IS_TRIVIAL 1 # define YYSTYPE_IS_TRIVIAL 1

View File

@@ -46,10 +46,6 @@ static YYLTYPE lloc_default (YYLTYPE const *, int);
gram_error (&yylloc, Msg) gram_error (&yylloc, Msg)
static void gram_error (location const *, char const *); static void gram_error (location const *, char const *);
#define YYPRINT(File, Type, Value) \
print_token_value (File, Type, &Value)
static void print_token_value (FILE *, int, YYSTYPE const *);
static void add_param (char const *, char *, location); static void add_param (char const *, char *, location);
symbol_class current_class = unknown_sym; symbol_class current_class = unknown_sym;
@@ -61,6 +57,7 @@ int current_prec = 0;
%} %}
%debug %debug
%verbose
%defines %defines
%locations %locations
%pure-parser %pure-parser
@@ -164,9 +161,25 @@ int current_prec = 0;
"%union {...}" "%union {...}"
BRACED_CODE action BRACED_CODE action
PROLOGUE EPILOGUE PROLOGUE EPILOGUE
%printer { fprintf (stderr, "\"%s\"", $$); }
STRING string_content
%printer { fprintf (stderr, "{\n%s\n}", $$); }
"%destructor {...}"
"%initial-action {...}"
"%lex-param {...}"
"%parse-param {...}"
"%printer {...}"
"%union {...}"
BRACED_CODE action
PROLOGUE EPILOGUE
%type <uniqstr> TYPE %type <uniqstr> TYPE
%printer { fprintf (stderr, "<%s>", $$); } TYPE
%type <integer> INT %type <integer> INT
%type <symbol> ID ID_COLON symbol string_as_id %printer { fprintf (stderr, "%d", $$); } INT
%type <symbol> ID symbol string_as_id
%printer { fprintf (stderr, "%s", $$->tag); } ID symbol string_as_id
%type <symbol> ID_COLON
%printer { fprintf (stderr, "%s:", $$->tag); } ID_COLON
%type <assoc> precedence_declarator %type <assoc> precedence_declarator
%type <list> symbols.1 %type <list> symbols.1
%% %%
@@ -516,49 +529,6 @@ add_param (char const *type, char *decl, location loc)
scanner_last_string_free (); scanner_last_string_free ();
} }
/*----------------------------------------------------.
| When debugging the parser, display tokens' values. |
`----------------------------------------------------*/
static void
print_token_value (FILE *file, int type, YYSTYPE const *value)
{
fputc (' ', file);
switch (type)
{
case ID:
fprintf (file, " = %s", value->symbol->tag);
break;
case INT:
fprintf (file, " = %d", value->integer);
break;
case STRING:
fprintf (file, " = \"%s\"", value->chars);
break;
case TYPE:
fprintf (file, " = <%s>", value->uniqstr);
break;
case BRACED_CODE:
case PERCENT_DESTRUCTOR:
case PERCENT_LEX_PARAM:
case PERCENT_PARSE_PARAM:
case PERCENT_PRINTER:
case PERCENT_UNION:
case PROLOGUE:
case EPILOGUE:
fprintf (file, " = {{ %s }}", value->chars);
break;
default:
fprintf (file, "unknown token type");
break;
}
}
static void static void
gram_error (location const *loc, char const *msg) gram_error (location const *loc, char const *msg)
{ {