// -*- C++ -*- // { dg-options "-ltbb" } // { dg-do run { target c++17 } } // { dg-timeout-factor 3 } // { dg-require-effective-target tbb-backend } //===-- for_each.pass.cpp -------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "pstl/pstl_test_config.h" #ifdef PSTL_STANDALONE_TESTS #include "pstl/execution" #include "pstl/algorithm" #else #include #include #endif // PSTL_STANDALONE_TESTS #include "pstl/test_utils.h" using namespace TestUtils; template struct Gen { Type operator()(std::size_t k) { return Type(k % 5 != 1 ? 3 * k - 7 : 0); }; }; template struct Flip { int32_t val; Flip(int32_t y) : val(y) {} T operator()(T& x) const { return x = val - x; } }; struct test_one_policy { template void operator()(Policy&& exec, Iterator first, Iterator last, Iterator expected_first, Iterator expected_last, Size n) { typedef typename std::iterator_traits::value_type T; // Try for_each std::for_each(expected_first, expected_last, Flip(1)); for_each(exec, first, last, Flip(1)); EXPECT_EQ_N(expected_first, first, n, "wrong effect from for_each"); // Try for_each_n std::for_each_n(__pstl::execution::seq, expected_first, n, Flip(1)); for_each_n(exec, first, n, Flip(1)); EXPECT_EQ_N(expected_first, first, n, "wrong effect from for_each_n"); } }; template void test() { for (size_t n = 0; n <= 100000; n = n <= 16 ? n + 1 : size_t(3.1415 * n)) { Sequence inout(n, Gen()); Sequence expected(n, Gen()); invoke_on_all_policies(test_one_policy(), inout.begin(), inout.end(), expected.begin(), expected.end(), inout.size()); } } struct test_non_const { template void operator()(Policy&& exec, Iterator iter) { invoke_if(exec, [&]() { auto f = [](typename std::iterator_traits::reference x) { x = x + 1; }; for_each(exec, iter, iter, non_const(f)); for_each_n(exec, iter, 0, non_const(f)); }); } }; int32_t main() { test(); test(); test(); test_algo_basic_single(run_for_rnd_fw()); std::cout << done() << std::endl; return 0; }