00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00037 #ifndef RC_VAR_H_
00038 #define RC_VAR_H_
00039
00040 #include "ReChannel/core/rc_common_header.h"
00041 #include "ReChannel/core/rc_resettable.h"
00042 #include "ReChannel/core/rc_reconfigurable.h"
00043
00044 namespace ReChannel {
00045 namespace internals {
00046 namespace resettable_var {
00047
00051 class resettable_var_base
00052 : virtual public rc_resettable
00053 {
00054 protected:
00055 resettable_var_base();
00056
00057 template<class P> void init();
00058
00059 void report_invalid_use_error();
00060
00061 protected:
00062
00063
00064
00065 void* m_parent;
00066
00067 private:
00068 class tmp_object : public sc_object {};
00069
00070 private:
00071
00072 resettable_var_base(const resettable_var_base& orig);
00073 resettable_var_base& operator=(const resettable_var_base& orig);
00074 };
00075
00079 template<class T>
00080 class resettable_var_b
00081 : public resettable_var_base
00082 {
00083 protected:
00084 resettable_var_b();
00085
00086 template<class P> void reset(T& (P::*get_ref)(void));
00087
00088 template<class P> void init_reset(T& (P::*get_ref)(void));
00089
00090 private:
00091 T m_reset_value;
00092 };
00093
00097 template<class P, class T, T& (P::*get_ref)(void)>
00098 class resettable_var
00099 : public resettable_var_b<T>
00100 {
00101 public:
00102 resettable_var()
00103 : resettable_var_b<T>()
00104 {
00105 this->template init<P>();
00106 }
00107
00108 protected:
00109
00110
00111 #if (defined(_MSC_VER) && _MSC_VER < 1400)
00112
00113 virtual void rc_on_reset()
00114 { this->template reset<P>(get_ref); }
00115
00116 virtual void rc_on_init_resettable()
00117 { this->template init_reset<P>(get_ref); }
00118
00119 #else // all other compilers
00120
00121 virtual void rc_on_reset();
00122
00123 virtual void rc_on_init_resettable();
00124
00125 #endif // (defined(_MSC_VER) && _MSC_VER < 1400)
00126 };
00127
00128
00129
00130 template<class P>
00131 void resettable_var_base::init()
00132 {
00133 sc_object* parent_obj = reinterpret_cast<sc_object*>(m_parent);
00134 m_parent = dynamic_cast<P*>(parent_obj);
00135 if (m_parent == NULL) {
00136 report_invalid_use_error();
00137 }
00138 }
00139
00140 template<class T>
00141 resettable_var_b<T>::resettable_var_b()
00142 : resettable_var_base()
00143 { }
00144
00145 template<class T>
00146 template<class P>
00147 void resettable_var_b<T>::reset(T& (P::*get_ref)(void))
00148 {
00149 (reinterpret_cast<P*>(m_parent)->*get_ref)() = m_reset_value;
00150 }
00151
00152 template<class T>
00153 template<class P>
00154 void resettable_var_b<T>::init_reset(T& (P::*get_ref)(void))
00155 {
00156 m_reset_value = (reinterpret_cast<P*>(m_parent)->*get_ref)();
00157 }
00158
00159
00160 #if (defined(_MSC_VER) && _MSC_VER < 1400)
00161
00162
00163
00164
00165 #else // all other compilers
00166
00167 template<class P, class T, T& (P::*get_ref)(void)>
00168 void resettable_var<P, T, get_ref>::rc_on_reset()
00169 {
00170 this->template reset<P>(get_ref);
00171 }
00172
00173 template<class P, class T, T& (P::*get_ref)(void)>
00174 void resettable_var<P, T, get_ref>::rc_on_init_resettable()
00175 {
00176 this->template init_reset<P>(get_ref);
00177 }
00178
00179 #endif // (defined(_MSC_VER) && _MSC_VER < 1400)
00180
00181 }
00182 }
00183 }
00184
00185
00186 #if (defined(_MSC_VER) && _MSC_VER < 1400)
00187
00188
00189 #define RC_HAS_RECONFIGURABLE_VAR(user_module_name) \
00190 typedef user_module_name RC_CURRENT_VAR_CONTAINER
00191
00192 #else // all other compilers
00193
00194 #define RC_HAS_RECONFIGURABLE_VAR(user_module_name) \
00195 template< \
00196 class _rc_var_P, \
00197 class _rc_var_T, \
00198 _rc_var_T& (_rc_var_P::*_rc_var_get_ref)(void) \
00199 > \
00200 friend class ::ReChannel::internals::resettable_var::resettable_var; \
00201 typedef user_module_name RC_CURRENT_VAR_CONTAINER
00202
00203 #endif // (defined(_MSC_VER) && _MSC_VER < 1400)
00204
00205 #define RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name) \
00206 var_type& _rc_var_get_##var_name() { return this->var_name; } \
00207 ::ReChannel::internals::resettable_var::resettable_var< \
00208 RC_CURRENT_VAR_CONTAINER, var_type, \
00209 &RC_CURRENT_VAR_CONTAINER::_rc_var_get_##var_name> \
00210 _rc_var_##var_name
00211
00212 #define RC_RECONFIGURABLE_VAR(var_type, var_name) \
00213 var_type var_name; \
00214 RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name)
00215
00216 #define RC_HAS_VAR(user_module_name) \
00217 RC_HAS_RECONFIGURABLE_VAR(user_module_name)
00218
00219 #define RC_DECLARE_VAR(var_type, var_name) \
00220 RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name)
00221 #define rc_declare_var(var_type, var_name) \
00222 RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name)
00223
00224 #define RC_VAR(var_type, var_name) \
00225 RC_RECONFIGURABLE_VAR(var_type, var_name)
00226 #define rc_var(var_type, var_name) \
00227 RC_RECONFIGURABLE_VAR(var_type, var_name)
00228
00229 #define RC_RESETTABLE_VAR(var_type, var_name) \
00230 RC_RECONFIGURABLE_VAR(var_type, var_name)
00231 #define rc_resettable_var(var_type, var_name) \
00232 RC_RECONFIGURABLE_VAR(var_type, var_name)
00233
00234 #define RC_PRESERVABLE_VAR(var_type, var_name) \
00235 var_type var_name;
00236 #define rc_preservable_var(var_type, var_name) \
00237 var_type var_name;
00238
00239 #define RC_DECLARE_RESETTABLE_VAR(var_type, var_name) \
00240 RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name)
00241 #define rc_declare_resettable_var(var_type, var_name) \
00242 RC_DECLARE_RECONFIGURABLE_VAR(var_type, var_name)
00243
00244 #define RC_DECLARE_PRESERVABLE_VAR(var_type, var_name) \
00245
00246 #define rc_declare_preservable_var(var_type, var_name) \
00247
00248
00249 #endif // RC_VAR_H_
00250
00251
00252
00253
00254