]> git.saurik.com Git - bison.git/commitdiff
Update variant.yy to newest interface.
authorAkim Demaille <demaille@gostai.com>
Wed, 22 Oct 2008 11:27:42 +0000 (06:27 -0500)
committerAkim Demaille <demaille@gostai.com>
Sat, 15 Nov 2008 10:29:57 +0000 (11:29 +0100)
* examples/variant.yy: Define lex_symbol.
Adjust.

ChangeLog
examples/variant.yy

index 2c0343d6616e3aa6e434fe28db4d7a89444241c8..bd530d5b472c8a1484a808f6f75442c164ca247a 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2008-11-15  Akim Demaille  <demaille@gostai.com>
+
+       Update variant.yy to newest interface.
+       * examples/variant.yy: Define lex_symbol.
+       Adjust.
+
 2008-11-15  Akim Demaille  <demaille@gostai.com>
 
        Don't use locations in variant.yy.
 2008-11-15  Akim Demaille  <demaille@gostai.com>
 
        Don't use locations in variant.yy.
index b1987cd2fdbd12b972c8af563bace7f2e57b92ff..016c4b2ad07d3c4a6a20d5fd138a3cb30cc04b86 100644 (file)
@@ -1,9 +1,8 @@
-/* Test file for C++ parsers using variants.
-   Based on an example by Michiel De Wilde <mdewilde.agilent@gmail.com>. */
 %debug
 %skeleton "lalr1.cc"
 %defines
 %define variant
 %debug
 %skeleton "lalr1.cc"
 %defines
 %define variant
+%define lex_symbol
 
 %code requires // *.hh
 {
 
 %code requires // *.hh
 {
@@ -20,17 +19,17 @@ typedef std::list<std::string> strings_type;
 #include <sstream>
 
   // Prototype of the yylex function providing subsequent tokens.
 #include <sstream>
 
   // Prototype of the yylex function providing subsequent tokens.
-  static yy::parser::token_type yylex(yy::parser::semantic_type* yylval);
+  static yy::parser::symbol_type yylex ();
 
   // Printing a list of strings.
   // Koening look up will look into std, since that's an std::list.
   namespace std
   {
     std::ostream&
 
   // Printing a list of strings.
   // Koening look up will look into std, since that's an std::list.
   namespace std
   {
     std::ostream&
-    operator<<(std::ostream& o, const strings_type& s)
+    operator<< (std::ostream& o, const strings_type& s)
     {
     {
-      std::copy(s.begin(), s.end(),
-                std::ostream_iterator<strings_type::value_type>(o, "\n"));
+      std::copy (s.begin (), s.end (),
+                 std::ostream_iterator<strings_type::value_type> (o, "\n"));
       return o;
     }
   }
       return o;
     }
   }
@@ -43,7 +42,7 @@ typedef std::list<std::string> strings_type;
   {
     std::ostringstream o;
     o << t;
   {
     std::ostringstream o;
     o << t;
-    return o.str();
+    return o.str ();
   }
 }
 
   }
 }
 
@@ -58,7 +57,7 @@ typedef std::list<std::string> strings_type;
 %%
 
 result:
 %%
 
 result:
-  list { std::cout << $1 << std::endl; }
+  list  { std::cout << $1 << std::endl; }
 ;
 
 list:
 ;
 
 list:
@@ -81,35 +80,23 @@ item:
 // END_OF_FILE
 
 static
 // END_OF_FILE
 
 static
-yy::parser::token_type
-yylex (yy::parser::semantic_type* yylval)
+yy::parser::symbol_type
+yylex ()
 {
 {
-  static int stage = 0;
-  yy::parser::token_type result;
-
-  switch (stage)
+  static int stage = -1;
+  switch (++stage)
   {
     case 0:
   {
     case 0:
-      yylval->build (std::string ("I have three numbers for you."));
-      result = yy::parser::token::TEXT;
-      break;
+      return yy::parser::make_TEXT ("I have three numbers for you.");
     case 1:
     case 2:
     case 3:
     case 1:
     case 2:
     case 3:
-      yylval->build (stage);
-      result = yy::parser::token::NUMBER;
-      break;
+      return yy::parser::make_NUMBER (stage);
     case 4:
     case 4:
-      yylval->build (std::string ("And that's all!"));
-      result = yy::parser::token::TEXT;
-      break;
+      return yy::parser::make_TEXT ("And that's all!");
     default:
     default:
-      result = yy::parser::token::END_OF_FILE;
-      break;
+      return yy::parser::make_END_OF_FILE ();
   }
   }
-
-  stage++;
-  return result;
 }
 
 // Mandatory error function
 }
 
 // Mandatory error function
@@ -120,11 +107,11 @@ yy::parser::error (const std::string& message)
 }
 
 int
 }
 
 int
-main (int argc, char *argv[])
+main ()
 {
   yy::parser p;
   p.set_debug_level (!!getenv ("YYDEBUG"));
 {
   yy::parser p;
   p.set_debug_level (!!getenv ("YYDEBUG"));
-  return p.parse();
+  return p.parse ();
 }
 
 // Local Variables:
 }
 
 // Local Variables: