Created on 2018-08-10.00:00:00 last changed 13 months ago
Proposed resolution:
This wording is relative to N4762.
Modify [meta.trans.other] p5 as follows:
-5- Note B: Notwithstanding the provisions of [meta.type.synop], and pursuant to [namespace.std], a program may specialize common_type<T1, T2> for types T1 and T2 such that is_same_v<T1, decay_t<T1>> and is_same_v<T2, decay_t<T2>> are each true. [Note: …] Such a specialization need not have a member named type, but if it does,
that member shall be a typedef-name for an accessible and unambiguousthe qualified-id common_type<T1, T2>::type shall denote a cv-unqualified non-reference typeCto which each of the types T1 and T2 is explicitly convertible. Moreover, […]
Modify [meta.trans.other] p7 similarly:
-7- Note D: Notwithstanding the provisions of [meta.type.synop], and pursuant to [namespace.std], a program may partially specialize basic_common_reference<T, U, TQual, UQual> for types T and U such that is_same_v<T, decay_t<T>> and is_same_v<U, decay_t<U>> are each true. [Note: …] Such a specialization need not have a member named type, but if it does,
that member shall be a typedef-name for an accessible and unambiguousthe qualified-id basic_common_reference<T, U, TQual, UQual>::type shall denote a typeCto which each of the types TQual<T> and UQual<U> is convertible. Moreover, […]
[ 2021-10-14 Approved at October 2021 virtual plenary. Status changed: Voting → WP. ]
[ 2021-06-23; Reflector poll ]
Set status to Tentatively Ready after seven votes in favour during reflector poll.
[ 2018-08 Batavia Monday issue prioritization ]
Priority set to 3
[meta.trans.other] p5 characterizes the requirements for program-defined specializations of common_type with the sentence:
Such a specialization need not have a member named type, but if it does, that member shall be a typedef-name for an accessible and unambiguous cv-unqualified non-reference type C to which each of the types T1 and T2 is explicitly convertible.
This sentence - which [meta.trans.other] p7 largely duplicates to specify requirements on program-defined specializations of basic_common_reference - has two problems:
The grammar term "typedef-name" is overconstraining; there's no reason to prefer a typedef-name here to an actual type, and
"accessible" and "unambiguous" are not properties of types, they are properties of names and base classes.
While we're here, we may as well strike the unused name C which both Note B and Note D define for the type denoted by type.
History | |||
---|---|---|---|
Date | User | Action | Args |
2023-11-22 15:47:43 | admin | set | status: wp -> c++23 |
2021-10-14 09:56:08 | admin | set | messages: + msg12113 |
2021-10-14 09:56:08 | admin | set | status: voting -> wp |
2021-09-29 12:57:28 | admin | set | status: ready -> voting |
2021-06-23 14:16:45 | admin | set | messages: + msg11952 |
2021-06-23 14:16:45 | admin | set | status: new -> ready |
2018-08-22 12:55:05 | admin | set | messages: + msg10099 |
2018-08-13 22:38:46 | admin | set | messages: + msg10067 |
2018-08-10 00:00:00 | admin | create |