summaryrefslogtreecommitdiff
path: root/src/third_party/boost-1.56.0/boost/thread/csbl/memory/unique_ptr.hpp
blob: eb272e4ec84d9a39f0bf7a07e8f914fa3e6a95c3 (plain)
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
// Copyright (C) 2013 Vicente J. Botet Escriba
//
//  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)
//
// 2013/10 Vicente J. Botet Escriba
//   Creation.

#ifndef BOOST_CSBL_MEMORY_UNIQUE_PTR_HPP
#define BOOST_CSBL_MEMORY_UNIQUE_PTR_HPP

#include <boost/thread/csbl/memory/config.hpp>

// 20.8.1 class template unique_ptr:
#if defined BOOST_NO_CXX11_SMART_PTR
#include <boost/thread/csbl/memory/default_delete.hpp>

#include <boost/interprocess/smart_ptr/unique_ptr.hpp>

namespace boost
{
  namespace csbl
  {
    template <class T, class D = default_delete<T> > class unique_ptr :
    public ::boost::interprocess::unique_ptr<T,D>
    {
      typedef ::boost::interprocess::unique_ptr<T,D> base_type;
      BOOST_MOVABLE_BUT_NOT_COPYABLE(unique_ptr)
    protected:
      //typedef typename base_type::nat nat;
      //typedef typename base_type::nullptr_t nullptr_t;
      struct nat  {int for_bool;};
      struct nat2 {int for_nullptr;};
      typedef int nat2::*nullptr_t;

    public:
      typedef typename base_type::element_type element_type;
      typedef typename base_type::deleter_type deleter_type;
      typedef typename base_type::pointer pointer;

      unique_ptr() : base_type()
      {}
      explicit unique_ptr(pointer p): base_type(p)
      {}
      unique_ptr(pointer p
          ,typename interprocess::ipcdetail::if_<interprocess::ipcdetail::is_reference<D>
          ,D
          ,typename interprocess::ipcdetail::add_reference<const D>::type>::type d)
      : base_type(p, d)
      {}
      unique_ptr(BOOST_RV_REF(unique_ptr) u)
      : base_type(boost::move(static_cast<base_type&>(u)))
      {}
      template <class U, class E>
      unique_ptr(BOOST_RV_REF_BEG unique_ptr<U, E> BOOST_RV_REF_END u,
          typename interprocess::ipcdetail::enable_if_c<
          interprocess::ipcdetail::is_convertible<typename unique_ptr<U, E>::pointer, pointer>::value &&
          interprocess::ipcdetail::is_convertible<E, D>::value &&
          (
              !interprocess::ipcdetail::is_reference<D>::value ||
              interprocess::ipcdetail::is_same<D, E>::value
          )
          ,
          nat
          >::type = nat())
      : base_type(boost::move(static_cast< ::boost::interprocess::unique_ptr<U,E>&>(u)))
      {}
      unique_ptr& operator=(BOOST_RV_REF(unique_ptr) u)
      {
        this->base_type::operator=(boost::move(static_cast<base_type&>(u)));
        return *this;
      }
      template <class U, class E>
      unique_ptr& operator=(BOOST_RV_REF_BEG unique_ptr<U, E> BOOST_RV_REF_END u)
      {
        this->base_type::template operator=<U,E>(boost::move(static_cast< ::boost::interprocess::unique_ptr<U,E>&>(u)));
        return *this;
      }
      unique_ptr& operator=(nullptr_t t)
      {
        this->base_type::operator=(t);
        return *this;
      }
      void swap(unique_ptr& u)
      {
        this->base_type::swap(u);
      }
    };
    template <class T, class D>
    class unique_ptr<T[], D> :
      public ::boost::interprocess::unique_ptr<T[],D>
    {

    };
  }
}
#else
namespace boost
{
  namespace csbl
  {
    using ::std::unique_ptr;
  }
}
#endif // BOOST_NO_CXX11_SMART_PTR
#endif // header