| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 | ////////////////////////////////////////////////////////////////////////////////// (C) Copyright Vicente J. Botet Escriba 2008-2009,2012. 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/thread for documentation.////////////////////////////////////////////////////////////////////////////////#ifndef BOOST_THREAD_POLY_SHARED_LOCKABLE_ADAPTER_HPP#define BOOST_THREAD_POLY_SHARED_LOCKABLE_ADAPTER_HPP#include <boost/thread/poly_lockable_adapter.hpp>#include <boost/thread/poly_shared_lockable.hpp>namespace boost{  //[shared_lockable_adapter  template <typename Mutex, typename Base=poly_shared_lockable>  class poly_shared_lockable_adapter: public poly_timed_lockable_adapter<Mutex, Base>  {  public:    typedef Mutex mutex_type;    void lock_shared()    {      this->mtx().lock_shared();    }    bool try_lock_shared()    {      return this->mtx().try_lock_shared();    }    void unlock_shared()    {      this->mtx().unlock_shared();    }    bool try_lock_shared_until(chrono::system_clock::time_point const & abs_time)    {      return this->mtx().try_lock_shared_until(abs_time);    }    bool try_lock_shared_until(chrono::steady_clock::time_point const & abs_time)    {      return this->mtx().try_lock_shared_until(abs_time);    }    bool try_lock_shared_for(chrono::nanoseconds const & rel_time)    {      return this->mtx().try_lock_shared_for(rel_time);    }  };  //]  //[upgrade_lockable_adapter  template <typename Mutex, typename Base=poly_shared_lockable>  class upgrade_lockable_adapter: public shared_lockable_adapter<Mutex, Base>  {  public:    typedef Mutex mutex_type;    void lock_upgrade()    {      this->mtx().lock_upgrade();    }    bool try_lock_upgrade()    {      return this->mtx().try_lock_upgrade();    }    void unlock_upgrade()    {      this->mtx().unlock_upgrade();    }    bool try_lock_upgrade_until(chrono::system_clock::time_point const & abs_time)    {      return this->mtx().try_lock_upgrade_until(abs_time);    }    bool try_lock_upgrade_until(chrono::steady_clock::time_point const & abs_time)    {      return this->mtx().try_lock_upgrade_until(abs_time);    }    bool try_lock_upgrade_for(chrono::nanoseconds const & rel_time)    {      return this->mtx().try_lock_upgrade_for(rel_time);    }    bool try_unlock_shared_and_lock()    {      return this->mtx().try_unlock_shared_and_lock();    }    bool try_unlock_shared_and_lock_until(chrono::system_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_shared_and_lock_until(abs_time);    }    bool try_unlock_shared_and_lock_until(chrono::steady_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_shared_and_lock_until(abs_time);    }    template <typename Rep, typename Period>    bool try_unlock_shared_and_lock_for(chrono::nanoseconds const & rel_time)    {      return this->mtx().try_unlock_shared_and_lock_for(rel_time);    }    void unlock_and_lock_shared()    {      this->mtx().unlock_and_lock_shared();    }    bool try_unlock_shared_and_lock_upgrade()    {      return this->mtx().try_unlock_shared_and_lock_upgrade();    }    bool try_unlock_shared_and_lock_upgrade_until(chrono::system_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_shared_and_lock_upgrade_until(abs_time);    }    bool try_unlock_shared_and_lock_upgrade_until(chrono::steady_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_shared_and_lock_upgrade_until(abs_time);    }    bool try_unlock_shared_and_lock_upgrade_for(chrono::nanoseconds const & rel_time)    {      return this->mtx().try_unlock_shared_and_lock_upgrade_for(rel_time);    }    void unlock_and_lock_upgrade()    {      this->mtx().unlock_and_lock_upgrade();    }    void unlock_upgrade_and_lock()    {      this->mtx().unlock_upgrade_and_lock();    }    bool try_unlock_upgrade_and_lock()    {      return this->mtx().try_unlock_upgrade_and_lock();    }    bool try_unlock_upgrade_and_lock_until(chrono::system_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_upgrade_and_lock_until(abs_time);    }    bool try_unlock_upgrade_and_lock_until(chrono::steady_clock::time_point const & abs_time)    {      return this->mtx().try_unlock_upgrade_and_lock_until(abs_time);    }    bool try_unlock_upgrade_and_lock_for(chrono::nanoseconds const & rel_time)    {      return this->mtx().try_unlock_upgrade_and_lock_for(rel_time);    }    void unlock_upgrade_and_lock_shared()    {      this->mtx().unlock_upgrade_and_lock_shared();    }  };//]}#endif
 |