PATH:
opt
/
cpanel
/
ea-ruby27
/
src
/
passenger-release-6.1.2
/
src
/
cxx_supportlib
/
vendor-modified
/
boost
/
thread
// (C) Copyright 2012 Vicente J. Botet Escriba // 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_THREAD_EXTERNALLY_LOCKED_STREAM_HPP #define BOOST_THREAD_EXTERNALLY_LOCKED_STREAM_HPP #include <boost/thread/detail/config.hpp> #include <boost/thread/detail/move.hpp> #include <boost/thread/detail/delete.hpp> #include <boost/thread/externally_locked.hpp> #include <boost/thread/lock_traits.hpp> #include <boost/thread/recursive_mutex.hpp> #include <boost/thread/strict_lock.hpp> #include <boost/config/abi_prefix.hpp> namespace boost { template <typename Stream, typename RecursiveMutex=recursive_mutex> class externally_locked_stream; template <class Stream, typename RecursiveMutex=recursive_mutex> class stream_guard { friend class externally_locked_stream<Stream, RecursiveMutex> ; public: typedef typename externally_locked_stream<Stream, RecursiveMutex>::mutex_type mutex_type; BOOST_THREAD_MOVABLE_ONLY( stream_guard) stream_guard(externally_locked_stream<Stream, RecursiveMutex>& mtx) : mtx_(&mtx) { mtx.lock(); } stream_guard(externally_locked_stream<Stream, RecursiveMutex>& mtx, adopt_lock_t) : mtx_(&mtx) { } stream_guard(BOOST_THREAD_RV_REF(stream_guard) rhs) BOOST_NOEXCEPT : mtx_(rhs.mtx_) { rhs.mtx_= 0; } ~stream_guard() { if (mtx_ != 0) mtx_->unlock(); } bool owns_lock(const mutex_type * l) const BOOST_NOEXCEPT { return l == mtx_->mutex(); } /** * @Requires mtx_ */ Stream& get() const { BOOST_THREAD_ASSERT_PRECONDITION( mtx_, lock_error() ); return mtx_->get(*this); } Stream& bypass() const { return get(); } private: externally_locked_stream<Stream, RecursiveMutex>* mtx_; }; template <typename Stream, typename RecursiveMutex> struct is_strict_lock_sur_parole<stream_guard<Stream, RecursiveMutex> > : true_type { }; /** * externally_locked_stream cloaks a reference to an stream of type Stream, and actually * provides full access to that object through the get and set member functions, provided you * pass a reference to a strict lock object. */ //[externally_locked_stream template <typename Stream, typename RecursiveMutex> class externally_locked_stream: public externally_locked<Stream&, RecursiveMutex> { typedef externally_locked<Stream&, RecursiveMutex> base_type; public: BOOST_THREAD_NO_COPYABLE( externally_locked_stream) /** * Effects: Constructs an externally locked object storing the cloaked reference object. */ externally_locked_stream(Stream& stream, RecursiveMutex& mtx) BOOST_NOEXCEPT : base_type(stream, mtx) { } stream_guard<Stream, RecursiveMutex> hold() BOOST_NOEXCEPT { return stream_guard<Stream, RecursiveMutex> (*this); } Stream& bypass() const { stream_guard<Stream, RecursiveMutex> lk(*this); return get(lk); } }; //] template <typename Stream, typename RecursiveMutex, typename T> inline const stream_guard<Stream, RecursiveMutex>& operator<<(const stream_guard<Stream, RecursiveMutex>& lck, T arg) { lck.get() << arg; return lck; } template <typename Stream, typename RecursiveMutex> inline const stream_guard<Stream, RecursiveMutex>& operator<<(const stream_guard<Stream, RecursiveMutex>& lck, Stream& (*arg)(Stream&)) { lck.get() << arg; return lck; } template <typename Stream, typename RecursiveMutex, typename T> inline const stream_guard<Stream, RecursiveMutex>& operator>>(const stream_guard<Stream, RecursiveMutex>& lck, T& arg) { lck.get() >> arg; return lck; } template <typename Stream, typename RecursiveMutex, typename T> inline stream_guard<Stream, RecursiveMutex> operator<<(externally_locked_stream<Stream, RecursiveMutex>& mtx, T arg) { stream_guard<Stream, RecursiveMutex> lk(mtx); mtx.get(lk) << arg; return boost::move(lk); } template <typename Stream, typename RecursiveMutex> inline stream_guard<Stream, RecursiveMutex> operator<<(externally_locked_stream<Stream, RecursiveMutex>& mtx, Stream& (*arg)(Stream&)) { stream_guard<Stream, RecursiveMutex> lk(mtx); mtx.get(lk) << arg; return boost::move(lk); } template <typename Stream, typename RecursiveMutex, typename T> inline stream_guard<Stream, RecursiveMutex> operator>>(externally_locked_stream<Stream, RecursiveMutex>& mtx, T& arg) { stream_guard<Stream, RecursiveMutex> lk(mtx); mtx.get(lk) >> arg; return boost::move(lk); } } #include <boost/config/abi_suffix.hpp> #endif // header
[-] caller_context.hpp
[edit]
[-] thread_time.hpp
[edit]
[-] thread_guard.hpp
[edit]
[+]
csbl
[-] scoped_thread.hpp
[edit]
[+]
concurrent_queues
[-] with_lock_guard.hpp
[edit]
[-] ostream_buffer.hpp
[edit]
[-] testable_mutex.hpp
[edit]
[-] lockable_traits.hpp
[edit]
[-] externally_locked.hpp
[edit]
[+]
v2
[-] lock_concepts.hpp
[edit]
[-] thread.hpp
[edit]
[-] is_locked_by_this_thread.hpp
[edit]
[-] locks.hpp
[edit]
[-] latch.hpp
[edit]
[-] barrier.hpp
[edit]
[-] condition.hpp
[edit]
[-] thread_pool.hpp
[edit]
[-] shared_lock_guard.hpp
[edit]
[-] cv_status.hpp
[edit]
[+]
..
[-] condition_variable.hpp
[edit]
[-] thread_only.hpp
[edit]
[-] exceptions.hpp
[edit]
[+]
executors
[-] sync_bounded_queue.hpp
[edit]
[-] poly_lockable.hpp
[edit]
[-] lock_guard.hpp
[edit]
[+]
experimental
[-] future.hpp
[edit]
[-] lock_types.hpp
[edit]
[+]
futures
[-] sync_queue.hpp
[edit]
[-] exceptional_ptr.hpp
[edit]
[-] lock_traits.hpp
[edit]
[-] mutex.hpp
[edit]
[-] lock_options.hpp
[edit]
[-] poly_lockable_adapter.hpp
[edit]
[-] poly_shared_lockable.hpp
[edit]
[-] interruption.hpp
[edit]
[-] poly_shared_lockable_adapter.hpp
[edit]
[-] synchronized_value.hpp
[edit]
[-] executor.hpp
[edit]
[-] completion_latch.hpp
[edit]
[-] lock_algorithms.hpp
[edit]
[-] tss.hpp
[edit]
[+]
detail
[+]
pthread
[-] recursive_mutex.hpp
[edit]
[-] lock_factories.hpp
[edit]
[-] user_scheduler.hpp
[edit]
[-] null_mutex.hpp
[edit]
[-] lockable_adapter.hpp
[edit]
[-] strict_lock.hpp
[edit]
[-] lockable_concepts.hpp
[edit]
[-] reverse_lock.hpp
[edit]
[-] shared_mutex.hpp
[edit]
[-] xtime.hpp
[edit]
[-] externally_locked_stream.hpp
[edit]
[-] once.hpp
[edit]
[-] thread_functors.hpp
[edit]