]> git.lyx.org Git - features.git/blobdiff - boost/boost/smart_ptr/detail/sp_counted_base_pt.hpp
boost: add eol property
[features.git] / boost / boost / smart_ptr / detail / sp_counted_base_pt.hpp
index 346976437356d35a45a654ed553843bf99306422..3c56fecfc362c56c45fd170db28487dbb1205541 100644 (file)
-#ifndef BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED\r
-#define BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED\r
-\r
-// MS compatible compilers support #pragma once\r
-\r
-#if defined(_MSC_VER) && (_MSC_VER >= 1020)\r
-# pragma once\r
-#endif\r
-\r
-//\r
-//  detail/sp_counted_base_pt.hpp\r
-//\r
-//  Copyright (c) 2001, 2002, 2003 Peter Dimov and Multi Media Ltd.\r
-//  Copyright 2004-2005 Peter Dimov\r
-//\r
-// Distributed under the Boost Software License, Version 1.0. (See\r
-// accompanying file LICENSE_1_0.txt or copy at\r
-// http://www.boost.org/LICENSE_1_0.txt)\r
-//\r
-\r
-#include <boost/detail/sp_typeinfo.hpp>\r
-#include <pthread.h>\r
-\r
-namespace boost\r
-{\r
-\r
-namespace detail\r
-{\r
-\r
-class sp_counted_base\r
-{\r
-private:\r
-\r
-    sp_counted_base( sp_counted_base const & );\r
-    sp_counted_base & operator= ( sp_counted_base const & );\r
-\r
-    long use_count_;        // #shared\r
-    long weak_count_;       // #weak + (#shared != 0)\r
-\r
-    mutable pthread_mutex_t m_;\r
-\r
-public:\r
-\r
-    sp_counted_base(): use_count_( 1 ), weak_count_( 1 )\r
-    {\r
-// HPUX 10.20 / DCE has a nonstandard pthread_mutex_init\r
-\r
-#if defined(__hpux) && defined(_DECTHREADS_)\r
-        pthread_mutex_init( &m_, pthread_mutexattr_default );\r
-#else\r
-        pthread_mutex_init( &m_, 0 );\r
-#endif\r
-    }\r
-\r
-    virtual ~sp_counted_base() // nothrow\r
-    {\r
-        pthread_mutex_destroy( &m_ );\r
-    }\r
-\r
-    // dispose() is called when use_count_ drops to zero, to release\r
-    // the resources managed by *this.\r
-\r
-    virtual void dispose() = 0; // nothrow\r
-\r
-    // destroy() is called when weak_count_ drops to zero.\r
-\r
-    virtual void destroy() // nothrow\r
-    {\r
-        delete this;\r
-    }\r
-\r
-    virtual void * get_deleter( sp_typeinfo const & ti ) = 0;\r
-\r
-    void add_ref_copy()\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        ++use_count_;\r
-        pthread_mutex_unlock( &m_ );\r
-    }\r
-\r
-    bool add_ref_lock() // true on success\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        bool r = use_count_ == 0? false: ( ++use_count_, true );\r
-        pthread_mutex_unlock( &m_ );\r
-        return r;\r
-    }\r
-\r
-    void release() // nothrow\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        long new_use_count = --use_count_;\r
-        pthread_mutex_unlock( &m_ );\r
-\r
-        if( new_use_count == 0 )\r
-        {\r
-            dispose();\r
-            weak_release();\r
-        }\r
-    }\r
-\r
-    void weak_add_ref() // nothrow\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        ++weak_count_;\r
-        pthread_mutex_unlock( &m_ );\r
-    }\r
-\r
-    void weak_release() // nothrow\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        long new_weak_count = --weak_count_;\r
-        pthread_mutex_unlock( &m_ );\r
-\r
-        if( new_weak_count == 0 )\r
-        {\r
-            destroy();\r
-        }\r
-    }\r
-\r
-    long use_count() const // nothrow\r
-    {\r
-        pthread_mutex_lock( &m_ );\r
-        long r = use_count_;\r
-        pthread_mutex_unlock( &m_ );\r
-\r
-        return r;\r
-    }\r
-};\r
-\r
-} // namespace detail\r
-\r
-} // namespace boost\r
-\r
-#endif  // #ifndef BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED\r
+#ifndef BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED
+#define BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED
+
+// MS compatible compilers support #pragma once
+
+#if defined(_MSC_VER) && (_MSC_VER >= 1020)
+# pragma once
+#endif
+
+//
+//  detail/sp_counted_base_pt.hpp
+//
+//  Copyright (c) 2001, 2002, 2003 Peter Dimov and Multi Media Ltd.
+//  Copyright 2004-2005 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)
+//
+
+#include <boost/detail/sp_typeinfo.hpp>
+#include <pthread.h>
+
+namespace boost
+{
+
+namespace detail
+{
+
+class sp_counted_base
+{
+private:
+
+    sp_counted_base( sp_counted_base const & );
+    sp_counted_base & operator= ( sp_counted_base const & );
+
+    long use_count_;        // #shared
+    long weak_count_;       // #weak + (#shared != 0)
+
+    mutable pthread_mutex_t m_;
+
+public:
+
+    sp_counted_base(): use_count_( 1 ), weak_count_( 1 )
+    {
+// HPUX 10.20 / DCE has a nonstandard pthread_mutex_init
+
+#if defined(__hpux) && defined(_DECTHREADS_)
+        pthread_mutex_init( &m_, pthread_mutexattr_default );
+#else
+        pthread_mutex_init( &m_, 0 );
+#endif
+    }
+
+    virtual ~sp_counted_base() // nothrow
+    {
+        pthread_mutex_destroy( &m_ );
+    }
+
+    // dispose() is called when use_count_ drops to zero, to release
+    // the resources managed by *this.
+
+    virtual void dispose() = 0; // nothrow
+
+    // destroy() is called when weak_count_ drops to zero.
+
+    virtual void destroy() // nothrow
+    {
+        delete this;
+    }
+
+    virtual void * get_deleter( sp_typeinfo const & ti ) = 0;
+
+    void add_ref_copy()
+    {
+        pthread_mutex_lock( &m_ );
+        ++use_count_;
+        pthread_mutex_unlock( &m_ );
+    }
+
+    bool add_ref_lock() // true on success
+    {
+        pthread_mutex_lock( &m_ );
+        bool r = use_count_ == 0? false: ( ++use_count_, true );
+        pthread_mutex_unlock( &m_ );
+        return r;
+    }
+
+    void release() // nothrow
+    {
+        pthread_mutex_lock( &m_ );
+        long new_use_count = --use_count_;
+        pthread_mutex_unlock( &m_ );
+
+        if( new_use_count == 0 )
+        {
+            dispose();
+            weak_release();
+        }
+    }
+
+    void weak_add_ref() // nothrow
+    {
+        pthread_mutex_lock( &m_ );
+        ++weak_count_;
+        pthread_mutex_unlock( &m_ );
+    }
+
+    void weak_release() // nothrow
+    {
+        pthread_mutex_lock( &m_ );
+        long new_weak_count = --weak_count_;
+        pthread_mutex_unlock( &m_ );
+
+        if( new_weak_count == 0 )
+        {
+            destroy();
+        }
+    }
+
+    long use_count() const // nothrow
+    {
+        pthread_mutex_lock( &m_ );
+        long r = use_count_;
+        pthread_mutex_unlock( &m_ );
+
+        return r;
+    }
+};
+
+} // namespace detail
+
+} // namespace boost
+
+#endif  // #ifndef BOOST_SMART_PTR_DETAIL_SP_COUNTED_BASE_PT_HPP_INCLUDED