boost/interprocess/sync/emulation/interprocess_semaphore.hpp
//////////////////////////////////////////////////////////////////////////////
//
// (C) Copyright Ion Gaztanaga 2005-2008. Distributed under the Boost
// Software License, Version 1.0. (See accompanying file
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
// See http://www.boost.org/libs/interprocess for documentation.
//
//////////////////////////////////////////////////////////////////////////////
#include<boost/interprocess/exceptions.hpp>
#include <boost/interprocess/detail/posix_time_types_wrk.hpp>
#include <boost/interprocess/sync/scoped_lock.hpp>
namespace boost {
namespace interprocess {
inline interprocess_semaphore::~interprocess_semaphore()
{}
inline interprocess_semaphore::interprocess_semaphore(int initialCount)
: m_mut(), m_cond(), m_count(initialCount)
{}
inline void interprocess_semaphore::post()
{
scoped_lock<interprocess_mutex> lock(m_mut);
if(m_count == 0){
m_cond.notify_one();
}
++m_count;
}
inline void interprocess_semaphore::wait()
{
scoped_lock<interprocess_mutex> lock(m_mut);
while(m_count == 0){
m_cond.wait(lock);
}
--m_count;
}
inline bool interprocess_semaphore::try_wait()
{
scoped_lock<interprocess_mutex> lock(m_mut);
if(m_count == 0){
return false;
}
--m_count;
return true;
}
inline bool interprocess_semaphore::timed_wait(const boost::posix_time::ptime &abs_time)
{
if(abs_time == boost::posix_time::pos_infin){
this->wait();
return true;
}
scoped_lock<interprocess_mutex> lock(m_mut);
while(m_count == 0){
if(!m_cond.timed_wait(lock, abs_time))
return m_count != 0;
}
--m_count;
return true;
}
/*
inline int interprocess_semaphore::get_count() const
{
scoped_lock<interprocess_mutex> lock(m_mut);
return count;
}*/
} //namespace interprocess {
} //namespace boost {