binary_transform.pass.cpp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. // <algorithm>
  9. // template<InputIterator InIter1, InputIterator InIter2, class OutIter,
  10. // Callable<auto, const InIter1::value_type&, const InIter2::value_type&> BinaryOp>
  11. // requires OutputIterator<OutIter, BinaryOp::result_type> && CopyConstructible<BinaryOp>
  12. // constexpr OutIter // constexpr after C++17
  13. // transform(InIter1 first1, InIter1 last1, InIter2 first2, OutIter result, BinaryOp binary_op);
  14. #include <algorithm>
  15. #include <functional>
  16. #include <cassert>
  17. #include "test_macros.h"
  18. #include "test_iterators.h"
  19. #if TEST_STD_VER > 17
  20. TEST_CONSTEXPR bool test_constexpr() {
  21. const int ia[] = {1, 3, 6, 7};
  22. const int ib[] = {2, 4, 7, 8};
  23. int ic[] = {0, 0, 0, 0, 0}; // one bigger
  24. const int expected[] = {3, 7, 13, 15};
  25. auto it = std::transform(std::begin(ia), std::end(ia),
  26. std::begin(ib), std::begin(ic), std::plus<int>());
  27. return it == (std::begin(ic) + std::size(ia))
  28. && *it == 0 // don't overwrite the last value in the output array
  29. && std::equal(std::begin(expected), std::end(expected), std::begin(ic), it)
  30. ;
  31. }
  32. #endif
  33. template<class InIter1, class InIter2, class OutIter>
  34. void
  35. test()
  36. {
  37. int ia[] = {0, 1, 2, 3, 4};
  38. const unsigned sa = sizeof(ia)/sizeof(ia[0]);
  39. int ib[sa] = {1, 2, 3, 4, 5};
  40. OutIter r = std::transform(InIter1(ib), InIter1(ib+sa), InIter2(ia),
  41. OutIter(ib), std::minus<int>());
  42. assert(base(r) == ib + sa);
  43. assert(ib[0] == 1);
  44. assert(ib[1] == 1);
  45. assert(ib[2] == 1);
  46. assert(ib[3] == 1);
  47. assert(ib[4] == 1);
  48. }
  49. int main(int, char**)
  50. {
  51. test<input_iterator<const int*>, input_iterator<const int*>, output_iterator<int*> >();
  52. test<input_iterator<const int*>, input_iterator<const int*>, input_iterator<int*> >();
  53. test<input_iterator<const int*>, input_iterator<const int*>, forward_iterator<int*> >();
  54. test<input_iterator<const int*>, input_iterator<const int*>, bidirectional_iterator<int*> >();
  55. test<input_iterator<const int*>, input_iterator<const int*>, random_access_iterator<int*> >();
  56. test<input_iterator<const int*>, input_iterator<const int*>, int*>();
  57. test<input_iterator<const int*>, forward_iterator<const int*>, output_iterator<int*> >();
  58. test<input_iterator<const int*>, forward_iterator<const int*>, input_iterator<int*> >();
  59. test<input_iterator<const int*>, forward_iterator<const int*>, forward_iterator<int*> >();
  60. test<input_iterator<const int*>, forward_iterator<const int*>, bidirectional_iterator<int*> >();
  61. test<input_iterator<const int*>, forward_iterator<const int*>, random_access_iterator<int*> >();
  62. test<input_iterator<const int*>, forward_iterator<const int*>, int*>();
  63. test<input_iterator<const int*>, bidirectional_iterator<const int*>, output_iterator<int*> >();
  64. test<input_iterator<const int*>, bidirectional_iterator<const int*>, input_iterator<int*> >();
  65. test<input_iterator<const int*>, bidirectional_iterator<const int*>, forward_iterator<int*> >();
  66. test<input_iterator<const int*>, bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  67. test<input_iterator<const int*>, bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  68. test<input_iterator<const int*>, bidirectional_iterator<const int*>, int*>();
  69. test<input_iterator<const int*>, random_access_iterator<const int*>, output_iterator<int*> >();
  70. test<input_iterator<const int*>, random_access_iterator<const int*>, input_iterator<int*> >();
  71. test<input_iterator<const int*>, random_access_iterator<const int*>, forward_iterator<int*> >();
  72. test<input_iterator<const int*>, random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  73. test<input_iterator<const int*>, random_access_iterator<const int*>, random_access_iterator<int*> >();
  74. test<input_iterator<const int*>, random_access_iterator<const int*>, int*>();
  75. test<input_iterator<const int*>, const int*, output_iterator<int*> >();
  76. test<input_iterator<const int*>, const int*, input_iterator<int*> >();
  77. test<input_iterator<const int*>, const int*, forward_iterator<int*> >();
  78. test<input_iterator<const int*>, const int*, bidirectional_iterator<int*> >();
  79. test<input_iterator<const int*>, const int*, random_access_iterator<int*> >();
  80. test<input_iterator<const int*>, const int*, int*>();
  81. test<forward_iterator<const int*>, input_iterator<const int*>, output_iterator<int*> >();
  82. test<forward_iterator<const int*>, input_iterator<const int*>, input_iterator<int*> >();
  83. test<forward_iterator<const int*>, input_iterator<const int*>, forward_iterator<int*> >();
  84. test<forward_iterator<const int*>, input_iterator<const int*>, bidirectional_iterator<int*> >();
  85. test<forward_iterator<const int*>, input_iterator<const int*>, random_access_iterator<int*> >();
  86. test<forward_iterator<const int*>, input_iterator<const int*>, int*>();
  87. test<forward_iterator<const int*>, forward_iterator<const int*>, output_iterator<int*> >();
  88. test<forward_iterator<const int*>, forward_iterator<const int*>, input_iterator<int*> >();
  89. test<forward_iterator<const int*>, forward_iterator<const int*>, forward_iterator<int*> >();
  90. test<forward_iterator<const int*>, forward_iterator<const int*>, bidirectional_iterator<int*> >();
  91. test<forward_iterator<const int*>, forward_iterator<const int*>, random_access_iterator<int*> >();
  92. test<forward_iterator<const int*>, forward_iterator<const int*>, int*>();
  93. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, output_iterator<int*> >();
  94. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, input_iterator<int*> >();
  95. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, forward_iterator<int*> >();
  96. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  97. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  98. test<forward_iterator<const int*>, bidirectional_iterator<const int*>, int*>();
  99. test<forward_iterator<const int*>, random_access_iterator<const int*>, output_iterator<int*> >();
  100. test<forward_iterator<const int*>, random_access_iterator<const int*>, input_iterator<int*> >();
  101. test<forward_iterator<const int*>, random_access_iterator<const int*>, forward_iterator<int*> >();
  102. test<forward_iterator<const int*>, random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  103. test<forward_iterator<const int*>, random_access_iterator<const int*>, random_access_iterator<int*> >();
  104. test<forward_iterator<const int*>, random_access_iterator<const int*>, int*>();
  105. test<forward_iterator<const int*>, const int*, output_iterator<int*> >();
  106. test<forward_iterator<const int*>, const int*, input_iterator<int*> >();
  107. test<forward_iterator<const int*>, const int*, forward_iterator<int*> >();
  108. test<forward_iterator<const int*>, const int*, bidirectional_iterator<int*> >();
  109. test<forward_iterator<const int*>, const int*, random_access_iterator<int*> >();
  110. test<forward_iterator<const int*>, const int*, int*>();
  111. test<bidirectional_iterator<const int*>, input_iterator<const int*>, output_iterator<int*> >();
  112. test<bidirectional_iterator<const int*>, input_iterator<const int*>, input_iterator<int*> >();
  113. test<bidirectional_iterator<const int*>, input_iterator<const int*>, forward_iterator<int*> >();
  114. test<bidirectional_iterator<const int*>, input_iterator<const int*>, bidirectional_iterator<int*> >();
  115. test<bidirectional_iterator<const int*>, input_iterator<const int*>, random_access_iterator<int*> >();
  116. test<bidirectional_iterator<const int*>, input_iterator<const int*>, int*>();
  117. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, output_iterator<int*> >();
  118. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, input_iterator<int*> >();
  119. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, forward_iterator<int*> >();
  120. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, bidirectional_iterator<int*> >();
  121. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, random_access_iterator<int*> >();
  122. test<bidirectional_iterator<const int*>, forward_iterator<const int*>, int*>();
  123. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, output_iterator<int*> >();
  124. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, input_iterator<int*> >();
  125. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, forward_iterator<int*> >();
  126. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  127. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  128. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*>, int*>();
  129. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, output_iterator<int*> >();
  130. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, input_iterator<int*> >();
  131. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, forward_iterator<int*> >();
  132. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  133. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, random_access_iterator<int*> >();
  134. test<bidirectional_iterator<const int*>, random_access_iterator<const int*>, int*>();
  135. test<bidirectional_iterator<const int*>, const int*, output_iterator<int*> >();
  136. test<bidirectional_iterator<const int*>, const int*, input_iterator<int*> >();
  137. test<bidirectional_iterator<const int*>, const int*, forward_iterator<int*> >();
  138. test<bidirectional_iterator<const int*>, const int*, bidirectional_iterator<int*> >();
  139. test<bidirectional_iterator<const int*>, const int*, random_access_iterator<int*> >();
  140. test<bidirectional_iterator<const int*>, const int*, int*>();
  141. test<random_access_iterator<const int*>, input_iterator<const int*>, output_iterator<int*> >();
  142. test<random_access_iterator<const int*>, input_iterator<const int*>, input_iterator<int*> >();
  143. test<random_access_iterator<const int*>, input_iterator<const int*>, forward_iterator<int*> >();
  144. test<random_access_iterator<const int*>, input_iterator<const int*>, bidirectional_iterator<int*> >();
  145. test<random_access_iterator<const int*>, input_iterator<const int*>, random_access_iterator<int*> >();
  146. test<random_access_iterator<const int*>, input_iterator<const int*>, int*>();
  147. test<random_access_iterator<const int*>, forward_iterator<const int*>, output_iterator<int*> >();
  148. test<random_access_iterator<const int*>, forward_iterator<const int*>, input_iterator<int*> >();
  149. test<random_access_iterator<const int*>, forward_iterator<const int*>, forward_iterator<int*> >();
  150. test<random_access_iterator<const int*>, forward_iterator<const int*>, bidirectional_iterator<int*> >();
  151. test<random_access_iterator<const int*>, forward_iterator<const int*>, random_access_iterator<int*> >();
  152. test<random_access_iterator<const int*>, forward_iterator<const int*>, int*>();
  153. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, output_iterator<int*> >();
  154. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, input_iterator<int*> >();
  155. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, forward_iterator<int*> >();
  156. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  157. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  158. test<random_access_iterator<const int*>, bidirectional_iterator<const int*>, int*>();
  159. test<random_access_iterator<const int*>, random_access_iterator<const int*>, output_iterator<int*> >();
  160. test<random_access_iterator<const int*>, random_access_iterator<const int*>, input_iterator<int*> >();
  161. test<random_access_iterator<const int*>, random_access_iterator<const int*>, forward_iterator<int*> >();
  162. test<random_access_iterator<const int*>, random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  163. test<random_access_iterator<const int*>, random_access_iterator<const int*>, random_access_iterator<int*> >();
  164. test<random_access_iterator<const int*>, random_access_iterator<const int*>, int*>();
  165. test<random_access_iterator<const int*>, const int*, output_iterator<int*> >();
  166. test<random_access_iterator<const int*>, const int*, input_iterator<int*> >();
  167. test<random_access_iterator<const int*>, const int*, forward_iterator<int*> >();
  168. test<random_access_iterator<const int*>, const int*, bidirectional_iterator<int*> >();
  169. test<random_access_iterator<const int*>, const int*, random_access_iterator<int*> >();
  170. test<random_access_iterator<const int*>, const int*, int*>();
  171. test<const int*, input_iterator<const int*>, output_iterator<int*> >();
  172. test<const int*, input_iterator<const int*>, input_iterator<int*> >();
  173. test<const int*, input_iterator<const int*>, forward_iterator<int*> >();
  174. test<const int*, input_iterator<const int*>, bidirectional_iterator<int*> >();
  175. test<const int*, input_iterator<const int*>, random_access_iterator<int*> >();
  176. test<const int*, input_iterator<const int*>, int*>();
  177. test<const int*, forward_iterator<const int*>, output_iterator<int*> >();
  178. test<const int*, forward_iterator<const int*>, input_iterator<int*> >();
  179. test<const int*, forward_iterator<const int*>, forward_iterator<int*> >();
  180. test<const int*, forward_iterator<const int*>, bidirectional_iterator<int*> >();
  181. test<const int*, forward_iterator<const int*>, random_access_iterator<int*> >();
  182. test<const int*, forward_iterator<const int*>, int*>();
  183. test<const int*, bidirectional_iterator<const int*>, output_iterator<int*> >();
  184. test<const int*, bidirectional_iterator<const int*>, input_iterator<int*> >();
  185. test<const int*, bidirectional_iterator<const int*>, forward_iterator<int*> >();
  186. test<const int*, bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  187. test<const int*, bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  188. test<const int*, bidirectional_iterator<const int*>, int*>();
  189. test<const int*, random_access_iterator<const int*>, output_iterator<int*> >();
  190. test<const int*, random_access_iterator<const int*>, input_iterator<int*> >();
  191. test<const int*, random_access_iterator<const int*>, forward_iterator<int*> >();
  192. test<const int*, random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  193. test<const int*, random_access_iterator<const int*>, random_access_iterator<int*> >();
  194. test<const int*, random_access_iterator<const int*>, int*>();
  195. test<const int*, const int*, output_iterator<int*> >();
  196. test<const int*, const int*, input_iterator<int*> >();
  197. test<const int*, const int*, forward_iterator<int*> >();
  198. test<const int*, const int*, bidirectional_iterator<int*> >();
  199. test<const int*, const int*, random_access_iterator<int*> >();
  200. test<const int*, const int*, int*>();
  201. #if TEST_STD_VER > 17
  202. static_assert(test_constexpr());
  203. #endif
  204. return 0;
  205. }