lift.cpp 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*=============================================================================
  2. Copyright (c) 2017 Paul Fultz II
  3. lift.cpp
  4. Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. ==============================================================================*/
  7. #include "test.hpp"
  8. #include <boost/hof/lift.hpp>
  9. #include <boost/hof/function.hpp>
  10. #include <boost/hof/detail/move.hpp>
  11. #include <tuple>
  12. #include <algorithm>
  13. template<class T, class U>
  14. constexpr T sum(T x, U y) BOOST_HOF_RETURNS_DEDUCE_NOEXCEPT(x+y)
  15. {
  16. return x + y;
  17. }
  18. BOOST_HOF_LIFT_CLASS(max_f, std::max);
  19. BOOST_HOF_LIFT_CLASS(sum_f, sum);
  20. #if BOOST_HOF_HAS_NOEXCEPT_DEDUCTION
  21. BOOST_HOF_TEST_CASE()
  22. {
  23. static_assert(noexcept(sum_f()(1, 2)), "noexcept lift");
  24. static_assert(!noexcept(sum_f()(std::string(), std::string())), "noexcept lift");
  25. }
  26. #endif
  27. BOOST_HOF_TEST_CASE()
  28. {
  29. BOOST_HOF_TEST_CHECK(max_f()(3, 4) == std::max(3, 4));
  30. BOOST_HOF_TEST_CHECK(sum_f()(1, 2) == 3);
  31. BOOST_HOF_STATIC_TEST_CHECK(sum_f()(1, 2) == 3);
  32. }
  33. #if BOOST_HOF_HAS_GENERIC_LAMBDA
  34. BOOST_HOF_TEST_CASE()
  35. {
  36. auto my_max = BOOST_HOF_LIFT(std::max);
  37. BOOST_HOF_TEST_CHECK(my_max(3, 4) == std::max(3, 4));
  38. BOOST_HOF_TEST_CHECK(BOOST_HOF_LIFT(std::max)(3, 4) == std::max(3, 4));
  39. BOOST_HOF_TEST_CHECK(BOOST_HOF_LIFT(sum)(1, 2) == 3);
  40. }
  41. BOOST_HOF_STATIC_FUNCTION(psum) = BOOST_HOF_LIFT(sum);
  42. BOOST_HOF_STATIC_FUNCTION(pmax) = BOOST_HOF_LIFT(std::max);
  43. BOOST_HOF_TEST_CASE()
  44. {
  45. BOOST_HOF_TEST_CHECK(pmax(3, 4) == std::max(3, 4));
  46. BOOST_HOF_TEST_CHECK(psum(1, 2) == 3);
  47. }
  48. #endif