]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/smart_ptr/test/intrusive_ptr_move_test.cpp
1 #include <boost/config.hpp>
3 #if defined(BOOST_MSVC)
5 #pragma warning(disable: 4786) // identifier truncated in debug info
6 #pragma warning(disable: 4710) // function not inlined
7 #pragma warning(disable: 4711) // function selected for automatic inline expansion
8 #pragma warning(disable: 4514) // unreferenced inline removed
9 #pragma warning(disable: 4355) // 'this' : used in base member initializer list
10 #pragma warning(disable: 4511) // copy constructor could not be generated
11 #pragma warning(disable: 4512) // assignment operator could not be generated
13 #if (BOOST_MSVC >= 1310)
14 #pragma warning(disable: 4675) // resolved overload found with Koenig lookup
20 // intrusive_ptr_move_test.cpp
22 // Copyright (c) 2002-2005 Peter Dimov
24 // Distributed under the Boost Software License, Version 1.0. (See
25 // accompanying file LICENSE_1_0.txt or copy at
26 // http://www.boost.org/LICENSE_1_0.txt)
29 #include <boost/detail/lightweight_test.hpp>
30 #include <boost/intrusive_ptr.hpp>
31 #include <boost/detail/atomic_count.hpp>
32 #include <boost/config.hpp>
35 #if !defined( BOOST_NO_CXX11_RVALUE_REFERENCES )
44 mutable boost::detail::atomic_count use_count_
;
47 base
& operator=(base
const &);
63 static long instances
;
65 long use_count() const
70 #if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
72 inline friend void intrusive_ptr_add_ref(base
const * p
)
77 inline friend void intrusive_ptr_release(base
const * p
)
79 if(--p
->use_count_
== 0) delete p
;
91 if(--use_count_
== 0) delete this;
97 long base::instances
= 0;
101 #if defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
106 inline void intrusive_ptr_add_ref(N::base
const * p
)
111 inline void intrusive_ptr_release(N::base
const * p
)
122 struct X
: public virtual N::base
132 BOOST_TEST( N::base::instances
== 0 );
135 boost::intrusive_ptr
<X
> p( new X
);
136 BOOST_TEST( N::base::instances
== 1 );
138 boost::intrusive_ptr
<X
> p2( std::move( p
) );
139 BOOST_TEST( N::base::instances
== 1 );
140 BOOST_TEST( p
.get() == 0 );
143 BOOST_TEST( N::base::instances
== 0 );
147 boost::intrusive_ptr
<Y
> p( new Y
);
148 BOOST_TEST( N::base::instances
== 1 );
150 boost::intrusive_ptr
<X
> p2( std::move( p
) );
151 BOOST_TEST( N::base::instances
== 1 );
152 BOOST_TEST( p
.get() == 0 );
155 BOOST_TEST( N::base::instances
== 0 );
159 boost::intrusive_ptr
<X
> p( new X
);
160 BOOST_TEST( N::base::instances
== 1 );
162 boost::intrusive_ptr
<X
> p2
;
164 BOOST_TEST( N::base::instances
== 1 );
165 BOOST_TEST( p
.get() == 0 );
168 BOOST_TEST( N::base::instances
== 0 );
172 boost::intrusive_ptr
<X
> p( new X
);
173 BOOST_TEST( N::base::instances
== 1 );
175 boost::intrusive_ptr
<X
> p2( new X
);
176 BOOST_TEST( N::base::instances
== 2 );
178 BOOST_TEST( N::base::instances
== 1 );
179 BOOST_TEST( p
.get() == 0 );
182 BOOST_TEST( N::base::instances
== 0 );
186 boost::intrusive_ptr
<Y
> p( new Y
);
187 BOOST_TEST( N::base::instances
== 1 );
189 boost::intrusive_ptr
<X
> p2
;
191 BOOST_TEST( N::base::instances
== 1 );
192 BOOST_TEST( p
.get() == 0 );
195 BOOST_TEST( N::base::instances
== 0 );
199 boost::intrusive_ptr
<Y
> p( new Y
);
200 BOOST_TEST( N::base::instances
== 1 );
202 boost::intrusive_ptr
<X
> p2( new X
);
203 BOOST_TEST( N::base::instances
== 2 );
205 BOOST_TEST( N::base::instances
== 1 );
206 BOOST_TEST( p
.get() == 0 );
209 BOOST_TEST( N::base::instances
== 0 );
213 boost::intrusive_ptr
<X
> px( new Y
);
217 boost::intrusive_ptr
<Y
> py
= boost::static_pointer_cast
<Y
>( std::move( px
) );
218 BOOST_TEST( py
.get() == px2
);
219 BOOST_TEST( px
.get() == 0 );
220 BOOST_TEST( py
->use_count() == 1 );
223 BOOST_TEST( N::base::instances
== 0 );
226 boost::intrusive_ptr
<X
const> px( new X
);
228 X
const * px2
= px
.get();
230 boost::intrusive_ptr
<X
> px3
= boost::const_pointer_cast
<X
>( std::move( px
) );
231 BOOST_TEST( px3
.get() == px2
);
232 BOOST_TEST( px
.get() == 0 );
233 BOOST_TEST( px3
->use_count() == 1 );
236 BOOST_TEST( N::base::instances
== 0 );
239 boost::intrusive_ptr
<X
> px( new Y
);
243 boost::intrusive_ptr
<Y
> py
= boost::dynamic_pointer_cast
<Y
>( std::move( px
) );
244 BOOST_TEST( py
.get() == px2
);
245 BOOST_TEST( px
.get() == 0 );
246 BOOST_TEST( py
->use_count() == 1 );
249 BOOST_TEST( N::base::instances
== 0 );
252 boost::intrusive_ptr
<X
> px( new X
);
256 boost::intrusive_ptr
<Y
> py
= boost::dynamic_pointer_cast
<Y
>( std::move( px
) );
257 BOOST_TEST( py
.get() == 0 );
258 BOOST_TEST( px
.get() == px2
);
259 BOOST_TEST( px
->use_count() == 1 );
262 BOOST_TEST( N::base::instances
== 0 );
264 return boost::report_errors();
267 #else // defined( BOOST_NO_CXX11_RVALUE_REFERENCES )