summaryrefslogtreecommitdiff
path: root/src/memb
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2013-04-06 13:14:44 +0200
committerPaul Buetow <paul@buetow.org>2013-04-06 13:14:44 +0200
commitc8b2ef7b899766d04562f7e04a84251cea8fa701 (patch)
tree52816b17c17e2db0cf89e68537ad1a52392f1510 /src/memb
parentca28c0e618890330d429c0dc12429255b20f0c90 (diff)
tagging ychat-0.8.0ychat-0.8.0
Diffstat (limited to 'src/memb')
-rw-r--r--src/memb/memb.h50
-rw-r--r--src/memb/memb.tmpl67
-rw-r--r--src/memb/tupel.h2
-rw-r--r--src/memb/tupel.tmpl14
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);
}