deluge/libtorrent/include/asio/detail/posix_event.hpp

112 lines
2.5 KiB
C++
Raw Normal View History

2007-07-04 08:24:30 +00:00
//
// posix_event.hpp
// ~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2007 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// 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)
//
#ifndef ASIO_DETAIL_POSIX_EVENT_HPP
#define ASIO_DETAIL_POSIX_EVENT_HPP
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
# pragma once
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
#include "asio/detail/push_options.hpp"
#include "asio/detail/push_options.hpp"
#include <boost/config.hpp>
#include "asio/detail/pop_options.hpp"
#if defined(BOOST_HAS_PTHREADS)
#include "asio/detail/push_options.hpp"
#include <boost/throw_exception.hpp>
#include <pthread.h>
#include "asio/detail/pop_options.hpp"
#include "asio/system_error.hpp"
#include "asio/detail/noncopyable.hpp"
namespace asio {
namespace detail {
class posix_event
: private noncopyable
{
public:
// Constructor.
posix_event()
: signalled_(false)
{
2007-09-21 00:22:38 +00:00
int error = ::pthread_mutex_init(&mutex_, 0);
2007-07-04 08:24:30 +00:00
if (error != 0)
{
asio::system_error e(
2007-09-21 00:22:38 +00:00
asio::error_code(error, asio::native_ecat),
"event");
boost::throw_exception(e);
}
error = ::pthread_cond_init(&cond_, 0);
if (error != 0)
{
::pthread_mutex_destroy(&mutex_);
asio::system_error e(
asio::error_code(error, asio::native_ecat),
2007-07-04 08:24:30 +00:00
"event");
boost::throw_exception(e);
}
}
// Destructor.
~posix_event()
{
::pthread_cond_destroy(&cond_);
2007-09-21 00:22:38 +00:00
::pthread_mutex_destroy(&mutex_);
2007-07-04 08:24:30 +00:00
}
// Signal the event.
2007-09-21 00:22:38 +00:00
void signal()
2007-07-04 08:24:30 +00:00
{
2007-09-21 00:22:38 +00:00
::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK.
2007-07-04 08:24:30 +00:00
signalled_ = true;
::pthread_cond_signal(&cond_); // Ignore EINVAL.
2007-09-21 00:22:38 +00:00
::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM.
2007-07-04 08:24:30 +00:00
}
// Reset the event.
2007-09-21 00:22:38 +00:00
void clear()
2007-07-04 08:24:30 +00:00
{
2007-09-21 00:22:38 +00:00
::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK.
2007-07-04 08:24:30 +00:00
signalled_ = false;
2007-09-21 00:22:38 +00:00
::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM.
2007-07-04 08:24:30 +00:00
}
// Wait for the event to become signalled.
2007-09-21 00:22:38 +00:00
void wait()
2007-07-04 08:24:30 +00:00
{
2007-09-21 00:22:38 +00:00
::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK.
2007-07-04 08:24:30 +00:00
while (!signalled_)
2007-09-21 00:22:38 +00:00
::pthread_cond_wait(&cond_, &mutex_); // Ignore EINVAL.
::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM.
2007-07-04 08:24:30 +00:00
}
private:
2007-09-21 00:22:38 +00:00
::pthread_mutex_t mutex_;
2007-07-04 08:24:30 +00:00
::pthread_cond_t cond_;
bool signalled_;
};
} // namespace detail
} // namespace asio
#endif // defined(BOOST_HAS_PTHREADS)
#include "asio/detail/pop_options.hpp"
#endif // ASIO_DETAIL_POSIX_EVENT_HPP