has_strong_structural_equality
has a meaningless definitionSection: 21.3.5.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
T
has 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??????L
represents 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.6 [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.6 [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 T
has strong
structural
equality (11.10.1 [class.compare.default])
can be used as non-type
template-parameter (13.2 [temp.param]).T
shall be a complete type,
cvvoid
, or an array of
unknown bound.
IfT
is a class type,T
shall
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.6 [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.6 [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 typeT
has strong
structural
equality (11.10.1 [class.compare.default]).T
shall be a complete type,
cvvoid
, or an array of
unknown bound.