// Copyright 2008 Christophe Henry // henry UNDERSCORE christophe AT hotmail DOT com // This is an extended version of the state machine available in the boost::mpl library // Distributed under the same license as the original. // Copyright for the original version: // Copyright 2005 David Abrahams and Aleksey Gurtovoy. 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_MSM_FRONT_EUML_OPERATOR_H #define BOOST_MSM_FRONT_EUML_OPERATOR_H #include <iterator> #include <boost/msm/front/euml/common.hpp> #include <boost/type_traits/remove_reference.hpp> #include <boost/utility/enable_if.hpp> #include <boost/mpl/has_key.hpp> #include <boost/mpl/eval_if.hpp> #include <boost/mpl/set.hpp> #include <boost/type_traits.hpp> #include <boost/fusion/container/set.hpp> BOOST_MPL_HAS_XXX_TRAIT_DEF(reference) BOOST_MPL_HAS_XXX_TRAIT_DEF(key_type) namespace boost { namespace msm { namespace front { namespace euml { template <class T1,class T2> struct Or_ : euml_action<Or_<T1,T2> > { template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt) { return (T1()(evt,fsm,src,tgt) || T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state) { return (T1()(evt,fsm,state) || T2()(evt,fsm,state)); } }; template <class T1,class T2> struct And_ : euml_action<And_<T1,T2> > { template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt) { return (T1()(evt,fsm,src,tgt) && T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state) { return (T1()(evt,fsm,state) && T2()(evt,fsm,state)); } }; template <class T1> struct Not_ : euml_action<Not_<T1> > { template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt) { return !(T1()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state) { return !(T1()(evt,fsm,state)); } }; template <class Condition,class Action1,class Action2, class Enable=void > struct If_Else_ : euml_action<If_Else_<Condition,Action1,Action2,Enable> > {}; template <class Condition,class Action1,class Action2> struct If_Else_<Condition,Action1,Action2 , typename ::boost::enable_if<typename has_tag_type<Action1>::type >::type> : euml_action<If_Else_<Condition,Action1,Action2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<Action1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<Action1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename Action1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { if (Condition()(evt,fsm,src,tgt)) { return Action1()(evt,fsm,src,tgt); } return Action2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename Action1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { if (Condition()(evt,fsm,state)) { return Action1()(evt,fsm,state); } return Action2()(evt,fsm,state); } }; template <class Condition,class Action1,class Action2> struct If_Else_<Condition,Action1,Action2 , typename ::boost::disable_if<typename has_tag_type<Action1>::type >::type> : euml_action<If_Else_<Condition,Action1,Action2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { if (Condition()(evt,fsm,src,tgt)) { return Action1()(evt,fsm,src,tgt); } return Action2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state )const { if (Condition()(evt,fsm,state)) { return Action1()(evt,fsm,state); } return Action2()(evt,fsm,state); } }; struct if_tag { }; struct If : proto::extends<proto::terminal<if_tag>::type, If, boost::msm::sm_domain> { If(){} using proto::extends< proto::terminal<if_tag>::type, If, boost::msm::sm_domain>::operator=; template <class Arg1,class Arg2,class Arg3,class Arg4,class Arg5 #ifdef BOOST_MSVC ,class Arg6 #endif > struct In { typedef If_Else_<Arg1,Arg2,Arg3> type; }; }; If const if_then_else_; template <class Condition,class Action1, class Enable=void > struct If_Then_ : euml_action<If_Then_<Condition,Action1,Enable> > {}; template <class Condition,class Action1> struct If_Then_<Condition,Action1 , typename ::boost::enable_if<typename has_tag_type<Action1>::type >::type> : euml_action<If_Then_<Condition,Action1> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<Action1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<Action1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename Action1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { if (Condition()(evt,fsm,src,tgt)) { return Action1()(evt,fsm,src,tgt); } } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename Action1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { if (Condition()(evt,fsm,state)) { return Action1()(evt,fsm,state); } } }; template <class Condition,class Action1> struct If_Then_<Condition,Action1 , typename ::boost::disable_if<typename has_tag_type<Action1>::type >::type> : euml_action<If_Then_<Condition,Action1> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { if (Condition()(evt,fsm,src,tgt)) { return Action1()(evt,fsm,src,tgt); } } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state )const { if (Condition()(evt,fsm,state)) { return Action1()(evt,fsm,state); } } }; struct if_then_tag { }; struct If_Then : proto::extends< proto::terminal<if_then_tag>::type, If_Then, boost::msm::sm_domain> { If_Then(){} using proto::extends< proto::terminal<if_then_tag>::type, If_Then, boost::msm::sm_domain>::operator=; template <class Arg1,class Arg2,class Arg3,class Arg4,class Arg5 #ifdef BOOST_MSVC ,class Arg6 #endif > struct In { typedef If_Then_<Arg1,Arg2> type; }; }; If_Then const if_then_; template <class Condition,class Body> struct While_Do_ : euml_action<While_Do_<Condition,Body> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef void type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef void type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> void operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { Body body_; Condition cond_; while (cond_(evt,fsm,src,tgt)) { body_(evt,fsm,src,tgt); } } template <class Event,class FSM,class STATE> void operator()(Event const& evt,FSM& fsm,STATE& state )const { Body body_; Condition cond_; while (cond_(evt,fsm,state)) { body_(evt,fsm,state); } } }; struct while_do_tag { }; struct While_Do_Helper : proto::extends< proto::terminal<while_do_tag>::type, While_Do_Helper, boost::msm::sm_domain> { While_Do_Helper(){} using proto::extends< proto::terminal<while_do_tag>::type, While_Do_Helper, boost::msm::sm_domain>::operator=; template <class Arg1,class Arg2,class Arg3,class Arg4,class Arg5 #ifdef BOOST_MSVC ,class Arg6 #endif > struct In { typedef While_Do_<Arg1,Arg2> type; }; }; While_Do_Helper const while_; template <class Condition,class Body> struct Do_While_ : euml_action<Do_While_<Condition,Body> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef void type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef void type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> void operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { Condition cond_; Body body_; do { body_(evt,fsm,src,tgt); } while (cond_(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> void operator()(Event const& evt,FSM& fsm,STATE& state )const { Condition cond_; Body body_; do { body_(evt,fsm,state); } while (cond_(evt,fsm,state)); } }; struct do_while_tag { }; struct Do_While_Helper : proto::extends< proto::terminal<do_while_tag>::type, Do_While_Helper, boost::msm::sm_domain> { Do_While_Helper(){} using proto::extends< proto::terminal<do_while_tag>::type, Do_While_Helper, boost::msm::sm_domain>::operator=; template <class Arg1,class Arg2,class Arg3,class Arg4,class Arg5 #ifdef BOOST_MSVC ,class Arg6 #endif > struct In { typedef Do_While_<Arg1,Arg2> type; }; }; Do_While_Helper const do_while_; template <class Begin,class End,class EndLoop,class Body> struct For_Loop_ : euml_action<For_Loop_<Begin,End,EndLoop,Body> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef void type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef void type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> void operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { End end_; EndLoop end_loop_; Body body_; for(Begin()(evt,fsm,src,tgt);end_(evt,fsm,src,tgt);end_loop_(evt,fsm,src,tgt)) { body_(evt,fsm,src,tgt); } } template <class Event,class FSM,class STATE> void operator()(Event const& evt,FSM& fsm,STATE& state )const { End end_; EndLoop end_loop_; Body body_; for(Begin()(evt,fsm,state);end_(evt,fsm,state);end_loop_(evt,fsm,state)) { body_(evt,fsm,state); } } }; struct for_loop_tag { }; struct For_Loop_Helper : proto::extends< proto::terminal<for_loop_tag>::type, For_Loop_Helper, boost::msm::sm_domain> { For_Loop_Helper(){} using proto::extends< proto::terminal<for_loop_tag>::type, For_Loop_Helper, boost::msm::sm_domain>::operator=; template <class Arg1,class Arg2,class Arg3,class Arg4,class Arg5 #ifdef BOOST_MSVC ,class Arg6 #endif > struct In { typedef For_Loop_<Arg1,Arg2,Arg3,Arg4> type; }; }; For_Loop_Helper const for_; template <class T> struct Deref_ : euml_action<Deref_<T> > { Deref_(){} using euml_action<Deref_<T> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::add_reference< typename std::iterator_traits < typename ::boost::remove_reference< typename get_result_type2<T,Event,FSM,STATE>::type>::type>::value_type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::add_reference< typename std::iterator_traits< typename ::boost::remove_reference< typename get_result_type<T,EVT,FSM,SourceState,TargetState>::type>::type >::value_type >::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return *(T()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return *(T()(evt,fsm,state)); } }; template <class T> struct Pre_inc_ : euml_action<Pre_inc_<T> > { using euml_action<Pre_inc_<T> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return ++T()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return ++T()(evt,fsm,state); } }; template <class T> struct Pre_dec_ : euml_action<Pre_dec_<T> > { using euml_action<Pre_dec_<T> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return --T()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return --T()(evt,fsm,state); } }; template <class T> struct Post_inc_ : euml_action<Post_inc_<T> > { using euml_action<Post_inc_<T> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T()(evt,fsm,src,tgt)++; } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T()(evt,fsm,state)++; } }; template <class T> struct Post_dec_ : euml_action<Post_dec_<T> > { using euml_action<Post_dec_<T> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T()(evt,fsm,src,tgt)--; } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T()(evt,fsm,state)--; } }; template <class T1,class T2> struct Plus_ : euml_action<Plus_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)+T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)+T2()(evt,fsm,state); } }; template <class T1,class T2> struct Minus_ : euml_action<Minus_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)-T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)-T2()(evt,fsm,state); } }; template <class T1,class T2> struct Multiplies_ : euml_action<Multiplies_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)*T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)*T2()(evt,fsm,state); } }; template <class T1,class T2> struct Divides_ : euml_action<Divides_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)/T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)/T2()(evt,fsm,state); } }; template <class T1,class T2> struct Modulus_ : euml_action<Modulus_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)%T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)%T2()(evt,fsm,state); } }; template <class T1,class T2> struct Bitwise_And_ : euml_action<Bitwise_And_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)&T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)&T2()(evt,fsm,state); } }; template <class T1,class T2> struct Bitwise_Or_ : euml_action<Bitwise_Or_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)|T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)|T2()(evt,fsm,state); } }; template <class T1,class T2> struct Bitwise_Xor_ : euml_action<Bitwise_Xor_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)^T2()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)^T2()(evt,fsm,state); } }; template <class T1,class T2> struct Subscript_ : euml_action<Subscript_<T1,T2> > { template <class T> struct get_reference { typedef typename T::reference type; }; template <class T> struct get_mapped_type { typedef typename T::value_type::second_type& type; }; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type container_type; typedef typename ::boost::mpl::eval_if< typename has_key_type<container_type>::type, get_mapped_type<container_type>, ::boost::mpl::eval_if< typename ::boost::is_pointer<container_type>::type, ::boost::add_reference<typename ::boost::remove_pointer<container_type>::type >, get_reference<container_type> > >::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type container_type; typedef typename ::boost::mpl::eval_if< typename has_key_type<container_type>::type, get_mapped_type<container_type>, ::boost::mpl::eval_if< typename ::boost::is_pointer<container_type>::type, ::boost::add_reference<typename ::boost::remove_pointer<container_type>::type >, get_reference<container_type> > >::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return T1()(evt,fsm,src,tgt)[T2()(evt,fsm,src,tgt)]; } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return T1()(evt,fsm,state)[T2()(evt,fsm,state)]; } }; template <class T1,class T2> struct Plus_Assign_ : euml_action<Plus_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)+=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)+=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Minus_Assign_ : euml_action<Minus_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)-=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)-=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Multiplies_Assign_ : euml_action<Multiplies_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)*=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)*=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Divides_Assign_ : euml_action<Divides_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)/=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)/=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Modulus_Assign_ : euml_action<Modulus_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)%=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)%=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct ShiftLeft_Assign_ : euml_action<ShiftLeft_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)<<=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)<<=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct ShiftRight_Assign_ : euml_action<ShiftRight_Assign_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)>>=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)>>=T2()(evt,fsm,state)); } }; template <class T1,class T2> struct ShiftLeft_ : euml_action<ShiftLeft_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)<<T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)<<T2()(evt,fsm,state)); } }; template <class T1,class T2> struct ShiftRight_ : euml_action<ShiftRight_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)>>T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)>>T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Assign_ : euml_action<Assign_<T1,T2> > { using euml_action< Assign_<T1,T2> >::operator=; template <class Event,class FSM,class STATE > struct state_action_result { typedef typename get_result_type2<T1,Event,FSM,STATE>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt)=T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return (T1()(evt,fsm,state)=T2()(evt,fsm,state)); } }; template <class T1> struct Unary_Plus_ : euml_action<Unary_Plus_<T1> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return +T1()(evt,fsm,src,tgt); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return +T1()(evt,fsm,state); } }; template <class T1> struct Unary_Minus_ : euml_action<Unary_Minus_<T1> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef typename ::boost::remove_reference< typename get_result_type2<T1,Event,FSM,STATE>::type>::type type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef typename ::boost::remove_reference< typename get_result_type<T1,EVT,FSM,SourceState,TargetState>::type>::type type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,action_tag>::type, typename transition_action_result<EVT,FSM,SourceState,TargetState>::type >::type operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return -(T1()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> typename ::boost::enable_if< typename ::boost::mpl::has_key< typename T1::tag_type,state_action_tag>::type, typename state_action_result<Event,FSM,STATE>::type >::type operator()(Event const& evt,FSM& fsm,STATE& state )const { return -(T1()(evt,fsm,state)); } }; template <class T1,class T2> struct Less_ : euml_action<Less_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) < T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) < T2()(evt,fsm,state)); } }; template <class T1,class T2> struct LessEqual_ : euml_action<LessEqual_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) <= T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) <= T2()(evt,fsm,state)); } }; template <class T1,class T2> struct Greater_ : euml_action<Greater_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) > T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) > T2()(evt,fsm,state)); } }; template <class T1,class T2> struct GreaterEqual_ : euml_action<GreaterEqual_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) >= T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) >= T2()(evt,fsm,state)); } }; template <class T1,class T2> struct EqualTo_ : euml_action<EqualTo_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) == T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) == T2()(evt,fsm,state)); } }; template <class T1,class T2> struct NotEqualTo_ : euml_action<NotEqualTo_<T1,T2> > { template <class Event,class FSM,class STATE > struct state_action_result { typedef bool type; }; template <class EVT,class FSM,class SourceState,class TargetState> struct transition_action_result { typedef bool type; }; typedef ::boost::fusion::set<state_action_tag,action_tag> tag_type; template <class EVT,class FSM,class SourceState,class TargetState> bool operator()(EVT const& evt, FSM& fsm,SourceState& src,TargetState& tgt)const { return (T1()(evt,fsm,src,tgt) != T2()(evt,fsm,src,tgt)); } template <class Event,class FSM,class STATE> bool operator()(Event const& evt,FSM& fsm,STATE& state)const { return (T1()(evt,fsm,state) != T2()(evt,fsm,state)); } }; }}}} #endif // BOOST_MSM_FRONT_EUML_OPERATOR_H