#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_FUNCTION(sum_partial) = fit::partial(sum_f()); FIT_TEST_CASE() { #ifndef _MSC_VER STATIC_ASSERT_EMPTY(sum_partial); #endif 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)); // } // }