This page is a snapshot from the LWG issues list, see the Library Active Issues List for more information and the meaning of Resolved status.
tuple<any, any>{allocator_arg_t, an_allocator}
Section: 22.4.4.2 [tuple.cnstr] Status: Resolved Submitter: Jonathan Wakely Opened: 2018-08-18 Last modified: 2021-10-23
Priority: 3
View other active issues in [tuple.cnstr].
View all other issues in [tuple.cnstr].
View all issues with Resolved status.
Discussion:
For a 2-element std::tuple
, attempting to call the "allocator-extended default constructor" might actually
pass the allocator_arg
tag and the allocator to the tuple element constructors:
tuple<any, any> t{allocator_arg, allocator<int>{}}; assert(std::get<0>(t).has_value());
This assertion should pass according to the standard, but users might expect the elements to be default constructed. If you really wanted to construct the elements with the tag and the allocator, you could do:
tuple<any, any> t{{allocator_arg}, {allocator<int>{}}};
or
tuple<any, any> t{tuple<allocator_arg_t, allocator<int>>{allocator_arg, allocator<int>{}}};
The deduction guides for std::tuple
always treat {allocator_arg_t, an_allocator}
as the
allocator-extended default constructor, so this creates an empty tuple:
tuple t{allocator_arg, allocator<int>{}};
And this is needed to create tuple<any, any>
:
tuple t{allocator_arg, allocator<int>{}, any{}, any{}};
The proposed resolution seems consistent with that, always calling an allocator-extended constructor for
{allocator_arg_t, a}
, instead of the tuple(UTypes&&...)
constructor.
[2018-08-20, Daniel comments]
The wording changes by this issue are very near to those suggested for LWG 3121.
[2018-08 Batavia Monday issue prioritization]
Priority set to 0, status to 'Tentatively Ready'. Alisdair to write a paper about SFINAE constraints on the Allocator-aware tuple constructors.
[2018-08 Batavia Friday]
Tim Song found a 3-element case of this issue. Status back to 'Open'
tuple<any,any,any>(allocator_arg_t, a, tuple)
[2018-09 Reflector prioritization]
Set Priority to 3
Previous resolution [SUPERSEDED]:
This wording is relative to N4762.
Modify 22.4.4.2 [tuple.cnstr] as indicated:
template<class... UTypes> explicit(see below) constexpr tuple(UTypes&&... u);-9- Effects: Initializes the elements in the tuple with the corresponding value in
-10- Remarks: This constructor shall not participate in overload resolution unlessstd::forward<UTypes>(u)
.sizeof...(Types) == sizeof...(UTypes)
andsizeof...(Types) >= 1
andis_constructible_v<Ti, Ui&&>
istrue
for alli
and(sizeof...(Types) != 2 || !is_same_v<remove_cvref_t<U0>, allocator_arg_t>)
. The expression insideexplicit
is equivalent to:!conjunction_v<is_convertible<UTypes, Types>...>
[2021-08-20; LWG telecon]
Status changed to Tentatively Resolved, by 3121.
[2021-10-23 Resolved by 3121, approved at October 2021 virtual plenary. Status changed: Tentatively Resolved → Resolved.]
Proposed resolution:
This issue is resolved by the resolution of issue 3121.