That's better! Sort of.... We created a custom expression template with an eager stream operator. This gives us eager evaluation, but gives away all the lazy AST building-then-evaluating that we're using expression templates for in the first place. In this simple example, we don't really need it.
#include <boost/yap/algorithm.hpp> #include <iostream> template <boost::yap::expr_kind Kind, typename Tuple> struct stream_expr { static const boost::yap::expr_kind kind = Kind; Tuple elements; template <typename T> decltype(auto) operator<< (T && x) { return boost::yap::value(*this) << std::forward<T &&>(x); } }; int main () { auto cout = boost::yap::make_terminal<stream_expr>(std::cout); cout << "Hello" << ',' << " world!\n"; return 0; }