diff options
| author | Paul Buetow <paul@buetow.org> | 2013-04-06 13:14:44 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2013-04-06 13:14:44 +0200 |
| commit | c8b2ef7b899766d04562f7e04a84251cea8fa701 (patch) | |
| tree | 52816b17c17e2db0cf89e68537ad1a52392f1510 /src/memb | |
| parent | ca28c0e618890330d429c0dc12429255b20f0c90 (diff) | |
tagging ychat-0.8.0ychat-0.8.0
Diffstat (limited to 'src/memb')
| -rw-r--r-- | src/memb/memb.h | 50 | ||||
| -rw-r--r-- | src/memb/memb.tmpl | 67 | ||||
| -rw-r--r-- | src/memb/tupel.h | 2 | ||||
| -rw-r--r-- | src/memb/tupel.tmpl | 14 |
4 files changed, 122 insertions, 11 deletions
diff --git a/src/memb/memb.h b/src/memb/memb.h index 9c398ec..f0df6ed 100644 --- a/src/memb/memb.h +++ b/src/memb/memb.h @@ -2,7 +2,8 @@ #define MEMB_H #include "../incl.h" -#include "../maps/nhashmap.h" +#include "../wrap.h" +#include "../maps/hashmap.h" #include "tupel.h" using namespace std; @@ -11,13 +12,58 @@ template<class obj_type> class memb { private: - nhashmap< mutexed_tupel<obj_type>* > map_elems; + hashmap< mutexed_tupel<obj_type>* > map_elems; public: + memb() + {} + memb(vector<string> &vec_fields); + void initialize(vector<string> &vec_fields); inline obj_type get_elem(string s_key); inline void set_elem(obj_type t_obj, string s_key); +}; +struct memb_string : protected memb<string> +{ + memb_string() + {} + memb_string(vector<string> &vec_fields) : memb<string>(vec_fields) + {} + void init_strings(vector<string> vec_fields) + { + initialize(vec_fields); + } + inline string get_string(string s_key); + inline void set_string(string s_obj, string s_key); +}; + +struct memb_int : protected memb<int> +{ + memb_int() + {} + void init_ints(vector<string> vec_fields) + { + initialize(vec_fields); + } + inline int get_int(string s_key); + inline void set_int(int i_obj, string s_key); }; +struct memb_bool : protected memb<bool> +{ + memb_bool() + {} + void init_bools(vector<string> vec_fields) + { + initialize(vec_fields); + } + inline bool get_bool(string s_key); + inline void set_bool(bool b_obj, string s_key); +}; + +class memb_base : public memb_string, public memb_int, public memb_bool + {} +; + #include "memb.tmpl" #endif diff --git a/src/memb/memb.tmpl b/src/memb/memb.tmpl index 0b4da0e..5c745cc 100644 --- a/src/memb/memb.tmpl +++ b/src/memb/memb.tmpl @@ -1,3 +1,20 @@ + +template<class obj_type> +memb<obj_type>::memb(vector<string> &vec_fields) +{ + initialize(vec_fields); +} + +template<class obj_type> +void +memb<obj_type>::initialize(vector<string> &vec_fields) +{ + obj_type t_default; + vector<string>::iterator iter; + for (iter = vec_fields.begin(); iter != vec_fields.end(); ++iter) + map_elems[*iter] = new mutexed_tupel<obj_type>(t_default); +} + template<class obj_type> obj_type memb<obj_type>::get_elem(string s_key) @@ -6,12 +23,58 @@ memb<obj_type>::get_elem(string s_key) if ( p_tupel ) return p_tupel->get_elem(); - return obj_type(); + obj_type t_ret; + return t_ret; } template<class obj_type> void memb<obj_type>::set_elem(obj_type t_obj, string s_key) { - // mutexed_tupel<obj_type> *p_tupel = map_elems + mutexed_tupel<obj_type> *p_tupel = map_elems.get_elem(s_key); + if ( p_tupel ) + { + p_tupel->set_elem(t_obj); + return; + } + + //wrap::system_message(MEMBERE+string("("+s_key+")")); +} + +string +memb_string::get_string(string s_key) +{ + return get_elem(s_key); +} + +void +memb_string::set_string(string s_obj, string s_key) +{ + set_elem(s_obj, s_key); +} + +int +memb_int::get_int(string s_key) +{ + return get_elem(s_key); +} + +void +memb_int::set_int(int i_obj, string s_key) +{ + set_elem(i_obj, s_key); } + +bool +memb_bool::get_bool(string s_key) +{ + return get_elem(s_key); +} + +void +memb_bool::set_bool(bool b_obj, string s_key) +{ + set_elem(b_obj, s_key); +} + + diff --git a/src/memb/tupel.h b/src/memb/tupel.h index bb1939e..864a092 100644 --- a/src/memb/tupel.h +++ b/src/memb/tupel.h @@ -13,7 +13,9 @@ class tupel private: pthread_mutex_t mut_tupel; obj_type t_obj; + public: + tupel(); tupel(obj_type t_obj); ~tupel(); diff --git a/src/memb/tupel.tmpl b/src/memb/tupel.tmpl index bdde516..ab42748 100644 --- a/src/memb/tupel.tmpl +++ b/src/memb/tupel.tmpl @@ -1,29 +1,29 @@ template<class obj_type> tupel<obj_type>::tupel() { - pthread_mutex_init( &mut_tupel, NULL ); + pthread_mutex_init(&mut_tupel, NULL); } template<class obj_type> tupel<obj_type>::tupel(obj_type t_obj) { this->t_obj = t_obj; - pthread_mutex_init( &mut_tupel, NULL ); + pthread_mutex_init(&mut_tupel, NULL); } template<class obj_type> tupel<obj_type>::~tupel() { - pthread_mutex_destroy( &mut_tupel ); + pthread_mutex_destroy(&mut_tupel); } template<class obj_type> obj_type tupel<obj_type>::get_elem() { - pthread_mutex_lock( &mut_tupel ); + pthread_mutex_lock(&mut_tupel); obj_type t_ret = t_obj; - pthread_mutex_unlock( &mut_tupel ); + pthread_mutex_unlock(&mut_tupel); return t_ret; } @@ -31,7 +31,7 @@ template<class obj_type> void tupel<obj_type>::set_elem(obj_type t_obj) { - pthread_mutex_lock( &mut_tupel ); + pthread_mutex_lock(&mut_tupel); this->t_obj = t_obj; - pthread_mutex_unlock( &mut_tupel ); + pthread_mutex_unlock(&mut_tupel); } |
