table of contents
        
      
      
    | std::compare_three_way_result(3) | C++ Standard Libary | std::compare_three_way_result(3) | 
NAME¶
std::compare_three_way_result - std::compare_three_way_result
Synopsis¶
 Defined in header <compare>
  
   template< class T, class U = T > (since C++20)
  
   struct compare_three_way_result;
  
   Let t and u denote lvalue of const std::remove_reference_t<T> and const
  
   std::remove_reference_t<U> respectively, if the expression t <=>
    u is well-formed,
  
   provides the member typedef type equal to decltype(t <=> u), otherwise
    there is no
  
   member type.
  
   If the program adds specializations for std::compare_three_way_result, the
    behavior
  
   is undefined.
Member types¶
 Name Definition
  
   type the result type of operator<=> on const-qualified lvalue of T and
    U
Helper types¶
 template< class T, class U = T >
  
   using compare_three_way_result_t = compare_three_way_result<T, (since
    C++20)
  
   U>::type;
Possible implementation¶
 // recommended by Casey Carter
  
   // see also: https://github.com/microsoft/STL/pull/385#discussion_r357894054
  
   template<class T, class U = T>
  
   using compare_three_way_result_t = decltype(
  
   std::declval<const std::remove_reference_t<T>&>() <=>
  
   std::declval<const std::remove_reference_t<U>&>()
  
   );
  
   template<class T, class U = T>
  
   struct compare_three_way_result {};
  
   template<class T, class U>
  
   requires requires { typename compare_three_way_result_t<T, U>; }
  
   struct compare_three_way_result<T, U>
  
   {
  
   using type = compare_three_way_result_t<T, U>;
  
   };
Example¶
// Run this code
  
   #include <compare>
  
   #include <iostream>
  
   #include <type_traits>
  
   template<class Ord>
  
   void print_cmp_type()
  
   {
  
   if constexpr (std::is_same_v<Ord, std::strong_ordering>)
  
   std::cout << "strong ordering\n";
  
   else if constexpr (std::is_same_v<Ord, std::weak_ordering>)
  
   std::cout << "weak ordering\n";
  
   else if constexpr (std::is_same_v<Ord, std::partial_ordering>)
  
   std::cout << "partial ordering\n";
  
   else
  
   std::cout << "illegal comparison result type\n";
  
   }
  
   int main()
  
   {
  
   print_cmp_type<std::compare_three_way_result_t<int>>();
  
   print_cmp_type<std::compare_three_way_result_t<double>>();
  
   }
Output:¶
 strong ordering
  
   partial ordering
See also¶
 partial_ordering the result type of 3-way comparison that
    supports all 6 operators,
  
   (C++20) is not substitutable, and allows incomparable values
  
   (class)
  
   weak_ordering the result type of 3-way comparison that supports all 6
    operators
  
   (C++20) and is not substitutable
  
   (class)
  
   strong_ordering the result type of 3-way comparison that supports all 6
    operators
  
   (C++20) and is substitutable
  
   (class)
| 2024.06.10 | http://cppreference.com |