This page is a snapshot from the LWG issues list, see the Library Active Issues List for more information and the meaning of C++20 status.
has_strong_structural_equality has a meaningless definitionSection: 21.3.6.4 [meta.unary.prop], 17.3.2 [version.syn] Status: C++20 Submitter: Daniel Krügler Opened: 2019-12-08 Last modified: 2021-02-25
Priority: 1
View other active issues in [meta.unary.prop].
View all other issues in [meta.unary.prop].
View all issues with C++20 status.
Discussion:
After the Belfast 2019 meeting with the acceptance of P1907R1
the core language term "strong structural equality" has been removed and instead a more general
definition of a "structural type" has been introduced that is suitable to be used as non-type template
parameter. These changes have caused the current definition of the has_strong_structural_equality
type trait (which had originally been introduced by P1614R2
during the Cologne 2019 meeting) to become meaningless since it is currently defined as follows:
The type
Thas strong structural equality (11.10.1 [class.compare.default]).
Besides the now undefined term "strong structural equality", the reference to 11.10.1 [class.compare.default] doesn't make sense anymore, assuming that the trait definition is supposed to refer now to a type that can be used as non-type template parameter.
During library reflector discussions several informal naming suggestions has been mentioned, such asis_structural[_type], can_be_nttp, is_nontype_template_parameter_type.
Albeit is_structural_type would come very near to the current core terminology, core experts
have argued that the term "structural type" should be considered as a "core-internal" term that may
easily be replaced post-C++20.
In addition to that definition and naming question of that type trait it should be discussed whether
there should exist a specific feature macro for just this type trait, similar to the reason why we
introduced the __cpp_lib_has_unique_object_representations test macro for the
has_unique_object_representations type trait while voting in
P0258R2. The submitter of this issue believes that such a feature
macro should be added and given that its final definition should be related to the date of the
acceptance of this issue (and should not be related to any historically accepted papers such as
P1614R2).
[2020-01 Priority set to 1 and questions to LEWG after review on the reflector.]
Previous resolution [SUPERSEDED]:This wording is relative to N4842.
Modify 17.3.2 [version.syn], header
<version>synopsis, as indicated (The symbolic??????Lrepresents the date to be defined by the project editor):[…] #define __cpp_lib_is_swappable 201603L // also in <type_traits> #define __cpp_lib_is_template_parameter_type ??????L // also in <type_traits> #define __cpp_lib_jthread 201911L // also in <stop_token>, <thread> […]Modify 21.3.3 [meta.type.synop], header
<type_traits>synopsis, as indicated:[…] template<class T> struct has_unique_object_representations; template<class T> structhas_strong_structural_equalityis_template_parameter_type; // 21.3.7 [meta.unary.prop.query], type property queries […] template<class T> inline constexpr bool has_unique_object_representations_v = has_unique_object_representations<T>::value; template<class T> inline constexpr boolhas_strong_structural_equality_vis_template_parameter_type_v =has_strong_structural_equalityis_template_parameter_type<T>::value; // 21.3.7 [meta.unary.prop.query], type property queries […]Modify 21.3.3 [meta.type.synop], Table 47 ([tab:meta.unary.prop]) — "Type property predicates" — as indicated:
Table 47: Type property predicates [tab:meta.unary.prop] Template Condition Preconditions …template<class T>
struct
has_strong_structural_equalityis_template_parameter_type;The type Thas strong
structural
equality (11.10.1 [class.compare.default])
can be used as non-type
template-parameter (13.2 [temp.param]).Tshall be a complete type,
cvvoid, or an array of
unknown bound.
IfTis a class type,Tshall
be a complete type.…
[2020-02, Prague]
LEWG looked at this and suggested to remove the existing trait has_strong_structural_equality
for now until someone demonstrates which usecases exist that would justify its existence.
[2020-02-13, Prague]
Set to Immediate.
Proposed resolution:
This wording is relative to N4849.
Modify 21.3.3 [meta.type.synop], header <type_traits> synopsis, as indicated:
[…] template<class T> struct has_unique_object_representations;template<class T> struct has_strong_structural_equality;// 21.3.7 [meta.unary.prop.query], type property queries […] template<class T> inline constexpr bool has_unique_object_representations_v = has_unique_object_representations<T>::value;template<class T> inline constexpr bool has_strong_structural_equality_v = has_strong_structural_equality<T>::value;// 21.3.7 [meta.unary.prop.query], type property queries […]
Modify 21.3.3 [meta.type.synop], Table 47 ([tab:meta.unary.prop]) — "Type property predicates" — as indicated:
Table 47: Type property predicates [tab:meta.unary.prop] Template Condition Preconditions …template<class T>
struct
has_strong_structural_equality;The typeThas strong
structural
equality (11.10.1 [class.compare.default]).Tshall be a complete type,
cvvoid, or an array of
unknown bound.