From b891420946d5269cc326d67555c6aab3db41a01a Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sun, 21 Nov 2010 17:01:59 +0000 Subject: added yhttpd and ycurses trunk versions --- yhttpd/src/maps/shashmap.tmpl | 157 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 157 insertions(+) create mode 100644 yhttpd/src/maps/shashmap.tmpl (limited to 'yhttpd/src/maps/shashmap.tmpl') diff --git a/yhttpd/src/maps/shashmap.tmpl b/yhttpd/src/maps/shashmap.tmpl new file mode 100644 index 0000000..0bd5796 --- /dev/null +++ b/yhttpd/src/maps/shashmap.tmpl @@ -0,0 +1,157 @@ +template +shashmap::shashmap() +{ + pthread_mutex_init( &mut_shashmap, NULL ); +} + +template +shashmap::~shashmap() +{ + pthread_mutex_destroy( &mut_shashmap ); +} + +template +void +shashmap::add_elem(obj_type t_obj, key_type_ t_key) +{ + pthread_mutex_lock( &mut_shashmap ); + (*this)[t_key] = t_obj; + pthread_mutex_unlock( &mut_shashmap ); +} + +template +void +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) +{ + 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 +obj_type +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_or_callback_set + (func, p_void, t_key); + pthread_mutex_unlock( &mut_shashmap ); + return t_ret; +} + +template +void +shashmap::set_elem(obj_type t_obj, key_type_ t_key) +{ + pthread_mutex_lock( &mut_shashmap ); + (*this)[t_key] = t_obj; + pthread_mutex_unlock( &mut_shashmap ); +} + +template +obj_type +shashmap::get_elem(key_type_ t_key) +{ + pthread_mutex_lock( &mut_shashmap ); + obj_type t_ret = hashmap::get_elem(t_key); + pthread_mutex_unlock( &mut_shashmap ); + return t_ret; +} + +template +void +shashmap::del_elem(key_type_ t_key) +{ + pthread_mutex_lock( &mut_shashmap ); + hashmap::erase(t_key); + pthread_mutex_unlock( &mut_shashmap ); +} + +template +void +shashmap::del_elem_insecure(key_type_ t_key) +{ + hashmap::erase(t_key); +} + +template +vector* +shashmap::get_key_vector() +{ + pthread_mutex_lock( &mut_shashmap ); + vector* p_vec = hashmap::get_key_vector(); + pthread_mutex_unlock( &mut_shashmap ); + return p_vec; +} + +template +void +shashmap::clear() +{ + pthread_mutex_lock( &mut_shashmap ); + hashmap::clear(); + pthread_mutex_unlock( &mut_shashmap ); +} + +template +int +shashmap::size() +{ + pthread_mutex_lock( &mut_shashmap ); + int i_size = hashmap::size(); + pthread_mutex_unlock( &mut_shashmap ); + return i_size; +} + +template +bool +shashmap::exists(key_type_ t_key) +{ + pthread_mutex_lock( &mut_shashmap ); + bool b_ret = hashmap::exists(t_key); + pthread_mutex_unlock( &mut_shashmap ); + return b_ret; +} + +template +void +shashmap::run_func( void (*func)(obj_type) ) +{ + pthread_mutex_lock( &mut_shashmap ); + hashmap::run_func(func); + pthread_mutex_unlock( &mut_shashmap ); +} + +template +void +shashmap::run_func( void (*func)(obj_type, void*), void* v_arg ) +{ + pthread_mutex_lock( &mut_shashmap ); + 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