From 9cd3ccffd5372dfde3af478e3f832f18db4be3f1 Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Sat, 6 Apr 2013 13:14:41 +0200 Subject: tagging tags --- yhttpd-0.7.2/src/maps/shashmap.tmpl | 155 ++++++++++++++++++++++++++++++++++++ 1 file changed, 155 insertions(+) create mode 100644 yhttpd-0.7.2/src/maps/shashmap.tmpl (limited to 'yhttpd-0.7.2/src/maps/shashmap.tmpl') diff --git a/yhttpd-0.7.2/src/maps/shashmap.tmpl b/yhttpd-0.7.2/src/maps/shashmap.tmpl new file mode 100644 index 0000000..c864d28 --- /dev/null +++ b/yhttpd-0.7.2/src/maps/shashmap.tmpl @@ -0,0 +1,155 @@ +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