boost/xpressive/proto/compiler/branch.hpp
/////////////////////////////////////////////////////////////////////////////// /// \file branch.hpp /// A special-purpose proto compiler for compiling one branch of the expression /// tree separately from the rest. Given an expression and a proto lambda, it /// compiles the expression using an initial state determined by the lambda. /// It then passes the result along with the current state and the visitor /// to the lambda for further processing. // // Copyright 2004 Eric Niebler. Distributed under the Boost // Software License, Version 1.0. (See accompanying file // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifndef BOOST_PROTO_COMPILER_BRANCH_HPP_EAN_04_01_2005 #define BOOST_PROTO_COMPILER_BRANCH_HPP_EAN_04_01_2005 #include <boost/xpressive/proto/proto_fwd.hpp> namespace boost { namespace proto { /////////////////////////////////////////////////////////////////////////////// // branch_compiler template<typename Lambda, typename DomainTag> struct branch_compiler { template<typename Op, typename State, typename Visitor> struct apply { typedef proto::compiler<typename tag_type<Op>::type, DomainTag> compiler_type; // Compile the branch typedef typename compiler_type::BOOST_NESTED_TEMPLATE apply < Op , typename Lambda::state_type , Visitor >::type branch_type; // Pass the branch, state and visitor to the lambda typedef typename Lambda::BOOST_NESTED_TEMPLATE apply < branch_type , State , Visitor >::type type; }; template<typename Op, typename State, typename Visitor> static typename apply<Op, State, Visitor>::type call(Op const &op, State const &state, Visitor &visitor) { return Lambda::call ( proto::compile(op, typename Lambda::state_type(), visitor, DomainTag()) , state , visitor ); } }; }} #endif