From c8b2ef7b899766d04562f7e04a84251cea8fa701 Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sat, 6 Apr 2013 13:14:44 +0200 Subject: tagging ychat-0.8.0 --- src/maps/shashmap.tmpl | 142 +++++++++++++++++++++++++++++-------------------- 1 file changed, 85 insertions(+), 57 deletions(-) (limited to 'src/maps/shashmap.tmpl') diff --git a/src/maps/shashmap.tmpl b/src/maps/shashmap.tmpl index 6a70f61..0bd5796 100644 --- a/src/maps/shashmap.tmpl +++ b/src/maps/shashmap.tmpl @@ -1,129 +1,157 @@ -template -shashmap::shashmap() +template +shashmap::shashmap() { - pthread_mutex_init( &mut_shashmap, NULL ); + pthread_mutex_init( &mut_shashmap, NULL ); } -template -shashmap::~shashmap() +template +shashmap::~shashmap() { - pthread_mutex_destroy( &mut_shashmap ); + pthread_mutex_destroy( &mut_shashmap ); } -template +template void -shashmap::add_elem(obj_type t_obj, string s_key) +shashmap::add_elem(obj_type t_obj, key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - (*this)[s_key] = t_obj; + (*this)[t_key] = t_obj; pthread_mutex_unlock( &mut_shashmap ); -} +} -template +template void -shashmap::add_elem_insecure(obj_type t_obj, string s_key) +shashmap::add_elem_insecure(obj_type t_obj, key_type_ t_key) +{ + (*this)[t_key] = t_obj; +} + +template +obj_type +shashmap::get_set_elem(obj_type t_obj, key_type_ t_key) { - (*this)[s_key] = t_obj; -} + pthread_mutex_lock( &mut_shashmap ); + obj_type t_ret = hashmap::get_set_elem(t_obj, t_key); + pthread_mutex_unlock( &mut_shashmap ); + return t_ret; +} -template +template obj_type -shashmap::get_set_elem(obj_type t_obj, string s_key) +shashmap::get_or_callback_set +(obj_type (*func)(void*), void* p_void, key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - obj_type t_ret = hashmap::get_set_elem(t_obj, s_key); + obj_type t_ret = hashmap::get_or_callback_set + (func, p_void, t_key); pthread_mutex_unlock( &mut_shashmap ); return t_ret; -} +} -template +template void -shashmap::set_elem(obj_type t_obj, string s_key) +shashmap::set_elem(obj_type t_obj, key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - (*this)[s_key] = t_obj; + (*this)[t_key] = t_obj; pthread_mutex_unlock( &mut_shashmap ); -} +} -template +template obj_type -shashmap::get_elem(string s_key) +shashmap::get_elem(key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - obj_type t_ret = hashmap::get_elem(s_key); + obj_type t_ret = hashmap::get_elem(t_key); pthread_mutex_unlock( &mut_shashmap ); return t_ret; -} +} -template +template void -shashmap::del_elem(string s_key) +shashmap::del_elem(key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - hashmap::erase(s_key); + hashmap::erase(t_key); pthread_mutex_unlock( &mut_shashmap ); -} +} -template +template void -shashmap::del_elem_insecure(string s_key) +shashmap::del_elem_insecure(key_type_ t_key) { - hashmap::erase(s_key); -} + hashmap::erase(t_key); +} -template -vector* -shashmap::get_key_vector() +template +vector* +shashmap::get_key_vector() { pthread_mutex_lock( &mut_shashmap ); - vector* p_vec = hashmap::get_key_vector(); + vector* p_vec = hashmap::get_key_vector(); pthread_mutex_unlock( &mut_shashmap ); return p_vec; -} +} -template +template void -shashmap::clear() +shashmap::clear() { pthread_mutex_lock( &mut_shashmap ); - hashmap::clear(); + hashmap::clear(); pthread_mutex_unlock( &mut_shashmap ); -} +} -template +template int -shashmap::size() +shashmap::size() { pthread_mutex_lock( &mut_shashmap ); - int i_size = hashmap::size(); + int i_size = hashmap::size(); pthread_mutex_unlock( &mut_shashmap ); return i_size; -} +} -template +template bool -shashmap::exists(string s_key) +shashmap::exists(key_type_ t_key) { pthread_mutex_lock( &mut_shashmap ); - bool b_ret = hashmap::exists(s_key); + bool b_ret = hashmap::exists(t_key); pthread_mutex_unlock( &mut_shashmap ); return b_ret; -} +} -template +template void -shashmap::run_func( void (*func)(obj_type) ) +shashmap::run_func( void (*func)(obj_type) ) { pthread_mutex_lock( &mut_shashmap ); - hashmap::run_func(func); + hashmap::run_func(func); pthread_mutex_unlock( &mut_shashmap ); } -template +template void -shashmap::run_func( void (*func)(obj_type, void*), void* v_arg ) +shashmap::run_func( void (*func)(obj_type, void*), void* v_arg ) { pthread_mutex_lock( &mut_shashmap ); - hashmap::run_func(func, v_arg); + hashmap::run_func(func, v_arg); pthread_mutex_unlock( &mut_shashmap ); } + +template +void +shashmap::dumpit() +{ + dumpable::add + ("[shashmap]"); + vector* p_vec = get_key_vector(); + + typename vector::iterator iter; + for (iter = p_vec->begin(); iter != p_vec->end(); ++iter) + dumpable::add + (*iter); + + delete p_vec; +} -- cgit v1.2.3