| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 | #ifndef BOOST_SMART_PTR_DETAIL_LWM_WIN32_CS_HPP_INCLUDED#define BOOST_SMART_PTR_DETAIL_LWM_WIN32_CS_HPP_INCLUDED// MS compatible compilers support #pragma once#if defined(_MSC_VER) && (_MSC_VER >= 1020)# pragma once#endif////  boost/detail/lwm_win32_cs.hpp////  Copyright (c) 2002, 2003 Peter Dimov//// 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)//#ifdef BOOST_USE_WINDOWS_H#include <windows.h>#elsestruct _RTL_CRITICAL_SECTION;#endifnamespace boost{namespace detail{#ifndef BOOST_USE_WINDOWS_Hstruct critical_section{    struct critical_section_debug * DebugInfo;    long LockCount;    long RecursionCount;    void * OwningThread;    void * LockSemaphore;#if defined(_WIN64)    unsigned __int64 SpinCount;#else    unsigned long SpinCount;#endif};extern "C" __declspec(dllimport) void __stdcall InitializeCriticalSection(::_RTL_CRITICAL_SECTION *);extern "C" __declspec(dllimport) void __stdcall EnterCriticalSection(::_RTL_CRITICAL_SECTION *);extern "C" __declspec(dllimport) void __stdcall LeaveCriticalSection(::_RTL_CRITICAL_SECTION *);extern "C" __declspec(dllimport) void __stdcall DeleteCriticalSection(::_RTL_CRITICAL_SECTION *);typedef ::_RTL_CRITICAL_SECTION rtl_critical_section;#else // #ifndef BOOST_USE_WINDOWS_Htypedef ::CRITICAL_SECTION critical_section;using ::InitializeCriticalSection;using ::EnterCriticalSection;using ::LeaveCriticalSection;using ::DeleteCriticalSection;typedef ::CRITICAL_SECTION rtl_critical_section;#endif // #ifndef BOOST_USE_WINDOWS_Hclass lightweight_mutex{private:    critical_section cs_;    lightweight_mutex(lightweight_mutex const &);    lightweight_mutex & operator=(lightweight_mutex const &);public:    lightweight_mutex()    {        boost::detail::InitializeCriticalSection(reinterpret_cast< rtl_critical_section* >(&cs_));    }    ~lightweight_mutex()    {        boost::detail::DeleteCriticalSection(reinterpret_cast< rtl_critical_section* >(&cs_));    }    class scoped_lock;    friend class scoped_lock;    class scoped_lock    {    private:        lightweight_mutex & m_;        scoped_lock(scoped_lock const &);        scoped_lock & operator=(scoped_lock const &);    public:        explicit scoped_lock(lightweight_mutex & m): m_(m)        {            boost::detail::EnterCriticalSection(reinterpret_cast< rtl_critical_section* >(&m_.cs_));        }        ~scoped_lock()        {            boost::detail::LeaveCriticalSection(reinterpret_cast< rtl_critical_section* >(&m_.cs_));        }    };};} // namespace detail} // namespace boost#endif // #ifndef BOOST_SMART_PTR_DETAIL_LWM_WIN32_CS_HPP_INCLUDED
 |