Created on 2017-05-05.00:00:00 last changed 46 months ago
Proposed resolution:
This wording is relative to N4659.
Edit [pairs.pair] as indicated:
pair& operator=(pair&& p) noexcept(see below);-21- Effects: Assigns to first with std::forward<first_type>(p.first) and to second with std::forward<second_type>(p.second).
-22- Remarks: This operator shallbe defined as deletednot participate in overload resolution unless is_move_assignable_v<first_type> is true and is_move_assignable_v<second_type> is true. […]
Edit [tuple.assign] as indicated:
tuple& operator=(tuple&& u) noexcept(see below);-5- Effects: For all i, assigns std::forward<Ti>(get<i>(u)) to get<i>(*this).
-6- Remarks: This operator shallbe defined as deletednot participate in overload resolution unless is_move_assignable_v<Ti> is true for all i. […]
[ 2017-11 Albuquerque Wednesday issue processing ]
Move to Immediate
[ 2017-07 Toronto Wed Issue Prioritization ]
Priority 2
LWG 2729 constrained many pair & tuple assignment operators to "not participate in overload resolution" and "be defined as deleted if." As discussed when LWG reviewed 2756, it is undesirable to require that a move constructor or assignment operator be "defined as deleted," since it is unclear whether that operation should be implicitly deleted, and therefore not participate in overload resolution, or explicitly deleted and therefore impede overload resolution for usages that would otherwise find copies.
History | |||
---|---|---|---|
Date | User | Action | Args |
2021-02-25 10:48:01 | admin | set | status: wp -> c++20 |
2017-11-13 19:01:36 | admin | set | status: immediate -> wp |
2017-11-11 01:14:27 | admin | set | status: ready -> immediate |
2017-11-10 03:05:33 | admin | set | messages: + msg9539 |
2017-11-10 03:05:33 | admin | set | status: new -> ready |
2017-07-15 22:58:07 | admin | set | messages: + msg9383 |
2017-05-07 16:55:02 | admin | set | messages: + msg9173 |
2017-05-05 00:00:00 | admin | create |