bison-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH] Make variant.yy more complex.


From: Akim Demaille
Subject: [PATCH] Make variant.yy more complex.
Date: Tue, 04 Nov 2008 20:43:26 -0000

std::list cannot be copied via memcpy, they are more demanding than
std::string.  Use one std::list to strengthen the test.

        * examples/variant.yy: Use lalr1-fusion.cc, not lalr1.cc.
        Adjust.
        Create a list of strings, instead of a single large string.
---
 ChangeLog           |   10 +++++
 examples/variant.yy |   94 ++++++++++++++++++++++++++++++++------------------
 2 files changed, 70 insertions(+), 34 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index dac5861..87c0fcf 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,15 @@
 2008-11-04  Akim Demaille  <address@hidden>
 
+       Make variant.yy more complex.
+       std::list cannot be copied via memcpy, they are more demanding than
+       std::string.  Use one std::list to strengthen the test.
+       
+       * examples/variant.yy: Use lalr1-fusion.cc, not lalr1.cc.
+       Adjust.
+       Create a list of strings, instead of a single large string.
+
+2008-11-04  Akim Demaille  <address@hidden>
+
        bench.pl --bench.
        * etc/bench.pl.in (--bench, $bench): New.
 
diff --git a/examples/variant.yy b/examples/variant.yy
index fafb655..be43c60 100644
--- a/examples/variant.yy
+++ b/examples/variant.yy
@@ -1,60 +1,88 @@
 /* Test file for C++ parsers using variants.
    Based on an example by Michiel De Wilde <address@hidden>. */
-%language "C++"
 %debug
+%skeleton "lalr1-fusion.cc"
 %defines
 %define variant
 
 %code requires // *.hh
 {
+#include <list>
 #include <string>
+typedef std::list<std::string> strings_type;
 }
 
 %code // *.cc
 {
 #include <algorithm>
 #include <iostream>
+#include <iterator>
 #include <sstream>
 
-static yy::parser::token_type yylex(yy::parser::semantic_type* yylval);
+  // Prototype of the yylex function providing subsequent tokens.
+  static yy::parser::token_type yylex(yy::parser::semantic_type* yylval);
+
+  // 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)
+    {
+      std::copy(s.begin(), s.end(),
+                std::ostream_iterator<strings_type::value_type>(o, "\n"));
+      return o;
+    }
+  }
+
+  // Conversion to string.
+  template <typename T>
+    inline
+    std::string
+    string_cast (const T& t)
+  {
+    std::ostringstream o;
+    o << t;
+    return o.str();
+  }
 }
 
-%token <std::string> TEXT
-%token <int> NUMBER
-%printer { debug_stream() << $$; } <int> <std::string>
-%token END_OF_FILE 0
+%token <std::string> TEXT;
+%token <int> NUMBER;
+%printer { debug_stream () << $$; } <int> <std::string> <strings_type>;
+%token END_OF_FILE 0;
 
-%type <std::string> text result
+%type <std::string> item;
+%type <strings_type> list;
 
 %%
 
 result:
- text  { std::cout << $1 << std::endl; }
+  list          { std::cout << $1 << std::endl; }
+;
+
+list:
+  /* nothing */ { /* Generates an empty string list */ }
+| list item     { std::swap ($$, $1); $$.push_back ($2); }
 ;
 
-text:
-  /* nothing */         { /* This will generate an empty string */ }
-| text TEXT             { std::swap($$,$1); $$.append($2); }
-| text NUMBER           {
-                          std::swap($$,$1);
-                          std::ostringstream o;
-                          o << ' ' << $2;
-                          $$.append(o.str());
-                        }
+item:
+  TEXT          { std::swap ($$, $1); }
+| NUMBER        { $$ = string_cast ($1); }
 ;
 %%
 
 // The yylex function providing subsequent tokens:
-// TEXT                "I have three numbers for you:"
-// NUMBER      1
-// NUMBER      2
-// NUMBER      3
-// TEXT                " and that's all!"
+// TEXT         "I have three numbers for you:"
+// NUMBER       1
+// NUMBER       2
+// NUMBER       3
+// TEXT         " and that's all!"
 // END_OF_FILE
 
 static
 yy::parser::token_type
-yylex(yy::parser::semantic_type* yylval)
+yylex (yy::parser::semantic_type* yylval)
 {
   static int stage = 0;
   yy::parser::token_type result;
@@ -62,20 +90,18 @@ yylex(yy::parser::semantic_type* yylval)
   switch (stage)
   {
     case 0:
-      yylval->build<std::string>();
-      yylval->as<std::string>() = std::string("I have three numbers for you:");
+      yylval->build<std::string> () =
+        std::string ("I have three numbers for you.");
       result = yy::parser::token::TEXT;
       break;
     case 1:
     case 2:
     case 3:
-      yylval->build<int>();
-      yylval->as<int>() = stage;
+      yylval->build<int> () = stage;
       result = yy::parser::token::NUMBER;
       break;
     case 4:
-      yylval->build<std::string>();
-      yylval->as<std::string>() = std::string(" and that's all!");
+      yylval->build<std::string> () = std::string ("And that's all!");
       result = yy::parser::token::TEXT;
       break;
     default:
@@ -89,18 +115,18 @@ yylex(yy::parser::semantic_type* yylval)
 
 // Mandatory error function
 void
-yy::parser::error(const yy::parser::location_type& yylloc,
-                  const std::string& message)
+yy::parser::error (const yy::parser::location_type& yylloc,
+                   const std::string& message)
 {
   std::cerr << yylloc << ": " << message << std::endl;
 }
 
 int
-main(int argc, char *argv[])
+main (int argc, char *argv[])
 {
   yy::parser p;
-  p.set_debug_level(!!getenv("YYDEBUG"));
-  p.parse();
+  p.set_debug_level (!!getenv ("YYDEBUG"));
+  p.parse ();
 }
 
 // Local Variables:
-- 
1.6.0.2.588.g3102





reply via email to

[Prev in Thread] Current Thread [Next in Thread]