#include #include #include #include #include "test.hpp" #include struct factorial_t { template T operator()(Self s, T x) const noexcept { return x == 0 ? 1 : x * s(x-1); } }; struct factorial_constexpr_t { template constexpr T operator()(Self s, T x) const noexcept { return x == 0 ? 1 : x * s(x-1); } }; struct factorial_move_t { std::unique_ptr i; factorial_move_t() : i(new int(1)) {} template T operator()(const Self& s, T x) const { return x == 0 ? *i : x * s(x-1); } }; static constexpr fit::fix_adaptor factorial = {}; static constexpr fit::fix_adaptor factorial_constexpr = {}; static constexpr fit::static_ > factorial_move = {}; #if FIT_HAS_NOEXCEPT_DEDUCTION FIT_TEST_CASE() { static_assert(noexcept(factorial(5)), "noexcept fix"); } #endif FIT_TEST_CASE() { const int r = factorial(5); FIT_TEST_CHECK(r == 5*4*3*2*1); } FIT_TEST_CASE() { const int r = fit::reveal(factorial)(5); FIT_TEST_CHECK(r == 5*4*3*2*1); } #if !FIT_NO_EXPRESSION_SFINAE FIT_TEST_CASE() { const int r = fit::fix(fit::result(factorial_constexpr_t()))(5); FIT_TEST_CHECK(r == 5*4*3*2*1); } FIT_TEST_CASE() { const int r = fit::result(factorial_constexpr)(5); FIT_TEST_CHECK(r == 5*4*3*2*1); } FIT_TEST_CASE() { FIT_STATIC_TEST_CHECK(fit::fix(fit::result(factorial_constexpr_t()))(5) == 5*4*3*2*1); FIT_STATIC_TEST_CHECK(fit::result(factorial_constexpr)(5) == 5*4*3*2*1); } #endif FIT_TEST_CASE() { #if FIT_HAS_GENERIC_LAMBDA auto factorial_ = fit::fix([](auto s, auto x) -> decltype(x) { return x == 0 ? 1 : x * s(x-1); }); int r = fit::result(factorial_)(5); FIT_TEST_CHECK(r == 5*4*3*2*1); #endif } FIT_TEST_CASE() { const int r = factorial_move(5); FIT_TEST_CHECK(r == 5*4*3*2*1); FIT_TEST_CHECK(fit::fix(factorial_move_t())(5) == 5*4*3*2*1); }