infix.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /*=============================================================================
  2. Copyright (c) 2017 Paul Fultz II
  3. infix.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 <boost/hof/infix.hpp>
  8. #include <boost/hof/function.hpp>
  9. #include <boost/hof/lambda.hpp>
  10. #include <boost/hof/pipable.hpp>
  11. #include <boost/hof/placeholders.hpp>
  12. #include "test.hpp"
  13. struct sum_f
  14. {
  15. template<class T, class U>
  16. constexpr T operator()(T x, U y) const BOOST_HOF_RETURNS_DEDUCE_NOEXCEPT(x+y)
  17. {
  18. return x+y;
  19. }
  20. };
  21. static constexpr boost::hof::infix_adaptor<sum_f> sum = {};
  22. #if BOOST_HOF_HAS_NOEXCEPT_DEDUCTION
  23. BOOST_HOF_TEST_CASE()
  24. {
  25. static_assert(noexcept(1 <sum> 2), "noexcept infix");
  26. static_assert(!noexcept(std::string() <sum> std::string()), "noexcept infix");
  27. }
  28. #endif
  29. BOOST_HOF_TEST_CASE()
  30. {
  31. BOOST_HOF_TEST_CHECK(3 == (1 <sum> 2));
  32. BOOST_HOF_STATIC_TEST_CHECK(3 == (1 <sum> 2));
  33. BOOST_HOF_TEST_CHECK(3 == (sum(1, 2)));
  34. BOOST_HOF_STATIC_TEST_CHECK(3 == (sum(1, 2)));
  35. }
  36. BOOST_HOF_STATIC_FUNCTION(sum1) = boost::hof::infix(sum_f());
  37. BOOST_HOF_TEST_CASE()
  38. {
  39. BOOST_HOF_TEST_CHECK(3 == (1 <sum1> 2));
  40. BOOST_HOF_STATIC_TEST_CHECK(3 == (1 <sum1> 2));
  41. BOOST_HOF_TEST_CHECK(3 == (sum1(1, 2)));
  42. BOOST_HOF_STATIC_TEST_CHECK(3 == (sum1(1, 2)));
  43. }
  44. BOOST_HOF_STATIC_LAMBDA_FUNCTION(sum2) = boost::hof::infix([](int x, int y) { return x + y; });
  45. BOOST_HOF_TEST_CASE()
  46. {
  47. BOOST_HOF_TEST_CHECK(3 == (1 <sum2> 2));
  48. BOOST_HOF_TEST_CHECK(3 == (sum2(1, 2)));
  49. }
  50. BOOST_HOF_STATIC_FUNCTION(sum3) = boost::hof::infix(boost::hof::_ + boost::hof::_);
  51. BOOST_HOF_TEST_CASE()
  52. {
  53. BOOST_HOF_TEST_CHECK(3 == (1 <sum3> 2));
  54. BOOST_HOF_STATIC_TEST_CHECK(3 == (1 <sum3> 2));
  55. BOOST_HOF_TEST_CHECK(3 == (sum3(1, 2)));
  56. BOOST_HOF_STATIC_TEST_CHECK(3 == (sum3(1, 2)));
  57. }
  58. BOOST_HOF_STATIC_LAMBDA_FUNCTION(sum4) = boost::hof::infix(boost::hof::infix([](int x, int y) { return x + y; }));
  59. BOOST_HOF_TEST_CASE()
  60. {
  61. BOOST_HOF_TEST_CHECK(3 == (1 <sum4> 2));
  62. BOOST_HOF_TEST_CHECK(3 == (sum4(1, 2)));
  63. }
  64. BOOST_HOF_STATIC_FUNCTION(sum5) = boost::hof::infix(boost::hof::infix(boost::hof::_ + boost::hof::_));
  65. BOOST_HOF_TEST_CASE()
  66. {
  67. BOOST_HOF_TEST_CHECK(3 == (1 <sum5> 2));
  68. BOOST_HOF_STATIC_TEST_CHECK(3 == (1 <sum5> 2));
  69. BOOST_HOF_TEST_CHECK(3 == (sum5(1, 2)));
  70. BOOST_HOF_STATIC_TEST_CHECK(3 == (sum5(1, 2)));
  71. }
  72. BOOST_HOF_TEST_CASE()
  73. {
  74. #if (defined(__GNUC__) && !defined (__clang__))
  75. #pragma GCC diagnostic push
  76. #pragma GCC diagnostic ignored "-Wparentheses"
  77. #endif
  78. BOOST_HOF_TEST_CHECK(6 == (1 + 2 <sum> 3));
  79. BOOST_HOF_TEST_CHECK(3 == 1 <sum> 2);
  80. #if (defined(__GNUC__) && !defined (__clang__))
  81. #pragma GCC diagnostic pop
  82. #endif
  83. }
  84. struct foo {};
  85. BOOST_HOF_TEST_CASE()
  86. {
  87. auto f = boost::hof::infix([](int, int) { return foo{}; });
  88. auto g = boost::hof::infix([](foo, foo) { return std::string("hello"); });
  89. BOOST_HOF_TEST_CHECK((1 <f> 2 <g> foo{}) == "hello");
  90. }