diff options
author | Minh Ngo <nlminhtl@gmail.com> | 2013-09-08 00:51:43 +0300 |
---|---|---|
committer | Minh Ngo <nlminhtl@gmail.com> | 2013-09-08 00:54:28 +0300 |
commit | 6b1b5b7c0b0e75c625603f3c6025484988cd5482 (patch) | |
tree | 89245461bacee284eff435374eea5c6ec23b2883 /avmedia | |
parent | 6f41d3dbcf618d3636ab456f933354dd5ed17cef (diff) |
Thread safe queue + event handler
Change-Id: I4c08179d6e5e2a6d8a3637e7ca306458cc59dfc8
Diffstat (limited to 'avmedia')
-rw-r--r-- | avmedia/source/vlc/wrapper/EventHandler.cxx | 16 | ||||
-rw-r--r-- | avmedia/source/vlc/wrapper/EventHandler.hxx | 7 | ||||
-rw-r--r-- | avmedia/source/vlc/wrapper/ThreadsafeQueue.hxx | 11 |
3 files changed, 20 insertions, 14 deletions
diff --git a/avmedia/source/vlc/wrapper/EventHandler.cxx b/avmedia/source/vlc/wrapper/EventHandler.cxx index 6104d31fa0e4..188ccbc698c0 100644 --- a/avmedia/source/vlc/wrapper/EventHandler.cxx +++ b/avmedia/source/vlc/wrapper/EventHandler.cxx @@ -11,12 +11,18 @@ namespace VLC { -EventHandler::EventHandler( const char *name ) - : Thread( name ) +EventHandler::EventHandler() + : ::osl::Thread() { } -void EventHandler::execute() +void EventHandler::stop() +{ + mCallbackQueue.push(TCallback()); + join(); +} + +void EventHandler::run() { TCallback callback; do @@ -25,8 +31,8 @@ void EventHandler::execute() if ( callback.empty() ) return; - else - callback(); + + callback(); } while ( true ); } diff --git a/avmedia/source/vlc/wrapper/EventHandler.hxx b/avmedia/source/vlc/wrapper/EventHandler.hxx index f203e399ca99..fbf506987714 100644 --- a/avmedia/source/vlc/wrapper/EventHandler.hxx +++ b/avmedia/source/vlc/wrapper/EventHandler.hxx @@ -15,13 +15,14 @@ namespace VLC { - class EventHandler : public salhelper::Thread + class EventHandler : public ::osl::Thread { public: - EventHandler( const char* name ); + EventHandler(); + void stop(); protected: - virtual void execute(); + virtual void run(); public: typedef boost::function< void() > TCallback; diff --git a/avmedia/source/vlc/wrapper/ThreadsafeQueue.hxx b/avmedia/source/vlc/wrapper/ThreadsafeQueue.hxx index 7f428c42d2e8..52360d4bfe02 100644 --- a/avmedia/source/vlc/wrapper/ThreadsafeQueue.hxx +++ b/avmedia/source/vlc/wrapper/ThreadsafeQueue.hxx @@ -52,22 +52,21 @@ void ThreadsafeQueue<T>::push( const T& data ) { ::osl::MutexGuard guard( mMutex ); mQueue.push( data ); + mMutex.release(); mCondition.set(); } template<class T> void ThreadsafeQueue<T>::pop( T& data ) { - mMutex.acquire(); - if ( mQueue.empty() ) + mCondition.wait(); + ::osl::MutexGuard guard( mMutex ); + while ( mQueue.empty() ) { mMutex.release(); mCondition.wait(); - mCondition.reset(); + mMutex.acquire(); } - - ::osl::MutexGuard guard( mMutex ); - data = mQueue.front(); mQueue.pop(); } |