#include #include #include #include #include #include "test.h" namespace test_constexpr { struct sum_f { template constexpr T operator()(T x, U y) const { return x+y; } }; FIT_STATIC_CONSTEXPR_FUNCTION(sum_partial) = fit::partial(sum_f()); FIT_TEST_CASE() { STATIC_ASSERT_EMPTY(sum_partial); FIT_TEST_CHECK(3 == sum_partial(1, 2)); FIT_TEST_CHECK(3 == sum_partial(1)(2)); FIT_STATIC_TEST_CHECK(3 == sum_partial(1, 2)); FIT_STATIC_TEST_CHECK(3 == sum_partial(1)(2)); } } namespace test_static { FIT_STATIC_FUNCTION(sum_partial) = fit::partial([](int x, int y) { return x + y; }); FIT_TEST_CASE() { STATIC_ASSERT_EMPTY(sum_partial); FIT_TEST_CHECK(3 == sum_partial(1, 2)); FIT_TEST_CHECK(3 == sum_partial(1)(2)); } FIT_STATIC_FUNCTION(add_one_pipable) = fit::pipable([](int x) { return x + 1; }); FIT_TEST_CASE() { STATIC_ASSERT_EMPTY(add_one_pipable); FIT_TEST_CHECK(3 == add_one_pipable(2)); FIT_TEST_CHECK(3 == (2 | add_one_pipable)); } FIT_STATIC_FUNCTION(sum_infix) = fit::infix([](int x, int y) { return x + y; }); FIT_TEST_CASE() { STATIC_ASSERT_EMPTY(sum_infix); FIT_TEST_CHECK(3 == (1 2)); } }