summaryrefslogtreecommitdiff
path: root/src/thrd/pool.h
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2013-04-06 13:14:48 +0200
committerPaul Buetow <paul@buetow.org>2013-04-06 13:14:48 +0200
commitbf5fc4cc4a15e8e57db58c2e065e0f5adbd8e800 (patch)
tree855a98aec6d09361074c9725e08063553044ecfb /src/thrd/pool.h
parentd9c4a95345bd758e45196b29368bd2ff0f2790e3 (diff)
tagging ychat-0.7.9.3ychat-0.7.9.3
Diffstat (limited to 'src/thrd/pool.h')
-rwxr-xr-xsrc/thrd/pool.h82
1 files changed, 30 insertions, 52 deletions
diff --git a/src/thrd/pool.h b/src/thrd/pool.h
index a744133..3a5f7b6 100755
--- a/src/thrd/pool.h
+++ b/src/thrd/pool.h
@@ -3,74 +3,52 @@
#ifndef POOL_H
#define POOL_H
+#include <queue>
+
using namespace std;
class pool
{
private:
- typedef struct tpool_work
- {
- void (*routine)(void*); ///
- void *arg;
- struct tpool_work *next;
- }
- tpool_work_t;
-
- typedef struct tpool
- {
- // pool characteristics:
- int num_threads;
- int max_queue_size;
- int do_not_block_when_full;
-
- // pool state
- pthread_t *threads;
- int cur_queue_size;
+ friend class thro;
- tpool_work_t *queue_head;
- tpool_work_t *queue_tail;
+ struct task
+ {
+ void(*p_func)(void*);
+ void *p_void;
- pthread_mutex_t queue_lock;
- pthread_cond_t queue_not_empty;
- pthread_cond_t queue_not_full;
- pthread_cond_t queue_empty;
-
- int queue_closed;
- int shutdown;
+ task(void(*p_func)(void*), void *p_void)
+ {
+ this->p_func = p_func;
+ this->p_void = p_void;
}
- *tpool_t;
+ };
- int i_thrd_pool_size;
- int i_thrd_pool_queue;
+ pthread_mutex_t mut_threads;
+ pthread_mutex_t mut_queue_tasks;
+ pthread_mutex_t mut_num_avail_threads;
+ pthread_cond_t cond_new_task;
- tpool_t thread_pool;
+ int i_num_avail_threads;
+ int i_num_total_threads;
- void
- tpool_init( tpool_t *tpoolp, int num_worker_threads, int max_queue_size, int do_not_block_when_full );
+ queue<task*> queue_tasks;
- int
- tpool_add_work( tpool_t tpool, void(*routine)(void*), void* arg );
+ int increase_pool(int i_num);
+ void add_task( void(*p_func)(void*), void* p_void );
+ static void* wait_for_task(void *p_void);
+ static void run_func(void *p_void);
- // virtual void
- // tpool_destroy( tpool_t tpoolp, int finish );
-
- static void*
- tpool_thread( void* arg);
-
- static void
- run_func( void *v_pointer );
-
- // public methods:
public:
- pool( );
+ pool();
+ ~pool();
+
+ void run(void* p_void);
+ bool allow_user_login();
- // inline (speed)!
- void run( void *arg )
- {
- tpool_add_work( thread_pool, run_func, arg );
- }
#ifdef NCURSES
- void print_pool_size();
+
+ void print_pool_size();
#endif
};