]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/smart_ptr/test/shared_ptr_basic_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
11 #if (BOOST_MSVC >= 1310)
12 #pragma warning(disable: 4675) // resolved overload found with Koenig lookup
18 // shared_ptr_basic_test.cpp
20 // Copyright (c) 2001, 2002 Peter Dimov and Multi Media Ltd.
22 // Distributed under the Boost Software License, Version 1.0. (See
23 // accompanying file LICENSE_1_0.txt or copy at
24 // http://www.boost.org/LICENSE_1_0.txt)
27 #include <boost/detail/lightweight_test.hpp>
29 #include <boost/shared_ptr.hpp>
30 #include <boost/weak_ptr.hpp>
41 ~X() // virtual destructor deliberately omitted
46 virtual int id() const
54 X
& operator= (X
const &);
69 virtual int id() const
77 Y
& operator= (Y
const &);
86 void release_object(int * p
)
88 BOOST_TEST(p
== &cnt
);
92 template<class T
> void test_is_X(boost::shared_ptr
<T
> const & p
)
94 BOOST_TEST(p
->id() == 1);
95 BOOST_TEST((*p
).id() == 1);
98 template<class T
> void test_is_X(boost::weak_ptr
<T
> const & p
)
100 BOOST_TEST(p
.get() != 0);
101 BOOST_TEST(p
.get()->id() == 1);
104 template<class T
> void test_is_Y(boost::shared_ptr
<T
> const & p
)
106 BOOST_TEST(p
->id() == 2);
107 BOOST_TEST((*p
).id() == 2);
110 template<class T
> void test_is_Y(boost::weak_ptr
<T
> const & p
)
112 boost::shared_ptr
<T
> q
= p
.lock();
113 BOOST_TEST(q
.get() != 0);
114 BOOST_TEST(q
->id() == 2);
117 template<class T
> void test_eq(T
const & a
, T
const & b
)
120 BOOST_TEST(!(a
!= b
));
121 BOOST_TEST(!(a
< b
));
122 BOOST_TEST(!(b
< a
));
125 template<class T
> void test_ne(T
const & a
, T
const & b
)
127 BOOST_TEST(!(a
== b
));
129 BOOST_TEST(a
< b
|| b
< a
);
130 BOOST_TEST(!(a
< b
&& b
< a
));
133 template<class T
, class U
> void test_shared(boost::weak_ptr
<T
> const & a
, boost::weak_ptr
<U
> const & b
)
135 BOOST_TEST(!(a
< b
));
136 BOOST_TEST(!(b
< a
));
139 template<class T
, class U
> void test_nonshared(boost::weak_ptr
<T
> const & a
, boost::weak_ptr
<U
> const & b
)
141 BOOST_TEST(a
< b
|| b
< a
);
142 BOOST_TEST(!(a
< b
&& b
< a
));
145 template<class T
, class U
> void test_eq2(T
const & a
, U
const & b
)
148 BOOST_TEST(!(a
!= b
));
151 template<class T
, class U
> void test_ne2(T
const & a
, U
const & b
)
153 BOOST_TEST(!(a
== b
));
157 template<class T
> void test_is_zero(boost::shared_ptr
<T
> const & p
)
160 BOOST_TEST(p
.get() == 0);
163 template<class T
> void test_is_nonzero(boost::shared_ptr
<T
> const & p
)
165 // p? true: false is used to test p in a boolean context.
166 // BOOST_TEST(p) is not guaranteed to test the conversion,
167 // as the macro might test !!p instead.
168 BOOST_TEST(p
? true: false);
169 BOOST_TEST(p
.get() != 0);
174 using namespace boost
;
177 shared_ptr
<X
> p(new Y
);
178 shared_ptr
<X
> p2(new X
);
191 #if !defined( BOOST_NO_RTTI )
192 shared_ptr
<Y
> p3
= dynamic_pointer_cast
<Y
>(p
);
193 shared_ptr
<Y
> p4
= dynamic_pointer_cast
<Y
>(p2
);
198 BOOST_TEST(p
.use_count() == 2);
199 BOOST_TEST(p2
.use_count() == 1);
200 BOOST_TEST(p3
.use_count() == 2);
207 shared_ptr
<void> p5(p
);
214 BOOST_TEST(!wp1
.expired());
215 BOOST_TEST(wp1
.use_count() != 0);
219 #if !defined( BOOST_NO_RTTI )
226 #if !defined( BOOST_NO_RTTI )
231 BOOST_TEST(p5
.use_count() == 1);
233 BOOST_TEST(wp1
.expired());
234 BOOST_TEST(wp1
.use_count() == 0);
238 shared_ptr
<X
> sp1(wp1
);
239 BOOST_ERROR("shared_ptr<X> sp1(wp1) failed to throw");
241 catch(boost::bad_weak_ptr
const &)
245 test_is_zero(wp1
.lock());
247 weak_ptr
<X
> wp2
= static_pointer_cast
<X
>(p5
);
249 BOOST_TEST(wp2
.use_count() == 1);
251 test_nonshared(wp1
, wp2
);
253 // Scoped to not affect the subsequent use_count() tests.
255 shared_ptr
<X
> sp2(wp2
);
256 test_is_nonzero(wp2
.lock());
259 #if !defined( BOOST_NO_RTTI )
260 weak_ptr
<Y
> wp3
= dynamic_pointer_cast
<Y
>(wp2
.lock());
262 BOOST_TEST(wp3
.use_count() == 1);
263 test_shared(wp2
, wp3
);
265 weak_ptr
<X
> wp4(wp3
);
267 BOOST_TEST(wp4
.use_count() == 1);
268 test_shared(wp2
, wp4
);
272 test_is_zero(wp1
.lock());
274 #if !defined( BOOST_NO_RTTI )
280 BOOST_TEST(wp1
.use_count() == 1);
281 test_shared(wp1
, wp2
);
290 BOOST_TEST(wp1
.use_count() == 0);
291 BOOST_TEST(wp2
.use_count() == 0);
292 #if !defined( BOOST_NO_RTTI )
293 BOOST_TEST(wp3
.use_count() == 0);
296 // Test operator< stability for std::set< weak_ptr<> >
297 // Thanks to Joe Gottman for pointing this out
299 BOOST_TEST(b1
== (wp1
< wp5
));
300 BOOST_TEST(b2
== (wp5
< wp1
));
303 // note that both get_object and release_object deal with int*
304 shared_ptr
<void> p6(get_object(), release_object
);
308 BOOST_TEST(cnt
== 0);
310 return boost::report_errors();