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 T>
1682439169SNikolas Klauser // ForwardIterator find(ExecutionPolicy&& exec, ForwardIterator first, ForwardIterator last,
1782439169SNikolas Klauser // const T& value);
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);
2882439169SNikolas Klauser
2982439169SNikolas Klauser static_assert(sfinae_test_find<int, int*, int*, bool (*)(int)>);
3082439169SNikolas Klauser static_assert(!sfinae_test_find<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(policy, Iter(std::begin(a)), Iter(std::end(a)), 3)) == a + 2);
4082439169SNikolas Klauser
4182439169SNikolas Klauser // check that last is returned if no element matches
4282439169SNikolas Klauser assert(base(std::find(policy, Iter(std::begin(a)), Iter(std::end(a)), 0)) == std::end(a));
4382439169SNikolas Klauser
4482439169SNikolas Klauser // check that the first element is returned
4582439169SNikolas Klauser assert(base(std::find(policy, Iter(std::begin(a)), Iter(std::end(a)), 1)) == std::begin(a));
4682439169SNikolas Klauser
4782439169SNikolas Klauser // check that an empty range works
4882439169SNikolas Klauser assert(base(std::find(policy, Iter(std::begin(a)), Iter(std::begin(a)), 1)) == std::begin(a));
4982439169SNikolas Klauser
5082439169SNikolas Klauser // check that a one-element range works
5182439169SNikolas Klauser assert(base(std::find(policy, Iter(std::begin(a)), Iter(std::begin(a) + 1), 1)) == std::begin(a));
5282439169SNikolas Klauser
5382439169SNikolas Klauser // check that a two-element range works
5482439169SNikolas Klauser assert(base(std::find(policy, Iter(std::begin(a)), Iter(std::begin(a) + 2), 2)) == std::begin(a) + 1);
5582439169SNikolas Klauser
5682439169SNikolas Klauser // check that a large number of elements works
5782439169SNikolas Klauser std::vector<int> vec(200, 4);
5882439169SNikolas Klauser vec[176] = 5;
5982439169SNikolas Klauser assert(base(std::find(policy, Iter(std::data(vec)), Iter(std::data(vec) + std::size(vec)), 5)) ==
6082439169SNikolas Klauser std::data(vec) + 176);
6182439169SNikolas Klauser }
6282439169SNikolas Klauser };
6382439169SNikolas Klauser
main(int,char **)6482439169SNikolas Klauser int main(int, char**) {
6582439169SNikolas Klauser types::for_each(types::forward_iterator_list<int*>{}, TestIteratorWithPolicies<Test>{});
6682439169SNikolas Klauser
6782439169SNikolas Klauser return 0;
6882439169SNikolas Klauser }
69