mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-17 00:03:03 +00:00
* data/glr.c (yyresolveValue): Fix redundant parse tree problem
reported by Joel E. Denny in <http://lists.gnu.org/archive/html/bison-patches/2005-08/msg00004.html> (trivial change). * tests/glr-regression.at (Duplicate representation of merged trees): New test, from Joel E. Denny in: <http://lists.gnu.org/archive/html/help-bison/2005-07/msg00013.html>. * THANKS: Add Joel E. Denny.
This commit is contained in:
13
ChangeLog
13
ChangeLog
@@ -1,3 +1,16 @@
|
|||||||
|
2005-08-21 Paul Eggert <eggert@cs.ucla.edu>
|
||||||
|
|
||||||
|
* data/glr.c (yyresolveValue): Fix redundant parse tree problem
|
||||||
|
reported by Joel E. Denny in
|
||||||
|
<http://lists.gnu.org/archive/html/bison-patches/2005-08/msg00004.html>
|
||||||
|
(trivial change).
|
||||||
|
* tests/glr-regression.at (Duplicate representation of merged trees):
|
||||||
|
New test, from Joel E. Denny in:
|
||||||
|
<http://lists.gnu.org/archive/html/help-bison/2005-07/msg00013.html>.
|
||||||
|
* THANKS: Add Joel E. Denny.
|
||||||
|
|
||||||
|
* configure.ac (AC_INIT): Bump to 2.0c.
|
||||||
|
|
||||||
2005-07-24 Paul Eggert <eggert@cs.ucla.edu>
|
2005-07-24 Paul Eggert <eggert@cs.ucla.edu>
|
||||||
|
|
||||||
* NEWS: Version 2.0b.
|
* NEWS: Version 2.0b.
|
||||||
|
|||||||
1
THANKS
1
THANKS
@@ -34,6 +34,7 @@ Jan Nieuwenhuizen janneke@gnu.org
|
|||||||
Jesse Thilo jthilo@gnu.org
|
Jesse Thilo jthilo@gnu.org
|
||||||
Jim Kent jkent@arch.sel.sony.com
|
Jim Kent jkent@arch.sel.sony.com
|
||||||
Jim Meyering jim@meyering.net
|
Jim Meyering jim@meyering.net
|
||||||
|
Joel E. Denny jdenny@hubcap.clemson.edu
|
||||||
Juan Manuel Guerrero ST001906@HRZ1.HRZ.TU-Darmstadt.De
|
Juan Manuel Guerrero ST001906@HRZ1.HRZ.TU-Darmstadt.De
|
||||||
Kees Zeelenberg kzlg@users.sourceforge.net
|
Kees Zeelenberg kzlg@users.sourceforge.net
|
||||||
Keith Browne kbrowne@legato.com
|
Keith Browne kbrowne@legato.com
|
||||||
|
|||||||
45
data/glr.c
45
data/glr.c
@@ -1606,35 +1606,44 @@ yyresolveValue (yySemanticOption* yyoptionList, yyGLRStack* yystack,
|
|||||||
YYSTYPE* yyvalp, YYLTYPE* yylocp]b4_user_formals[)
|
YYSTYPE* yyvalp, YYLTYPE* yylocp]b4_user_formals[)
|
||||||
{
|
{
|
||||||
yySemanticOption* yybest;
|
yySemanticOption* yybest;
|
||||||
yySemanticOption* yyp;
|
yySemanticOption** yypp;
|
||||||
yybool yymerge;
|
yybool yymerge;
|
||||||
|
|
||||||
yybest = yyoptionList;
|
yybest = yyoptionList;
|
||||||
yymerge = yyfalse;
|
yymerge = yyfalse;
|
||||||
for (yyp = yyoptionList->yynext; yyp != NULL; yyp = yyp->yynext)
|
for (yypp = &yyoptionList->yynext; *yypp != NULL; )
|
||||||
{
|
{
|
||||||
|
yySemanticOption* yyp = *yypp;
|
||||||
|
|
||||||
if (yyidenticalOptions (yybest, yyp))
|
if (yyidenticalOptions (yybest, yyp))
|
||||||
yymergeOptionSets (yybest, yyp);
|
{
|
||||||
|
yymergeOptionSets (yybest, yyp);
|
||||||
|
*yypp = yyp->yynext;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
switch (yypreference (yybest, yyp))
|
{
|
||||||
{
|
switch (yypreference (yybest, yyp))
|
||||||
case 0:
|
{
|
||||||
yyreportAmbiguity (yybest, yyp, yystack]b4_pure_args[);
|
case 0:
|
||||||
break;
|
yyreportAmbiguity (yybest, yyp, yystack]b4_pure_args[);
|
||||||
case 1:
|
break;
|
||||||
yymerge = yytrue;
|
case 1:
|
||||||
break;
|
yymerge = yytrue;
|
||||||
case 2:
|
break;
|
||||||
break;
|
case 2:
|
||||||
case 3:
|
break;
|
||||||
yybest = yyp;
|
case 3:
|
||||||
yymerge = yyfalse;
|
yybest = yyp;
|
||||||
break;
|
yymerge = yyfalse;
|
||||||
}
|
break;
|
||||||
|
}
|
||||||
|
yypp = &yyp->yynext;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (yymerge)
|
if (yymerge)
|
||||||
{
|
{
|
||||||
|
yySemanticOption* yyp;
|
||||||
int yyprec = yydprec[yybest->yyrule];
|
int yyprec = yydprec[yybest->yyrule];
|
||||||
YYCHK (yyresolveAction (yybest, yystack, yyvalp, yylocp]b4_user_args[));
|
YYCHK (yyresolveAction (yybest, yystack, yyvalp, yylocp]b4_user_args[));
|
||||||
for (yyp = yybest->yynext; yyp != NULL; yyp = yyp->yynext)
|
for (yyp = yybest->yynext; yyp != NULL; yyp = yyp->yynext)
|
||||||
|
|||||||
@@ -327,3 +327,96 @@ AT_CHECK([[echo p1 t4 o2 p1 p1 t1 o1 t2 p2 o1 t3 p2 p2 | ./glr-regr3]], 0,
|
|||||||
]], [])
|
]], [])
|
||||||
|
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
|
|
||||||
|
|
||||||
|
## ---------------------------------------------------------------------- ##
|
||||||
|
## Duplicate representation of merged trees ##
|
||||||
|
## Thanks to Joel E. Denny for this test; see ##
|
||||||
|
## <http://lists.gnu.org/archive/html/help-bison/2005-07/msg00013.html>. ##
|
||||||
|
## ---------------------------------------------------------------------- ##
|
||||||
|
|
||||||
|
AT_SETUP([Duplicate representation of merged trees])
|
||||||
|
|
||||||
|
AT_DATA_GRAMMAR([glr-regr4.y],
|
||||||
|
[[%union { char *ptr; }
|
||||||
|
%type <ptr> S A A1 A2 B
|
||||||
|
%glr-parser
|
||||||
|
|
||||||
|
%{
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char *merge (YYSTYPE, YYSTYPE);
|
||||||
|
static char *make_value (char *, char *);
|
||||||
|
static void yyerror (char const *);
|
||||||
|
static int yylex (void);
|
||||||
|
%}
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
tree: S { printf ("%s\n", $1); } ;
|
||||||
|
|
||||||
|
S:
|
||||||
|
A %merge<merge> { $$ = make_value ("S", $1); }
|
||||||
|
| B %merge<merge> { $$ = make_value ("S", $1); }
|
||||||
|
;
|
||||||
|
|
||||||
|
A:
|
||||||
|
A1 %merge<merge> { $$ = make_value ("A", $1); }
|
||||||
|
| A2 %merge<merge> { $$ = make_value ("A", $1); }
|
||||||
|
;
|
||||||
|
|
||||||
|
A1: 'a' { $$ = make_value ("A1", "'a'"); } ;
|
||||||
|
A2: 'a' { $$ = make_value ("A2", "'a'"); } ;
|
||||||
|
B: 'a' { $$ = make_value ("B", "'a'"); } ;
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
static int
|
||||||
|
yylex (void)
|
||||||
|
{
|
||||||
|
static char const *input = "a";
|
||||||
|
return *input++;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main (void)
|
||||||
|
{
|
||||||
|
return yyparse ();
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
make_value (char *parent, char *child)
|
||||||
|
{
|
||||||
|
char const format[] = "%s <- %s";
|
||||||
|
char *value = malloc (strlen (parent) + strlen (child) + sizeof format);
|
||||||
|
sprintf (value, format, parent, child);
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
merge (YYSTYPE s1, YYSTYPE s2)
|
||||||
|
{
|
||||||
|
char const format[] = "merge{ %s and %s }";
|
||||||
|
char *value = malloc (strlen (s1.ptr) + strlen (s2.ptr) + sizeof format);
|
||||||
|
sprintf (value, format, s1.ptr, s2.ptr);
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
yyerror (char const *msg)
|
||||||
|
{
|
||||||
|
printf ("%s\n", msg);
|
||||||
|
}
|
||||||
|
]])
|
||||||
|
|
||||||
|
AT_CHECK([[bison -o glr-regr4.c glr-regr4.y]], 0, [],
|
||||||
|
[glr-regr4.y: conflicts: 1 reduce/reduce
|
||||||
|
])
|
||||||
|
AT_COMPILE([glr-regr4])
|
||||||
|
|
||||||
|
AT_CHECK([[./glr-regr4]], 0,
|
||||||
|
[[merge{ S <- merge{ A <- A1 <- 'a' and A <- A2 <- 'a' } and S <- B <- 'a' }
|
||||||
|
]], [])
|
||||||
|
|
||||||
|
AT_CLEANUP
|
||||||
|
|||||||
Reference in New Issue
Block a user