@@ -89,9 +89,8 using default_copier_t = typename default_copier<T>::type; | |||||
89 |
|
89 | |||
90 | template <class T, class D, class C> |
|
90 | template <class T, class D, class C> | |
91 | struct is_default_manageable |
|
91 | struct is_default_manageable | |
92 | : public std::integral_constant<bool, |
|
92 | : public std::integral_constant<bool, std::is_same<D, default_deleter_t<T> >::value | |
93 |
std::is_same< |
|
93 | && std::is_same<C, default_copier_t<T> >::value> { | |
94 | && std::is_same<C, default_copier_t<T> >::value> { |
|
|||
95 | }; |
|
94 | }; | |
96 | } |
|
95 | } | |
97 |
|
96 | |||
@@ -132,11 +131,10 public: | |||||
132 | } |
|
131 | } | |
133 |
|
132 | |||
134 | template <class U> |
|
133 | template <class U> | |
135 | impl_ptr(U *u, |
|
134 | impl_ptr(U *u, typename std::enable_if<std::is_convertible<U *, pointer>::value | |
136 | typename std::enable_if<std::is_convertible<U *, pointer>::value |
|
135 | && is_default_manageable::value, | |
137 |
|
|
136 | dummy_t_>::type | |
138 | dummy_t_>::type |
|
137 | = dummy_t_()) SPIMPL_NOEXCEPT | |
139 | = dummy_t_()) SPIMPL_NOEXCEPT |
|
|||
140 | : impl_ptr(u, &details::default_delete<T>, &details::default_copy<T>) |
|
138 | : impl_ptr(u, &details::default_delete<T>, &details::default_copy<T>) | |
141 | { |
|
139 | { | |
142 | } |
|
140 | } | |
@@ -153,12 +151,12 public: | |||||
153 |
|
151 | |||
154 | #ifdef SPIMPL_HAS_AUTO_PTR |
|
152 | #ifdef SPIMPL_HAS_AUTO_PTR | |
155 | template <class U> |
|
153 | template <class U> | |
156 | impl_ptr(std::auto_ptr<U> &&u, |
|
154 | impl_ptr(std::auto_ptr<U> &&u, typename std::enable_if<std::is_convertible<U *, pointer>::value | |
157 | typename std::enable_if<std::is_convertible<U *, pointer>::value |
|
155 | && is_default_manageable::value, | |
158 |
|
|
156 | dummy_t_>::type | |
159 |
|
|
157 | = dummy_t_()) SPIMPL_NOEXCEPT | |
160 |
|
|
158 | : ptr_(u.release(), &details::default_delete<T>), | |
161 |
|
|
159 | copier_(&details::default_copy<T>) | |
162 | { |
|
160 | { | |
163 | } |
|
161 | } | |
164 | #endif |
|
162 | #endif | |
@@ -240,9 +238,8 public: | |||||
240 |
|
238 | |||
241 | #ifdef SPIMPL_HAS_AUTO_PTR |
|
239 | #ifdef SPIMPL_HAS_AUTO_PTR | |
242 | template <class U> |
|
240 | template <class U> | |
243 | typename std::enable_if<std::is_convertible<U *, pointer>::value |
|
241 | typename std::enable_if< | |
244 | && is_default_manageable::value, |
|
242 | std::is_convertible<U *, pointer>::value && is_default_manageable::value, impl_ptr &>::type | |
245 | impl_ptr &>::type |
|
|||
246 | operator=(std::auto_ptr<U> &&u) SPIMPL_NOEXCEPT |
|
243 | operator=(std::auto_ptr<U> &&u) SPIMPL_NOEXCEPT | |
247 | { |
|
244 | { | |
248 | return operator=(impl_ptr(std::move(u))); |
|
245 | return operator=(impl_ptr(std::move(u))); | |
@@ -250,9 +247,8 public: | |||||
250 | #endif |
|
247 | #endif | |
251 |
|
248 | |||
252 | template <class U> |
|
249 | template <class U> | |
253 | typename std::enable_if<std::is_convertible<U *, pointer>::value |
|
250 | typename std::enable_if< | |
254 | && is_default_manageable::value, |
|
251 | std::is_convertible<U *, pointer>::value && is_default_manageable::value, impl_ptr &>::type | |
255 | impl_ptr &>::type |
|
|||
256 | operator=(std::unique_ptr<U> &&u) SPIMPL_NOEXCEPT |
|
252 | operator=(std::unique_ptr<U> &&u) SPIMPL_NOEXCEPT | |
257 | { |
|
253 | { | |
258 | return operator=(impl_ptr(std::move(u))); |
|
254 | return operator=(impl_ptr(std::move(u))); |
General Comments 0
You need to be logged in to leave comments.
Login now