1
0
forked from Alepha/Alepha

Add named comparator support.

This commit is contained in:
2024-07-12 14:55:03 -04:00
parent 0e970762e4
commit db1b0edff3
4 changed files with 109 additions and 0 deletions

View File

@ -5,3 +5,4 @@ target_sources( alepha PRIVATE
add_subdirectory( derived_pointer_cast.test )
add_subdirectory( print_number.test )
add_subdirectory( NamedOperator.test )
add_subdirectory( NamedComparator.test )

61
Utility/NamedComparator.h Normal file
View File

@ -0,0 +1,61 @@
static_assert( __cplusplus > 2023'00 );
#pragma once
#include <Alepha/Alepha.h>
#include <map>
#include <functional>
#include <type_traits>
#include <Alepha/Enum.h>
namespace Alepha::Hydrogen::Utility ::detail:: NamedComparator_m
{
inline namespace exports
{
using ComparatorName= Enum
<
"eq"_value,
"ne"_value,
"lt"_value,
"gt"_value,
"le"_value,
"ge"_value
>;
}
struct comparator
{
constexpr auto
operator () ( const ComparatorName &lhs, const ComparatorName &rhs ) const
{
return lhs.get_index() < rhs.get_index();
}
};
namespace exports
{
template< typename Type >
auto
getComparatorMap()
{
std::map< ComparatorName, std::function< bool ( Type, Type ) >, comparator > rv
{
{ "eq"_value, std::equal_to<>{} },
{ "ne"_value, std::not_equal_to<>{} },
{ "lt"_value, std::less<>{} },
{ "gt"_value, std::greater<>{} },
{ "le"_value, std::less_equal<>{} },
{ "ge"_value, std::greater_equal<>{} },
};
return rv;
};
}
}
namespace Alepha::Hydrogen::Utility::inline exports::inline NamedComparator_m
{
using namespace detail::NamedComparator_m::exports;
}

View File

@ -0,0 +1,46 @@
static_assert( __cplusplus > 2023'00 );
#include "../NamedComparator.h"
#include <Alepha/Testing/test.h>
#include <Alepha/Testing/TableTest.h>
#include <Alepha/Utility/enroll.h>
static auto init= Alepha::Utility::enroll <=[]
{
using namespace Alepha::Testing::exports;
using namespace Alepha::Utility::NamedComparator_m;
using namespace Alepha::literals::enum_literals;
"Does the named comparator system have the expected basic functionality?"_test <= TableTest
<
[]( const int lhs, const ComparatorName name, const int rhs )
{
return getComparatorMap< int >().at( name )( lhs, rhs );
}
>
::Cases
{
{ "equals (true)", { 1, "eq"_value, 1 }, true },
{ "equals (false)", { 1, "eq"_value, 2 }, false },
{ "not equals (true)", { 1, "ne"_value, 2 }, true },
{ "not equals (false)", { 1, "ne"_value, 1 }, false },
{ "less (true)", { 1, "lt"_value, 2 }, true },
{ "less (false)", { 1, "lt"_value, 1 }, false },
{ "greater (true)", { 2, "gt"_value, 1 }, true },
{ "greater (false)", { 1, "gt"_value, 1 }, false },
{ "less equal (true)", { 1, "le"_value, 2 }, true },
{ "less equal (true)", { 1, "le"_value, 1 }, true },
{ "less equal (false)", { 1, "le"_value, 0 }, false },
{ "greater equal (true)", { 2, "ge"_value, 1 }, true },
{ "greater equal (true)", { 1, "ge"_value, 1 }, true },
{ "greater equal (false)", { 0, "ge"_value, 1 }, false },
};
};

View File

@ -0,0 +1 @@
unit_test( 0 )