File: test_shared_ptr.cpp

package info (click to toggle)
boost 1.34.1-14
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 116,412 kB
  • ctags: 259,566
  • sloc: cpp: 642,395; xml: 56,450; python: 17,612; ansic: 14,520; sh: 2,265; yacc: 858; perl: 481; makefile: 478; lex: 94; sql: 74; csh: 6
file content (128 lines) | stat: -rw-r--r-- 3,808 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
//  (C) Copyright John Maddock 2005.
//  Use, modification and distribution are subject to 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 TEST_STD_HEADERS
#include <memory>
#else
#include <boost/tr1/memory.hpp>
#endif

#include <iostream>
#include <boost/static_assert.hpp>
#include <boost/type_traits/is_base_and_derived.hpp>
#include <boost/type_traits/is_same.hpp>
#include "verify_return.hpp"

struct base
{
   char member();
};
struct derived : public base{};
struct derived_deleter
{
   void operator()(derived*b)
   {
      delete b;
   }
};

struct abstract_base
{
   virtual ~abstract_base();
};

struct concrete : public abstract_base
{};

void noop(){}

struct shared_self : public std::tr1::enable_shared_from_this<shared_self>
{
   typedef std::tr1::enable_shared_from_this<shared_self> base_type;
   shared_self() : base_type(){}
   shared_self(const shared_self& s) : base_type(s){}
   ~shared_self(){}
   // implicit assignment:
   //shared_self& operator=(const shared_self& s)
   //{
   //   return *this;
   //}
};

int main()
{
   // bad_weak_ptr:
   std::tr1::bad_weak_ptr b;
   BOOST_STATIC_ASSERT((::boost::is_base_and_derived<std::exception, std::tr1::bad_weak_ptr>::value));

   // shared_ptr:
   typedef std::tr1::shared_ptr<derived> pderived;
   typedef std::tr1::shared_ptr<base> pbase;
   typedef std::tr1::shared_ptr<abstract_base> pabase;
   BOOST_STATIC_ASSERT((::boost::is_same<pderived::element_type, derived>::value));
   pderived pd1;
   pabase pb1(new concrete());
   pbase pb2(new derived(), derived_deleter());
   pderived pd2(pd1);
   pbase pb3(pd1);
   std::tr1::weak_ptr<derived>* pweak = 0;
   pbase pb4(*pweak);
   std::auto_ptr<derived>* pap = 0;
   pbase pb5(*pap);
   pb2 = pb3;
   pb2 = pd1;
   pb2 = *pap;
   pb2.swap(pb3);
   pb2.reset();
   pb1.reset(new concrete());
   pb2.reset(new derived(), derived_deleter());
   verify_return_type(pb2.get(), static_cast<base*>(0));
   verify_return_type(*pb2, base());
   verify_return_type(pb2->member(), char(0));
   verify_return_type(pb2.use_count(), long(0));
   verify_return_type(pb2.unique(), bool(0));
   if(pb2) { noop(); }
   if(!pb3) { noop(); }
   if(pb2 && pb3) { noop(); }
   // heterogeneous compare:
   verify_return_type(pd1 == pb2, bool());
   verify_return_type(pd1 != pb2, bool());
   verify_return_type(pd1 < pb2, bool());
   std::cout << pb1 << pb2 << std::endl;
   std::tr1::swap(pb2, pb3);
   swap(pb2, pb3);  // ADL
   verify_return_type(std::tr1::static_pointer_cast<derived>(pb2), pderived());
   verify_return_type(std::tr1::dynamic_pointer_cast<concrete>(pb1), std::tr1::shared_ptr<concrete>());
   verify_return_type(std::tr1::const_pointer_cast<base>(std::tr1::shared_ptr<const base>()), std::tr1::shared_ptr<base>());
   verify_return_type(std::tr1::get_deleter<derived_deleter>(pb2), static_cast<derived_deleter*>(0));

   // weak_ptr:
   typedef std::tr1::weak_ptr<base> wpb_t;
   BOOST_STATIC_ASSERT((::boost::is_same<wpb_t::element_type, base>::value));
   wpb_t wpb1;
   wpb_t wpb2(pd1);
   wpb_t wpb3(wpb1);
   std::tr1::weak_ptr<derived> wpd;
   wpb_t wpb4(wpd);
   wpb4 = wpb1;
   wpb4 = wpd;
   wpb4 = pd1;
   wpb4.swap(wpb1);
   wpb4.reset();
   verify_return_type(wpb4.use_count(), long(0));
   verify_return_type(wpb4.expired(), bool(0));
   verify_return_type(wpb4.lock(), pb2);

   // enable_shared_from_this:
   typedef std::tr1::shared_ptr<shared_self> pshared_self;
   typedef std::tr1::shared_ptr<const shared_self> pcshared_self;
   pshared_self sf1(new shared_self());
   pshared_self sf2(new shared_self(*sf1));
   *sf2 = *sf1;
   pcshared_self csf(sf1);
   verify_return_type(sf1->shared_from_this(), sf1);
   verify_return_type(csf->shared_from_this(), csf);
}