summaryrefslogtreecommitdiffstats
path: root/libcxx/include/tuple
diff options
context:
space:
mode:
Diffstat (limited to 'libcxx/include/tuple')
-rw-r--r--libcxx/include/tuple42
1 files changed, 29 insertions, 13 deletions
diff --git a/libcxx/include/tuple b/libcxx/include/tuple
index c33b48ab54c..c4cd3bc5495 100644
--- a/libcxx/include/tuple
+++ b/libcxx/include/tuple
@@ -500,20 +500,22 @@ class _LIBCPP_TEMPLATE_VIS tuple
struct _CheckArgsConstructor<true, _Dummy>
{
template <class ..._Args>
- static constexpr bool __enable_implicit_default() {
+ struct __enable_implicit_default
// In C++03, there's no way to implement the resolution of LWG2510.
#ifdef _LIBCPP_CXX03_LANG
- return true;
+ : true_type
#else
- return __all<__is_implicitly_default_constructible<_Args>::value...>::value;
+ : __all<__is_implicitly_default_constructible<_Args>::value...>
#endif
- }
+ { };
template <class ..._Args>
- static constexpr bool __enable_explicit_default() {
- return __all<is_default_constructible<_Args>::value...>::value
- && !__enable_implicit_default<_Args...>();
- }
+ struct __enable_explicit_default
+ : integral_constant<bool,
+ __all<is_default_constructible<_Args>::value...>::value &&
+ !__enable_implicit_default<_Args...>::value
+ >
+ { };
template <class ..._Args>
static constexpr bool __enable_explicit() {
@@ -653,14 +655,14 @@ class _LIBCPP_TEMPLATE_VIS tuple
public:
template <bool _Dummy = true, _EnableIf<
- _CheckArgsConstructor<_Dummy>::template __enable_implicit_default<_Tp...>()
+ _CheckArgsConstructor<_Dummy>::template __enable_implicit_default<_Tp...>::value
, void*> = nullptr>
_LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
tuple()
_NOEXCEPT_(__all<is_nothrow_default_constructible<_Tp>::value...>::value) {}
template <bool _Dummy = true, _EnableIf<
- _CheckArgsConstructor<_Dummy>::template __enable_explicit_default<_Tp...>()
+ _CheckArgsConstructor<_Dummy>::template __enable_explicit_default<_Tp...>::value
, void*> = nullptr>
explicit _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
tuple()
@@ -669,12 +671,12 @@ public:
tuple(tuple const&) = default;
tuple(tuple&&) = default;
- template <class _AllocArgT, class _Alloc, bool _Dummy = true, class = _EnableIf<
+ template <class _AllocArgT, class _Alloc, bool _Dummy = true, _EnableIf<
_And<
_IsSame<allocator_arg_t, _AllocArgT>,
- __dependent_type<is_default_constructible<_Tp>, _Dummy>...
+ typename _CheckArgsConstructor<_Dummy>::template __enable_implicit_default<_Tp...>
>::value
- >
+ , void*> = nullptr
>
_LIBCPP_INLINE_VISIBILITY
tuple(_AllocArgT, _Alloc const& __a)
@@ -683,6 +685,20 @@ public:
typename __make_tuple_indices<sizeof...(_Tp), 0>::type(),
__tuple_types<_Tp...>()) {}
+ template <class _AllocArgT, class _Alloc, bool _Dummy = true, _EnableIf<
+ _And<
+ _IsSame<allocator_arg_t, _AllocArgT>,
+ typename _CheckArgsConstructor<_Dummy>::template __enable_explicit_default<_Tp...>
+ >::value
+ , void*> = nullptr
+ >
+ explicit _LIBCPP_INLINE_VISIBILITY
+ tuple(_AllocArgT, _Alloc const& __a)
+ : __base_(allocator_arg_t(), __a,
+ __tuple_indices<>(), __tuple_types<>(),
+ typename __make_tuple_indices<sizeof...(_Tp), 0>::type(),
+ __tuple_types<_Tp...>()) {}
+
template <bool _Dummy = true,
typename enable_if
<
OpenPOWER on IntegriCloud