eval_if.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. // Copyright Louis Dionne 2013-2017
  2. // Distributed under the Boost Software License, Version 1.0.
  3. // (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)
  4. #include <boost/hana/assert.hpp>
  5. #include <boost/hana/config.hpp>
  6. #include <boost/hana/equal.hpp>
  7. #include <boost/hana/eval_if.hpp>
  8. #include <boost/hana/lazy.hpp>
  9. #include <boost/hana/traits.hpp>
  10. #include <boost/hana/type.hpp>
  11. namespace hana = boost::hana;
  12. // eval_if with heterogeneous branches and a Constant condition
  13. BOOST_HANA_CONSTEXPR_LAMBDA auto safe_make_unsigned = [](auto t) {
  14. return hana::eval_if(hana::traits::is_integral(t),
  15. hana::make_lazy(hana::traits::make_unsigned)(t),
  16. hana::make_lazy(t)
  17. );
  18. };
  19. BOOST_HANA_CONSTANT_CHECK(safe_make_unsigned(hana::type_c<void>) == hana::type_c<void>);
  20. BOOST_HANA_CONSTANT_CHECK(safe_make_unsigned(hana::type_c<int>) == hana::type_c<unsigned int>);
  21. // eval_if with homogeneous branches and a constexpr or runtime condition
  22. BOOST_HANA_CONSTEXPR_LAMBDA auto safe_divide = [](auto x, auto y) {
  23. return hana::eval_if(y == 0,
  24. [=](auto) { return 0; },
  25. [=](auto _) { return _(x) / y; }
  26. );
  27. };
  28. int main() {
  29. BOOST_HANA_CONSTEXPR_CHECK(safe_divide(6, 3) == 2);
  30. BOOST_HANA_CONSTEXPR_CHECK(safe_divide(6, 0) == 0);
  31. }