00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00023
00033
00034
00035 #ifndef _XST_MEMBER_ACTION_H_INCLUDED_
00036 #define _XST_MEMBER_ACTION_H_INCLUDED_
00037
00038 namespace cttl_impl {
00039
00058 template< typename ObjectT, typename MemberActionT, typename ArgumentT, typename ResultT >
00059 class xst_member_action
00060
00061 #ifdef CTTL_TRACE_DEPOSITS
00062 : public xst_traced_action_base
00063 #endif
00064
00065 {
00067 xst_storage_adaptor< ObjectT > m_object;
00068
00070 MemberActionT m_member_action;
00071
00073 xst_storage_adaptor< ArgumentT > m_argument;
00074
00075 public:
00077 typedef xst_member_action< ObjectT, MemberActionT, ArgumentT, ResultT > action_T;
00078
00080 typedef typename MemberActionT::result_type result_T;
00081
00083 typedef typename xst_dereference_traits< action_T, result_T >::value_type value_type;
00084
00086 xst_member_action(
00087 #ifdef CTTL_TRACE_DEPOSITS
00088 int line_,
00089 char const* action_name_,
00090 #endif
00091 ObjectT object_ref_,
00092 MemberActionT member_action_,
00093 ArgumentT argument_
00094 )
00095 :
00096 #ifdef CTTL_TRACE_DEPOSITS
00097 xst_traced_action_base( line_, action_name_ ),
00098 #endif
00099 m_object( object_ref_ ),
00100 m_member_action( member_action_ ),
00101 m_argument( argument_ )
00102 {
00103 }
00104
00106 result_T operator() ( bool ) const
00107 {
00108 return operator*();
00109 }
00110
00112 result_T operator* () const
00113 {
00114 #ifdef CTTL_TRACE_DEPOSITS
00115 trace_prolog( m_argument.value() );
00116 result_T result = m_member_action( &m_object.value(), m_argument.value() );
00117 trace_epilog( result );
00118 return result;
00119 #else
00120 return m_member_action( &m_object.value(), m_argument.value() );
00121 #endif // CTTL_TRACE_DEPOSITS
00122 }
00123
00124 };
00125
00126 }
00127
00128
00129 #endif //_XST_MEMBER_ACTION_H_INCLUDED_