Standard library header <compare> (C++20)
From cppreference.com
This header is part of the language support library.
Concepts | |
specifies that operator <=> produces consistent result on given types (concept) | |
Classes | |
(C++20) |
the result type of 3-way comparison that supports all 6 operators, is not substitutable, and allows incomparable values (class) |
(C++20) |
the result type of 3-way comparison that supports all 6 operators and is not substitutable (class) |
(C++20) |
the result type of 3-way comparison that supports all 6 operators and is substitutable (class) |
(C++20) |
the strongest comparison category to which all of the given types can be converted (class template) |
(C++20) |
obtains the result type of the three-way comparison operator <=> on given types (class template) |
(C++20) |
constrained function object implementing x <=> y (class) |
Customization point objects | |
(C++20) |
performs 3-way comparison and produces a result of type std::strong_ordering(customization point object) |
(C++20) |
performs 3-way comparison and produces a result of type std::weak_ordering(customization point object) |
(C++20) |
performs 3-way comparison and produces a result of type std::partial_ordering(customization point object) |
performs 3-way comparison and produces a result of type std::strong_ordering, even if operator<=> is unavailable(customization point object) | |
(C++20) |
performs 3-way comparison and produces a result of type std::weak_ordering, even if operator<=> is unavailable(customization point object) |
performs 3-way comparison and produces a result of type std::partial_ordering, even if operator<=> is unavailable(customization point object) | |
Functions | |
| named comparison functions (function) | |
Synopsis
// all freestanding
namespace std {
// comparison category types
class partial_ordering;
class weak_ordering;
class strong_ordering;
// named comparison functions
constexpr bool is_eq(partial_ordering cmp) noexcept { return cmp == 0; }
constexpr bool is_neq(partial_ordering cmp) noexcept { return cmp != 0; }
constexpr bool is_lt(partial_ordering cmp) noexcept { return cmp < 0; }
constexpr bool is_lteq(partial_ordering cmp) noexcept { return cmp <= 0; }
constexpr bool is_gt(partial_ordering cmp) noexcept { return cmp > 0; }
constexpr bool is_gteq(partial_ordering cmp) noexcept { return cmp >= 0; }
// common comparison category type
template<class... Ts> struct common_comparison_category
{
using type = /* see description */;
};
template<class... Ts>
using common_comparison_category_t = common_comparison_category<Ts...>::type;
// concept three_way_comparable
template<class T, class Cat = partial_ordering>
concept three_way_comparable = /* see description */;
template<class T, class U, class Cat = partial_ordering>
concept three_way_comparable_with = /* see description */;
// result of three-way comparison
template<class T, class U = T> struct compare_three_way_result;
template<class T, class U = T>
using compare_three_way_result_t = compare_three_way_result<T, U>::type;
// class compare_three_way
struct compare_three_way;
// comparison algorithms
inline namespace /* unspecified */ {
inline constexpr /* unspecified */ strong_order = /* unspecified */;
inline constexpr /* unspecified */ weak_order = /* unspecified */;
inline constexpr /* unspecified */ partial_order = /* unspecified */;
inline constexpr /* unspecified */ compare_strong_order_fallback = /* unspecified */;
inline constexpr /* unspecified */ compare_weak_order_fallback = /* unspecified */;
inline constexpr /* unspecified */ compare_partial_order_fallback = /* unspecified */;
}
// type ordering
template<class T, class U> struct type_order;
template<class T, class U>
constexpr strong_ordering type_order_v = type_order<T, U>::value;
}
Concept three_way_comparable
namespace std {
template<class T, class Cat>
concept /*compares-as*/ = // exposition-only
same_as<common_comparison_category_t<T, Cat>, Cat>;
template<class T, class U>
concept /*partially-ordered-with*/ = // exposition-only
requires(const remove_reference_t<T>& t, const remove_reference_t<U>& u) {
{ t < u } -> /*boolean-testable*/;
{ t > u } -> /*boolean-testable*/;
{ t <= u } -> /*boolean-testable*/;
{ t >= u } -> /*boolean-testable*/;
{ u < t } -> /*boolean-testable*/;
{ u > t } -> /*boolean-testable*/;
{ u <= t } -> /*boolean-testable*/;
{ u >= t } -> /*boolean-testable*/;
};
template<class T, class Cat = partial_ordering>
concept three_way_comparable =
/*weakly-equality-comparable-with*/<T, T> && /*partially-ordered-with*/<T, T> &&
requires(const remove_reference_t<T>& a, const remove_reference_t<T>& b) {
{ a <=> b } -> /*compares-as*/<Cat>;
};
}
Concept three_way_comparable_with
namespace std {
template<class T, class U, class Cat = partial_ordering>
concept three_way_comparable_with =
three_way_comparable<T, Cat> && three_way_comparable<U, Cat> &&
/*comparison-common-type-with*/<T, U> &&
three_way_comparable<
common_reference_t<const remove_reference_t<T>&, const remove_reference_t<U>&>,
Cat> &&
/*weakly-equality-comparable-with*/<T, U> && /*partially-ordered-with*/<T, U> &&
requires(const remove_reference_t<T>& t, const remove_reference_t<U>& u) {
{ t <=> u } -> /*compares-as*/<Cat>;
{ u <=> t } -> /*compares-as*/<Cat>;
};
}
Class std::partial_ordering
namespace std {
class partial_ordering
{
int /*value*/; // exposition-only
bool /*is-ordered*/; // exposition-only
// exposition-only constructors
constexpr explicit partial_ordering(/*ord*/ v) noexcept
: /*value*/(int(v))
, /*is-ordered*/(true)
{
} // exposition-only
constexpr explicit partial_ordering(/*ncmp*/ v) noexcept
: /*value*/(int(v))
, /*is-ordered*/(false)
{
} // exposition-only
public:
// valid values
static const partial_ordering less;
static const partial_ordering equivalent;
static const partial_ordering greater;
static const partial_ordering unordered;
// comparisons
friend constexpr bool operator==(partial_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator==(partial_ordering v,
partial_ordering w) noexcept = default;
friend constexpr bool operator<(partial_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>(partial_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<=(partial_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>=(partial_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<(/* unspecified */, partial_ordering v) noexcept;
friend constexpr bool operator>(/* unspecified */, partial_ordering v) noexcept;
friend constexpr bool operator<=(/* unspecified */, partial_ordering v) noexcept;
friend constexpr bool operator>=(/* unspecified */, partial_ordering v) noexcept;
friend constexpr partial_ordering operator<=>(partial_ordering v,
/* unspecified */) noexcept;
friend constexpr partial_ordering operator<=>(/* unspecified */,
partial_ordering v) noexcept;
};
// valid values' definitions
inline constexpr partial_ordering partial_ordering::less(/*ord*/::/*less*/);
inline constexpr partial_ordering partial_ordering::equivalent(/*ord*/::/*equivalent*/);
inline constexpr partial_ordering partial_ordering::greater(/*ord*/::/*greater*/);
inline constexpr partial_ordering partial_ordering::unordered(/*ncmp*/::/*unordered*/);
}
Class std::weak_ordering
namespace std {
class weak_ordering
{
int /*value*/; // exposition-only
// exposition-only constructors
constexpr explicit weak_ordering(/*ord*/ v) noexcept
: /*value*/(int(v))
{
} // exposition-only
public:
// valid values
static const weak_ordering less;
static const weak_ordering equivalent;
static const weak_ordering greater;
// conversions
constexpr operator partial_ordering() const noexcept;
// comparisons
friend constexpr bool operator==(weak_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator==(weak_ordering v, weak_ordering w) noexcept = default;
friend constexpr bool operator<(weak_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>(weak_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<=(weak_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>=(weak_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<(/* unspecified */, weak_ordering v) noexcept;
friend constexpr bool operator>(/* unspecified */, weak_ordering v) noexcept;
friend constexpr bool operator<=(/* unspecified */, weak_ordering v) noexcept;
friend constexpr bool operator>=(/* unspecified */, weak_ordering v) noexcept;
friend constexpr weak_ordering operator<=>(weak_ordering v,
/* unspecified */) noexcept;
friend constexpr weak_ordering operator<=>(/* unspecified */,
weak_ordering v) noexcept;
};
// valid values' definitions
inline constexpr weak_ordering weak_ordering::less(/*ord*/::/*less*/);
inline constexpr weak_ordering weak_ordering::equivalent(/*ord*/::/*equivalent*/);
inline constexpr weak_ordering weak_ordering::greater(/*ord*/::/*greater*/);
}
Class std::strong_ordering
namespace std {
class strong_ordering
{
int /*value*/; // exposition-only
// exposition-only constructors
constexpr explicit strong_ordering(/*ord*/ v) noexcept
: /*value*/(int(v))
{
} // exposition-only
public:
// valid values
static const strong_ordering less;
static const strong_ordering equal;
static const strong_ordering equivalent;
static const strong_ordering greater;
// conversions
constexpr operator partial_ordering() const noexcept;
constexpr operator weak_ordering() const noexcept;
// comparisons
friend constexpr bool operator==(strong_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator==(strong_ordering v,
strong_ordering w) noexcept = default;
friend constexpr bool operator<(strong_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>(strong_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<=(strong_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator>=(strong_ordering v, /* unspecified */) noexcept;
friend constexpr bool operator<(/* unspecified */, strong_ordering v) noexcept;
friend constexpr bool operator>(/* unspecified */, strong_ordering v) noexcept;
friend constexpr bool operator<=(/* unspecified */, strong_ordering v) noexcept;
friend constexpr bool operator>=(/* unspecified */, strong_ordering v) noexcept;
friend constexpr strong_ordering operator<=>(strong_ordering v,
/* unspecified */) noexcept;
friend constexpr strong_ordering operator<=>(/* unspecified */,
strong_ordering v) noexcept;
};
// valid values' definitions
inline constexpr strong_ordering strong_ordering::less(/*ord*/::/*less*/);
inline constexpr strong_ordering strong_ordering::equal(/*ord*/::/*equal*/);
inline constexpr strong_ordering strong_ordering::equivalent(/*ord*/::/*equivalent*/);
inline constexpr strong_ordering strong_ordering::greater(/*ord*/::/*greater*/);
}
Class std::compare_three_way
namespace std {
struct compare_three_way {
template<class T, class U>
constexpr auto operator()(T&& t, U&& u) const;
using is_transparent = /* unspecified */;
};
}
Class std::type_order
namespace std {
template<class T, class U> struct type_order {
static constexpr strong_ordering value = /*TYPE-ORDER*/(T, U);
using value_type = strong_ordering;
constexpr operator value_type() const noexcept { return value; }
constexpr value_type operator()() const noexcept { return value; }
};
}
See also
three-way comparison operator expression lhs <=> rhs (C++20)
|