2011/8/15 <boost_mailinglist@gmx.de>Hello,
if I execute the following example, I get the following output "The bad one The good one a" but I only expected "The good one a".
Why does it happens? Boost 1.47.0 was used.
#include <boost/config/warning_disable.hpp>
#include <boost/spirit/include/qi.hpp>
#include <boost/lambda/lambda.hpp>
#include <iostream>
int main()
{
using boost::spirit::qi::char_;
using boost::spirit::qi::parse;
char const *first = "{a}", *last = first + std::strlen(first);
parse(first, last, '{' >> char_("a")[std::cout << "The good one " << boost::lambda::_1 << '\n'] |
char_("b")[std::cout << "The bad one " << boost::lambda::_1 << '\n'] >> '}');
return 0;
}
Because (std::cout << "The good one ") & (std::cout << "The bad one ") are not lambda expressions so they are executed immediately, and it seems Boost.Lambda just happened to work here.
The corrected version would be:#include <boost/config/warning_disable.hpp>#include <boost/spirit/include/phoenix.hpp>
#include <boost/spirit/include/qi.hpp>using boost::spirit::qi::_1;
#include <iostream>
int main()
{
using boost::spirit::qi::char_;
using boost::spirit::qi::parse;
using boost::phoenix::val;parse(first, last, '{' >> char_("a")[std::cout << phx::val("The good one ") << _1 << '\n'] |
char const *first = "{a}", *last = first + std::strlen(first);
char_("b")[std::cout << phx::val("The bad one ") << _1 << '\n'] >> '}');
return 0;
}