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_NOARG_ACTION_H_INCLUDED_
00036 #define _XST_MEMBER_NOARG_ACTION_H_INCLUDED_
00037
00038 namespace cttl_impl {
00039
00055 template< typename ObjectT, typename MemberActionT, typename ResultT >
00056 class xst_member_action< ObjectT, MemberActionT, void, ResultT >
00057
00058 #ifdef CTTL_TRACE_DEPOSITS
00059 : public xst_traced_action_base
00060 #endif
00061
00062 {
00063
00065 xst_storage_adaptor< ObjectT > m_object;
00066
00068 MemberActionT m_member_action;
00069
00070 public:
00072 typedef xst_member_action< ObjectT, MemberActionT, void, ResultT > action_T;
00073
00075 typedef typename MemberActionT::result_type result_T;
00076
00078 typedef typename xst_dereference_traits< action_T, result_T >::value_type value_type;
00079
00081 xst_member_action(
00082 #ifdef CTTL_TRACE_DEPOSITS
00083 int line_,
00084 char const* action_name_,
00085 #endif
00086 ObjectT object_ref_,
00087 MemberActionT member_action_
00088 )
00089 :
00090 #ifdef CTTL_TRACE_DEPOSITS
00091 xst_traced_action_base( line_, action_name_ ),
00092 #endif
00093 m_object( object_ref_ ),
00094 m_member_action( member_action_ )
00095 {
00096 }
00097
00099 result_T operator() ( bool ) const
00100 {
00101 return operator*();
00102 }
00103
00105 result_T operator* () const
00106 {
00107 #ifdef CTTL_TRACE_DEPOSITS
00108 trace_prolog();
00109 result_T result = m_member_action( &m_object.value() );
00110 trace_epilog( result );
00111 return result;
00112 #else
00113 return m_member_action( &m_object.value() );
00114 #endif // CTTL_TRACE_DEPOSITS
00115 }
00116
00117 };
00118
00119 }
00120
00121
00122 #endif //_XST_MEMBER_NOARG_ACTION_H_INCLUDED_