Defined in header <concepts> | ||
|---|---|---|
template< class T, class U >
concept common_with =
std::same_as<std::common_type_t<T, U>, std::common_type_t<U, T>> &&
requires {
static_cast<std::common_type_t<T, U>>(std::declval<T>());
static_cast<std::common_type_t<T, U>>(std::declval<U>());
} &&
std::common_reference_with<
std::add_lvalue_reference_t<const T>,
std::add_lvalue_reference_t<const U>> &&
std::common_reference_with<
std::add_lvalue_reference_t<std::common_type_t<T, U>>,
std::common_reference_t<
std::add_lvalue_reference_t<const T>,
std::add_lvalue_reference_t<const U>>>;
| (since C++20) |
The concept common_with<T, U> specifies that two types T and U share a common type (as computed by std::common_type_t) to which both can be converted.
T and U model std::common_with<T, U> only if, given equality-preserving expressions t1, t2, u1 and u2 such that decltype((t1)) and decltype((t2)) are both T and decltype((u1)) and decltype((u2)) are both U,
std::common_type_t<T, U>(t1) equals std::common_type_t<T, U>(t2) if and only if t1 equals t2; and std::common_type_t<T, U>(u1) equals std::common_type_t<T, U>(u2) if and only if u1 equals u2. In other words, the conversion to the common type must preserve equality.
Expressions declared in requires expressions of the standard library concepts are required to be equality-preserving (except where stated otherwise).
|
(C++11) | determines the common type of a group of types (class template) |
|
(C++20) | determines the common reference type of a group of types (class template) |
|
(C++20) | specifies that two types share a common reference type (concept) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/concepts/common_with