#include #include "test.hpp" struct max_f { template constexpr T operator()(T x, U y) const { return x > y ? x : y; } }; struct sum_f { template constexpr T operator()(T x, U y) const { return x + y; } }; FIT_TEST_CASE() { FIT_TEST_CHECK(fit::reverse_compress(max_f(), 0)(2, 3, 4, 5) == 5); FIT_TEST_CHECK(fit::reverse_compress(max_f(), 0)(5, 4, 3, 2) == 5); FIT_TEST_CHECK(fit::reverse_compress(max_f(), 0)(2, 3, 5, 4) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f(), 0)(2, 3, 4, 5) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f(), 0)(5, 4, 3, 2) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f(), 0)(2, 3, 5, 4) == 5); } FIT_TEST_CASE() { FIT_TEST_CHECK(fit::reverse_compress(max_f(), 0)() == 0); FIT_TEST_CHECK(fit::reverse_compress(max_f(), 0)(5) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f(), 0)() == 0); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f(), 0)(5) == 5); } template constexpr auto find_positive_max(Ts... xs) FIT_RETURNS ( fit::reverse_compress(max_f(), 0)(xs...) ); FIT_TEST_CASE() { FIT_TEST_CHECK(find_positive_max() == 0); FIT_TEST_CHECK(find_positive_max(5) == 5); FIT_STATIC_TEST_CHECK(find_positive_max() == 0); FIT_STATIC_TEST_CHECK(find_positive_max(5) == 5); } FIT_TEST_CASE() { FIT_TEST_CHECK(fit::reverse_compress(max_f())(5) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f())(5) == 5); } FIT_TEST_CASE() { FIT_TEST_CHECK(fit::reverse_compress(max_f())(2, 3, 4, 5) == 5); FIT_TEST_CHECK(fit::reverse_compress(max_f())(5, 4, 3, 2) == 5); FIT_TEST_CHECK(fit::reverse_compress(max_f())(2, 3, 5, 4) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f())(2, 3, 4, 5) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f())(5, 4, 3, 2) == 5); FIT_STATIC_TEST_CHECK(fit::reverse_compress(max_f())(2, 3, 5, 4) == 5); } FIT_TEST_CASE() { FIT_TEST_CHECK(fit::reverse_compress(sum_f(), std::string())("hello", "-", "world") == "world-hello"); }