thrust / dependencies /libcudacxx /libcxx /test /std /algorithms /alg.modifying.operations /alg.copy /copy.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 | |
| // | |
| //===----------------------------------------------------------------------===// | |
| // <algorithm> | |
| // template<InputIterator InIter, OutputIterator<auto, InIter::reference> OutIter> | |
| // constexpr OutIter // constexpr after C++17 | |
| // copy(InIter first, InIter last, OutIter result); | |
| // #if TEST_STD_VER > 17 | |
| // TEST_CONSTEXPR bool test_constexpr() { | |
| // int ia[] = {1, 2, 3, 4, 5}; | |
| // int ic[] = {6, 6, 6, 6, 6, 6, 6}; | |
| // | |
| // auto p = std::copy(std::begin(ia), std::end(ia), std::begin(ic)); | |
| // return std::equal(std::begin(ia), std::end(ia), std::begin(ic), p) | |
| // && std::all_of(p, std::end(ic), [](int a){return a == 6;}) | |
| // ; | |
| // } | |
| // #endif | |
| template <class InIter, class OutIter> | |
| void | |
| test() | |
| { | |
| const unsigned N = 1000; | |
| int ia[N]; | |
| for (unsigned i = 0; i < N; ++i) | |
| ia[i] = i; | |
| int ib[N] = {0}; | |
| OutIter r = std::copy(InIter(ia), InIter(ia+N), OutIter(ib)); | |
| assert(base(r) == ib+N); | |
| for (unsigned i = 0; i < N; ++i) | |
| assert(ia[i] == ib[i]); | |
| } | |
| int main(int, char**) | |
| { | |
| test<input_iterator<const int*>, output_iterator<int*> >(); | |
| test<input_iterator<const int*>, input_iterator<int*> >(); | |
| test<input_iterator<const int*>, forward_iterator<int*> >(); | |
| test<input_iterator<const int*>, bidirectional_iterator<int*> >(); | |
| test<input_iterator<const int*>, random_access_iterator<int*> >(); | |
| test<input_iterator<const int*>, int*>(); | |
| test<forward_iterator<const int*>, output_iterator<int*> >(); | |
| test<forward_iterator<const int*>, input_iterator<int*> >(); | |
| test<forward_iterator<const int*>, forward_iterator<int*> >(); | |
| test<forward_iterator<const int*>, bidirectional_iterator<int*> >(); | |
| test<forward_iterator<const int*>, random_access_iterator<int*> >(); | |
| test<forward_iterator<const int*>, int*>(); | |
| test<bidirectional_iterator<const int*>, output_iterator<int*> >(); | |
| test<bidirectional_iterator<const int*>, input_iterator<int*> >(); | |
| test<bidirectional_iterator<const int*>, forward_iterator<int*> >(); | |
| test<bidirectional_iterator<const int*>, bidirectional_iterator<int*> >(); | |
| test<bidirectional_iterator<const int*>, random_access_iterator<int*> >(); | |
| test<bidirectional_iterator<const int*>, int*>(); | |
| test<random_access_iterator<const int*>, output_iterator<int*> >(); | |
| test<random_access_iterator<const int*>, input_iterator<int*> >(); | |
| test<random_access_iterator<const int*>, forward_iterator<int*> >(); | |
| test<random_access_iterator<const int*>, bidirectional_iterator<int*> >(); | |
| test<random_access_iterator<const int*>, random_access_iterator<int*> >(); | |
| test<random_access_iterator<const int*>, int*>(); | |
| test<const int*, output_iterator<int*> >(); | |
| test<const int*, input_iterator<int*> >(); | |
| test<const int*, forward_iterator<int*> >(); | |
| test<const int*, bidirectional_iterator<int*> >(); | |
| test<const int*, random_access_iterator<int*> >(); | |
| test<const int*, int*>(); | |
| // #if TEST_STD_VER > 17 | |
| // static_assert(test_constexpr()); | |
| // #endif | |
| return 0; | |
| } | |