blob: f13612890784c7be02f605961a9d226c1a048e1c [file] [log] [blame]
//////////////////////////////////////////////////////////////////////////////
//
// (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