Hans Åberg wrote:

> > On 29 Jun 2017, at 15:55, Piotr Marcinczyk <piomar...@gmail.com> wrote:
> > 
> > I supposedly found a bug in lalr1.cc skeleton with variant semantic type.
> You might check if std::variant, of C++17, can be used instead. Cf.
>   http://en.cppreference.com/w/cpp/utility/variant
> > When using mid-rule action { $<type>$ = value; } to return a value that
> > will be used in further semantic actions, it appears that the value on
> > stack becomes zero. Tested with Bison version 3.0.4.

This answer may come a bit late, but I had the same problem (and
others) recently, so I wrote a new Bison skeleton using std::variant
which, as Hans said, solves this problem.

You can find it here:


To use the new skeleton, change in parser.y:

-%skeleton "lalr1.cc"
+%skeleton "lalr1-c++17.cc"

Since tokens are now of std::variant type, compiling requires C++17,
e.g. gcc-7 with "--std=c++17" option, and tokens are built a bit
differently, so change in lexer.flex (or use make_int):

-                yylval->build(atoi(yytext));
+                yylval->emplace<int>(atoi(yytext));


Reply via email to