mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-21 02:03:03 +00:00
* tests/actions.at (Destructors): Augment to test locations.
* data/bison.simple (yydestructor): Pass it the current location if locations are enabled. Prototype only when __STDC__ or C++. Change the argument names to move into the yy name space: there is user code here.
This commit is contained in:
@@ -1,3 +1,12 @@
|
|||||||
|
2002-06-19 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
|
* tests/actions.at (Destructors): Augment to test locations.
|
||||||
|
* data/bison.simple (yydestructor): Pass it the current location
|
||||||
|
if locations are enabled.
|
||||||
|
Prototype only when __STDC__ or C++.
|
||||||
|
Change the argument names to move into the yy name space: there is
|
||||||
|
user code here.
|
||||||
|
|
||||||
2002-06-19 Akim Demaille <akim@epita.fr>
|
2002-06-19 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
* data/bison.simple (b4_pure_if): New.
|
* data/bison.simple (b4_pure_if): New.
|
||||||
|
|||||||
@@ -667,7 +667,11 @@ int yyparse (void *);
|
|||||||
int yyparse (void);
|
int yyparse (void);
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
static void yydestructor (int symbol_type, YYSTYPE symbol_value);
|
|
||||||
|
#if defined (__STDC__) || defined (__cplusplus)
|
||||||
|
static void yydestructor (int yytype,
|
||||||
|
YYSTYPE yyvalue[]b4_location_if([, YYLTYPE yylocation]));
|
||||||
|
#endif
|
||||||
|
|
||||||
m4_divert_push([KILL])# ======================== M4 code.
|
m4_divert_push([KILL])# ======================== M4 code.
|
||||||
# b4_declare_parser_variables
|
# b4_declare_parser_variables
|
||||||
@@ -1126,7 +1130,7 @@ yyerrlab1:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
yydestructor (yystos[*yyssp], *yyvsp);
|
yydestructor (yystos[*yyssp], *yyvsp]b4_location_if([, *yylsp])[);
|
||||||
YYPOPSTACK;
|
YYPOPSTACK;
|
||||||
}
|
}
|
||||||
YYABORT;
|
YYABORT;
|
||||||
@@ -1134,7 +1138,7 @@ yyerrlab1:
|
|||||||
|
|
||||||
YYDPRINTF ((stderr, "Discarding token %d (%s).\n",
|
YYDPRINTF ((stderr, "Discarding token %d (%s).\n",
|
||||||
yychar, yytname[yychar1]));
|
yychar, yytname[yychar1]));
|
||||||
yydestructor (yychar1, yylval);
|
yydestructor (yychar1, yylval]b4_location_if([, yylloc])[);
|
||||||
yychar = YYEMPTY;
|
yychar = YYEMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1181,7 +1185,7 @@ yyerrlab1:
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
yydestructor (yystos[yystate], *yyvsp);
|
yydestructor (yystos[yystate], *yyvsp]b4_location_if([, *yylsp])[);
|
||||||
yyvsp--;
|
yyvsp--;
|
||||||
yystate = *--yyssp;
|
yystate = *--yyssp;
|
||||||
]b4_location_if([ yylsp--;])[
|
]b4_location_if([ yylsp--;])[
|
||||||
@@ -1251,24 +1255,27 @@ m4_divert_push([KILL])# M4 code.
|
|||||||
# b4_symbol_destructor(SYMBOL-NUMBER, DESTRUCTOR, TYPE-NAME)
|
# b4_symbol_destructor(SYMBOL-NUMBER, DESTRUCTOR, TYPE-NAME)
|
||||||
# ----------------------------------------------------------
|
# ----------------------------------------------------------
|
||||||
m4_define([b4_symbol_destructor],
|
m4_define([b4_symbol_destructor],
|
||||||
[m4_pushdef([b4_dollar_dollar], [symbol_value.$6])dnl
|
[m4_pushdef([b4_dollar_dollar], [yyvalue.$6])dnl
|
||||||
|
m4_pushdef([b4_at_dollar], [yylocation])dnl
|
||||||
case $4: /* $3 */
|
case $4: /* $3 */
|
||||||
#line $2 "$1"
|
#line $2 "$1"
|
||||||
$5;
|
$5;
|
||||||
#line __oline__ "__ofile__"
|
#line __oline__ "__ofile__"
|
||||||
break;
|
break;
|
||||||
|
m4_popdef([b4_at_dollar])dnl
|
||||||
m4_popdef([b4_dollar_dollar])])
|
m4_popdef([b4_dollar_dollar])])
|
||||||
|
|
||||||
m4_divert_pop([KILL])dnl# End of M4 code.
|
m4_divert_pop([KILL])dnl# End of M4 code.
|
||||||
static void
|
static void
|
||||||
yydestructor (int symbol_type, YYSTYPE symbol_value)
|
yydestructor (int yytype,
|
||||||
|
YYSTYPE yyvalue[]b4_location_if([, YYLTYPE yylocation]))
|
||||||
{
|
{
|
||||||
switch (symbol_type)
|
switch (yytype)
|
||||||
{
|
{
|
||||||
m4_map([b4_symbol_destructor], m4_defn([b4_symbol_destructors]))dnl
|
m4_map([b4_symbol_destructor], m4_defn([b4_symbol_destructors]))dnl
|
||||||
default:
|
default:
|
||||||
YYDPRINTF ((stderr, "yydestructor: unknown symbol type: %d (%s)\n",
|
YYDPRINTF ((stderr, "yydestructor: unknown symbol type: %d (%s)\n",
|
||||||
symbol_type, yytname[[symbol_type]]));
|
yytype, yytname[[yytype]]));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -177,10 +177,10 @@ AT_DATA([[input.y]],
|
|||||||
int ival;
|
int ival;
|
||||||
}
|
}
|
||||||
%type <ival> 'x' thing line input
|
%type <ival> 'x' thing line input
|
||||||
%destructor { printf ("Freeing input %d\n", $$); } input
|
%destructor { printf ("Freeing input %d from %d\n", $$, @$.first_line); } input
|
||||||
%destructor { printf ("Freeing line %d\n", $$); } line
|
%destructor { printf ("Freeing line %d from %d\n", $$, @$.first_line); } line
|
||||||
%destructor { printf ("Freeing thing %d\n", $$); } thing
|
%destructor { printf ("Freeing thing %d from %d\n", $$, @$.first_line); } thing
|
||||||
%destructor { printf ("Freeing 'x' %d\n", $$); } 'x'
|
%destructor { printf ("Freeing 'x' %d from %d\n", $$, @$.first_line); } 'x'
|
||||||
|
|
||||||
%{
|
%{
|
||||||
static int yylex (void);
|
static int yylex (void);
|
||||||
@@ -256,6 +256,8 @@ yylex (void)
|
|||||||
{
|
{
|
||||||
yylval.ival = counter;
|
yylval.ival = counter;
|
||||||
printf ("sending: '%c'(%d)\n", input[counter], counter);
|
printf ("sending: '%c'(%d)\n", input[counter], counter);
|
||||||
|
/* As in BASIC, line numbers go from 10 to 10. */
|
||||||
|
yylloc.first_line = 10 * counter;
|
||||||
return input[counter++];
|
return input[counter++];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -268,7 +270,7 @@ yylex (void)
|
|||||||
static void
|
static void
|
||||||
yyerror (const char *msg)
|
yyerror (const char *msg)
|
||||||
{
|
{
|
||||||
fprintf (stdout, "%s\n", msg);
|
fprintf (stdout, "%d: %s\n", yylloc.first_line, msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -291,7 +293,7 @@ main (void)
|
|||||||
}
|
}
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_CHECK([bison input.y -d -v -o input.c])
|
AT_CHECK([bison input.y --location -d -v -o input.c])
|
||||||
AT_CHECK([$CC $CFLAGS $CPPFLAGS input.c -o input], 0, [], [ignore])
|
AT_CHECK([$CC $CFLAGS $CPPFLAGS input.c -o input], 0, [], [ignore])
|
||||||
AT_CHECK([./input], 1,
|
AT_CHECK([./input], 1,
|
||||||
[[sending: 'x'(0)
|
[[sending: 'x'(0)
|
||||||
@@ -301,15 +303,15 @@ thing(1): 'x'(1)
|
|||||||
sending: 'x'(2)
|
sending: 'x'(2)
|
||||||
thing(2): 'x'(2)
|
thing(2): 'x'(2)
|
||||||
sending: 'x'(3)
|
sending: 'x'(3)
|
||||||
parse error, unexpected 'x', expecting ';'
|
30: parse error, unexpected 'x', expecting ';'
|
||||||
Freeing thing 2
|
Freeing thing 2 from 20
|
||||||
Freeing thing 1
|
Freeing thing 1 from 10
|
||||||
Freeing thing 0
|
Freeing thing 0 from 0
|
||||||
Freeing 'x' 3
|
Freeing 'x' 3 from 30
|
||||||
sending: 'x'(4)
|
sending: 'x'(4)
|
||||||
Freeing 'x' 4
|
Freeing 'x' 4 from 40
|
||||||
sending: 'x'(5)
|
sending: 'x'(5)
|
||||||
Freeing 'x' 5
|
Freeing 'x' 5 from 50
|
||||||
sending: ';'(6)
|
sending: ';'(6)
|
||||||
line(-1): error ';'
|
line(-1): error ';'
|
||||||
sending: 'x'(7)
|
sending: 'x'(7)
|
||||||
@@ -323,11 +325,11 @@ thing(10): 'x'(10)
|
|||||||
sending: ';'(11)
|
sending: ';'(11)
|
||||||
line(10): thing(10) ';'
|
line(10): thing(10) ';'
|
||||||
sending: 'y'(12)
|
sending: 'y'(12)
|
||||||
parse error, unexpected $undefined., expecting $ or error or 'x'
|
120: parse error, unexpected $undefined., expecting $ or error or 'x'
|
||||||
sending: EOF
|
sending: EOF
|
||||||
Freeing line 10
|
Freeing line 10 from 100
|
||||||
Freeing line 7
|
Freeing line 7 from 70
|
||||||
Freeing line -1
|
Freeing line -1 from 50
|
||||||
Parsing FAILED.
|
Parsing FAILED.
|
||||||
]])
|
]])
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user