Created on 2017-03-04.00:00:00 last changed 45 months ago
Proposed resolution:
This wording is relative to N4659.
Change [depr.meta.types] as indicated:
-4- The behavior of a program that adds specializations for any of the templates defined in this subclause
is_literal_type or is_literal_type_vis undefined, unless explicitly permitted by the specification of the corresponding template.
[ 2017-06-10, Moved to Tentatively Ready after 6 positive votes on c++std-lib ]
[ 2017-04-24, Daniel provides wording ]
Instead of enumerating all the templates where adding a specialization is valid, a general exclusion rule is provided. Albeit currently not needed for the templates handled by this sub-clause, a potential exception case is constructed to ensure correctness for the first deprecated trait template that would permit specializations by the user.
[ 2017-03-04, Kona ]
Set priority to 3
P0604R0 missed a similar adjustment that was performed for the deprecated type trait templates is_literal_type and is_literal_type_v via LWG 2838:
Moving the result_of to Annex D means that the general prohibition against specializing type traits in [meta.type.synop]/1 does no longer exist, so should be explicitly spelled out. Wording will be provided after publication of the successor of N4640.History | |||
---|---|---|---|
Date | User | Action | Args |
2021-02-25 10:48:01 | admin | set | status: wp -> c++20 |
2017-07-30 20:18:47 | admin | set | status: voting -> wp |
2017-06-26 13:46:20 | admin | set | status: ready -> voting |
2017-06-10 21:31:39 | admin | set | messages: + msg9242 |
2017-06-10 21:31:39 | admin | set | status: new -> ready |
2017-04-24 18:14:25 | admin | set | messages: + msg9167 |
2017-04-24 18:14:25 | admin | set | messages: + msg9166 |
2017-03-14 03:14:09 | admin | set | messages: + msg9120 |
2017-03-04 00:00:00 | admin | create |