]> git.lyx.org Git - lyx.git/blob - boost/boost/smart_ptr/scoped_ptr.hpp
Cmake build: Omit files with names not starting with aplha character.
[lyx.git] / boost / boost / smart_ptr / scoped_ptr.hpp
1 #ifndef BOOST_SMART_PTR_SCOPED_PTR_HPP_INCLUDED
2 #define BOOST_SMART_PTR_SCOPED_PTR_HPP_INCLUDED
3
4 //  (C) Copyright Greg Colvin and Beman Dawes 1998, 1999.
5 //  Copyright (c) 2001, 2002 Peter Dimov
6 //
7 //  Distributed under the Boost Software License, Version 1.0. (See
8 //  accompanying file LICENSE_1_0.txt or copy at
9 //  http://www.boost.org/LICENSE_1_0.txt)
10 //
11 //  http://www.boost.org/libs/smart_ptr/scoped_ptr.htm
12 //
13
14 #include <boost/config.hpp>
15 #include <boost/assert.hpp>
16 #include <boost/checked_delete.hpp>
17 #include <boost/smart_ptr/detail/sp_nullptr_t.hpp>
18 #include <boost/detail/workaround.hpp>
19
20 #ifndef BOOST_NO_AUTO_PTR
21 # include <memory>          // for std::auto_ptr
22 #endif
23
24 namespace boost
25 {
26
27 // Debug hooks
28
29 #if defined(BOOST_SP_ENABLE_DEBUG_HOOKS)
30
31 void sp_scalar_constructor_hook(void * p);
32 void sp_scalar_destructor_hook(void * p);
33
34 #endif
35
36 //  scoped_ptr mimics a built-in pointer except that it guarantees deletion
37 //  of the object pointed to, either on destruction of the scoped_ptr or via
38 //  an explicit reset(). scoped_ptr is a simple solution for simple needs;
39 //  use shared_ptr or std::auto_ptr if your needs are more complex.
40
41 template<class T> class scoped_ptr // noncopyable
42 {
43 private:
44
45     T * px;
46
47     scoped_ptr(scoped_ptr const &);
48     scoped_ptr & operator=(scoped_ptr const &);
49
50     typedef scoped_ptr<T> this_type;
51
52     void operator==( scoped_ptr const& ) const;
53     void operator!=( scoped_ptr const& ) const;
54
55 public:
56
57     typedef T element_type;
58
59     explicit scoped_ptr( T * p = 0 ): px( p ) // never throws
60     {
61 #if defined(BOOST_SP_ENABLE_DEBUG_HOOKS)
62         boost::sp_scalar_constructor_hook( px );
63 #endif
64     }
65
66 #ifndef BOOST_NO_AUTO_PTR
67
68     explicit scoped_ptr( std::auto_ptr<T> p ) BOOST_NOEXCEPT : px( p.release() )
69     {
70 #if defined(BOOST_SP_ENABLE_DEBUG_HOOKS)
71         boost::sp_scalar_constructor_hook( px );
72 #endif
73     }
74
75 #endif
76
77     ~scoped_ptr() // never throws
78     {
79 #if defined(BOOST_SP_ENABLE_DEBUG_HOOKS)
80         boost::sp_scalar_destructor_hook( px );
81 #endif
82         boost::checked_delete( px );
83     }
84
85     void reset(T * p = 0) // never throws
86     {
87         BOOST_ASSERT( p == 0 || p != px ); // catch self-reset errors
88         this_type(p).swap(*this);
89     }
90
91     T & operator*() const // never throws
92     {
93         BOOST_ASSERT( px != 0 );
94         return *px;
95     }
96
97     T * operator->() const // never throws
98     {
99         BOOST_ASSERT( px != 0 );
100         return px;
101     }
102
103     T * get() const BOOST_NOEXCEPT
104     {
105         return px;
106     }
107
108 // implicit conversion to "bool"
109 #include <boost/smart_ptr/detail/operator_bool.hpp>
110
111     void swap(scoped_ptr & b) BOOST_NOEXCEPT
112     {
113         T * tmp = b.px;
114         b.px = px;
115         px = tmp;
116     }
117 };
118
119 #if !defined( BOOST_NO_CXX11_NULLPTR )
120
121 template<class T> inline bool operator==( scoped_ptr<T> const & p, boost::detail::sp_nullptr_t ) BOOST_NOEXCEPT
122 {
123     return p.get() == 0;
124 }
125
126 template<class T> inline bool operator==( boost::detail::sp_nullptr_t, scoped_ptr<T> const & p ) BOOST_NOEXCEPT
127 {
128     return p.get() == 0;
129 }
130
131 template<class T> inline bool operator!=( scoped_ptr<T> const & p, boost::detail::sp_nullptr_t ) BOOST_NOEXCEPT
132 {
133     return p.get() != 0;
134 }
135
136 template<class T> inline bool operator!=( boost::detail::sp_nullptr_t, scoped_ptr<T> const & p ) BOOST_NOEXCEPT
137 {
138     return p.get() != 0;
139 }
140
141 #endif
142
143 template<class T> inline void swap(scoped_ptr<T> & a, scoped_ptr<T> & b) BOOST_NOEXCEPT
144 {
145     a.swap(b);
146 }
147
148 // get_pointer(p) is a generic way to say p.get()
149
150 template<class T> inline T * get_pointer(scoped_ptr<T> const & p) BOOST_NOEXCEPT
151 {
152     return p.get();
153 }
154
155 } // namespace boost
156
157 #endif // #ifndef BOOST_SMART_PTR_SCOPED_PTR_HPP_INCLUDED