182439169SNikolas Klauser //===----------------------------------------------------------------------===//
282439169SNikolas Klauser //
382439169SNikolas Klauser // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
482439169SNikolas Klauser // See https://llvm.org/LICENSE.txt for license information.
582439169SNikolas Klauser // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
682439169SNikolas Klauser //
782439169SNikolas Klauser //===----------------------------------------------------------------------===//
882439169SNikolas Klauser
982439169SNikolas Klauser // UNSUPPORTED: c++03, c++11, c++14
1082439169SNikolas Klauser
11*e7e37118SNikolas Klauser // UNSUPPORTED: libcpp-has-no-incomplete-pstl
1282439169SNikolas Klauser
1382439169SNikolas Klauser // <algorithm>
1482439169SNikolas Klauser
1582439169SNikolas Klauser // template<class ExecutionPolicy, class ForwardIterator, class Predicate>
1682439169SNikolas Klauser // ForwardIterator find_if(ExecutionPolicy&& exec, ForwardIterator first, ForwardIterator last,
1782439169SNikolas Klauser // Predicate pred);
1882439169SNikolas Klauser
1982439169SNikolas Klauser #include <algorithm>
2082439169SNikolas Klauser #include <cassert>
2182439169SNikolas Klauser #include <vector>
2282439169SNikolas Klauser
2382439169SNikolas Klauser #include "test_macros.h"
2482439169SNikolas Klauser #include "test_execution_policies.h"
2582439169SNikolas Klauser #include "test_iterators.h"
2682439169SNikolas Klauser
2782439169SNikolas Klauser EXECUTION_POLICY_SFINAE_TEST(find_if);
2882439169SNikolas Klauser
2982439169SNikolas Klauser static_assert(sfinae_test_find_if<int, int*, int*, bool (*)(int)>);
3082439169SNikolas Klauser static_assert(!sfinae_test_find_if<std::execution::parallel_policy, int*, int*, int>);
3182439169SNikolas Klauser
3282439169SNikolas Klauser template <class Iter>
3382439169SNikolas Klauser struct Test {
3482439169SNikolas Klauser template <class Policy>
operator ()Test3582439169SNikolas Klauser void operator()(Policy&& policy) {
3682439169SNikolas Klauser int a[] = {1, 2, 3, 4, 5, 6, 7, 8};
3782439169SNikolas Klauser
3882439169SNikolas Klauser // simple test
3982439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::end(a)), [](int i) { return i == 3; })) == a + 2);
4082439169SNikolas Klauser
4182439169SNikolas Klauser // check that last is returned if no element matches
4282439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::end(a)), [](int i) { return i == 0; })) ==
4382439169SNikolas Klauser std::end(a));
4482439169SNikolas Klauser
4582439169SNikolas Klauser // check that the first element is returned
4682439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::end(a)), [](int i) { return i == 1; })) ==
4782439169SNikolas Klauser std::begin(a));
4882439169SNikolas Klauser
4982439169SNikolas Klauser // check that an empty range works
5082439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::begin(a)), [](int i) { return i == 1; })) ==
5182439169SNikolas Klauser std::begin(a));
5282439169SNikolas Klauser
5382439169SNikolas Klauser // check that a one-element range works
5482439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::begin(a) + 1), [](int i) { return i == 1; })) ==
5582439169SNikolas Klauser std::begin(a));
5682439169SNikolas Klauser
5782439169SNikolas Klauser // check that a two-element range works
5882439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::begin(a)), Iter(std::begin(a) + 2), [](int i) { return i == 2; })) ==
5982439169SNikolas Klauser std::begin(a) + 1);
6082439169SNikolas Klauser
6182439169SNikolas Klauser // check that a large number of elements works
6282439169SNikolas Klauser std::vector<int> vec(200, 4);
6382439169SNikolas Klauser vec[176] = 5;
6482439169SNikolas Klauser assert(base(std::find_if(policy, Iter(std::data(vec)), Iter(std::data(vec) + std::size(vec)), [](int i) {
6582439169SNikolas Klauser return i == 5;
6682439169SNikolas Klauser })) == std::data(vec) + 176);
6782439169SNikolas Klauser }
6882439169SNikolas Klauser };
6982439169SNikolas Klauser
main(int,char **)7082439169SNikolas Klauser int main(int, char**) {
7182439169SNikolas Klauser types::for_each(types::forward_iterator_list<int*>{}, TestIteratorWithPolicies<Test>{});
7282439169SNikolas Klauser
7382439169SNikolas Klauser return 0;
7482439169SNikolas Klauser }
75