// // posix_event.hpp // ~~~~~~~~~~~~~~~ // // Copyright (c) 2003-2006 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 BOOST_ASIO_DETAIL_POSIX_EVENT_HPP #define BOOST_ASIO_DETAIL_POSIX_EVENT_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif // defined(_MSC_VER) && (_MSC_VER >= 1200) #include #include #include #include #if defined(BOOST_HAS_PTHREADS) #include #include #include #include #include #include namespace boost { namespace asio { namespace detail { class posix_event : private noncopyable { public: // Constructor. posix_event() : signalled_(false) { int error = ::pthread_mutex_init(&mutex_, 0); if (error != 0) { system_exception e("event", error); boost::throw_exception(e); } error = ::pthread_cond_init(&cond_, 0); if (error != 0) { ::pthread_mutex_destroy(&mutex_); system_exception e("event", error); boost::throw_exception(e); } } // Destructor. ~posix_event() { ::pthread_cond_destroy(&cond_); ::pthread_mutex_destroy(&mutex_); } // Signal the event. void signal() { ::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK. signalled_ = true; ::pthread_cond_signal(&cond_); // Ignore EINVAL. ::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM. } // Reset the event. void clear() { ::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK. signalled_ = false; ::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM. } // Wait for the event to become signalled. void wait() { ::pthread_mutex_lock(&mutex_); // Ignore EINVAL and EDEADLK. while (!signalled_) ::pthread_cond_wait(&cond_, &mutex_); // Ignore EINVAL. ::pthread_mutex_unlock(&mutex_); // Ignore EINVAL and EPERM. } private: ::pthread_mutex_t mutex_; ::pthread_cond_t cond_; bool signalled_; }; } // namespace detail } // namespace asio } // namespace boost #endif // defined(BOOST_HAS_PTHREADS) #include #endif // BOOST_ASIO_DETAIL_POSIX_EVENT_HPP