#include #include #include "test.h" #include struct factorial_t { template FIT_FIX_CONSTEXPR T operator()(Self s, T x) const { return x == 0 ? 1 : x * s(x-1); } }; struct factorial_move_t { std::unique_ptr i; factorial_move_t() : i(new int(1)) {} template FIT_FIX_CONSTEXPR T operator()(const Self& s, T x) const { return x == 0 ? *i : x * s(x-1); } }; fit::static_ > factorial = {}; fit::static_ > factorial_move = {}; FIT_TEST_CASE() { const int r1 = factorial(5); FIT_TEST_CHECK(r1 == 5*4*3*2*1); #if FIT_FIX_HAS_CONSTEXPR static_assert(r1 == 5*4*3*2*1, "Fix constexpr failed"); #endif int r2 = fit::fix([](auto s, auto x) -> decltype(x) { return x == 0 ? 1 : x * s(x-1); })(5); FIT_TEST_CHECK(r2 == 5*4*3*2*1); } 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); }