X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fthread_pool_observer.hpp;h=f8ce75aa18081e3b54dacef277daf994be8c7486;hb=16921033f2609ed948cf6985b4fbce3d927a20c1;hp=fb75761a2ec53573dea50eeabc5fb5f9ee8ead83;hpb=016501ca2d40d21abe865a8833c918a7c50412e1;p=metaproxy-moved-to-github.git diff --git a/src/thread_pool_observer.hpp b/src/thread_pool_observer.hpp index fb75761..f8ce75a 100644 --- a/src/thread_pool_observer.hpp +++ b/src/thread_pool_observer.hpp @@ -1,23 +1,18 @@ -/* $Id: thread_pool_observer.hpp,v 1.5 2005-11-04 10:27:51 adam Exp $ - Copyright (c) 2005, Index Data. +/* $Id: thread_pool_observer.hpp,v 1.10 2006-06-10 14:29:13 adam Exp $ + Copyright (c) 2005-2006, Index Data. -%LICENSE% + See the LICENSE file for details */ #ifndef YP2_THREAD_POOL_OBSERVER_HPP #define YP2_THREAD_POOL_OBSERVER_HPP -#include -#include -#include +#include -#include - -#include -#include +#include #include -namespace yp2 { +namespace metaproxy_1 { class IThreadPoolMsg { public: virtual IThreadPoolMsg *handle() = 0; @@ -26,38 +21,19 @@ namespace yp2 { }; class ThreadPoolSocketObserver : public yazpp_1::ISocketObserver { - private: - class Worker { - public: - Worker(ThreadPoolSocketObserver *s) : m_s(s) {}; - ThreadPoolSocketObserver *m_s; - void operator() (void) { - m_s->run(0); - } - }; + class Rep; + class Worker; public: ThreadPoolSocketObserver(yazpp_1::ISocketObservable *obs, int no_threads); virtual ~ThreadPoolSocketObserver(); - void socketNotify(int event); void put(IThreadPoolMsg *m); IThreadPoolMsg *get(); void run(void *p); - int m_fd[2]; private: - yazpp_1::ISocketObservable *m_SocketObservable; - int m_no_threads; - boost::thread_group m_thrds; - - std::deque m_input; - std::deque m_output; - - boost::mutex m_mutex_input_data; - boost::condition m_cond_input_data; - boost::mutex m_mutex_output_data; - bool m_stop_flag; + void socketNotify(int event); + boost::scoped_ptr m_p; - }; } #endif