diff options
Diffstat (limited to '3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp')
| -rw-r--r-- | 3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp | 29 | 
1 files changed, 19 insertions, 10 deletions
| diff --git a/3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp b/3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp index 2a6bc7d..9330d77 100644 --- a/3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp +++ b/3rdParty/Boost/src/boost/thread/pthread/recursive_mutex.hpp @@ -9,7 +9,9 @@  #include <pthread.h>  #include <boost/throw_exception.hpp>  #include <boost/thread/exceptions.hpp> -#include <boost/thread/locks.hpp> +#if defined BOOST_THREAD_PROVIDES_NESTED_LOCKS +#include <boost/thread/lock_types.hpp> +#endif  #include <boost/thread/thread_time.hpp>  #include <boost/assert.hpp>  #ifndef _WIN32 @@ -26,10 +28,13 @@  #include <boost/thread/detail/delete.hpp>  #ifdef _POSIX_TIMEOUTS -#if _POSIX_TIMEOUTS >= 0 +#if _POSIX_TIMEOUTS >= 0 && _POSIX_TIMEOUTS>=200112L +#ifndef BOOST_PTHREAD_HAS_TIMEDLOCK  #define BOOST_PTHREAD_HAS_TIMEDLOCK  #endif  #endif +#endif +  #if defined(BOOST_HAS_PTHREAD_MUTEXATTR_SETTYPE) && defined(BOOST_PTHREAD_HAS_TIMEDLOCK)  #define BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK @@ -167,8 +172,10 @@ namespace boost  #endif +#if defined BOOST_THREAD_PROVIDES_NESTED_LOCKS          typedef unique_lock<recursive_mutex> scoped_lock;          typedef detail::try_lock_wrapper<recursive_mutex> scoped_try_lock; +#endif      };      typedef recursive_mutex recursive_try_mutex; @@ -232,11 +239,13 @@ namespace boost  #endif          } +#if defined BOOST_THREAD_USES_DATETIME          template<typename TimeDuration>          bool timed_lock(TimeDuration const & relative_time)          {              return timed_lock(get_system_time()+relative_time);          } +#endif  #ifdef BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK          void lock() @@ -334,12 +343,13 @@ namespace boost  #endif +#if defined BOOST_THREAD_USES_DATETIME          bool timed_lock(system_time const & abs_time)          { -            struct timespec const ts=detail::get_timespec(abs_time); +            struct timespec const ts=detail::to_timespec(abs_time);              return do_try_lock_until(ts);          } - +#endif  #ifdef BOOST_THREAD_USES_CHRONO          template <class Rep, class Period>          bool try_lock_for(const chrono::duration<Rep, Period>& rel_time) @@ -363,12 +373,9 @@ namespace boost          }          bool try_lock_until(const chrono::time_point<chrono::system_clock, chrono::nanoseconds>& tp)          { -          using namespace chrono; -          nanoseconds d = tp.time_since_epoch(); -          timespec ts; -          seconds s = duration_cast<seconds>(d); -          ts.tv_sec = static_cast<long>(s.count()); -          ts.tv_nsec = static_cast<long>((d - s).count()); +          //using namespace chrono; +          chrono::nanoseconds d = tp.time_since_epoch(); +          timespec ts = boost::detail::to_timespec(d);            return do_try_lock_until(ts);          }  #endif @@ -380,9 +387,11 @@ namespace boost              return &m;          } +#if defined BOOST_THREAD_PROVIDES_NESTED_LOCKS          typedef unique_lock<recursive_timed_mutex> scoped_timed_lock;          typedef detail::try_lock_wrapper<recursive_timed_mutex> scoped_try_lock;          typedef scoped_timed_lock scoped_lock; +#endif      };  } | 
 Swift
 Swift