copy.pass.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is dual licensed under the MIT and the University of Illinois Open
  6. // Source Licenses. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <algorithm>
  10. // template<InputIterator InIter, OutputIterator<auto, InIter::reference> OutIter>
  11. // constexpr OutIter // constexpr after C++17
  12. // copy(InIter first, InIter last, OutIter result);
  13. #include <algorithm>
  14. #include <cassert>
  15. #include "test_macros.h"
  16. #include "test_iterators.h"
  17. // #if TEST_STD_VER > 17
  18. // TEST_CONSTEXPR bool test_constexpr() {
  19. // int ia[] = {1, 2, 3, 4, 5};
  20. // int ic[] = {6, 6, 6, 6, 6, 6, 6};
  21. //
  22. // auto p = std::copy(std::begin(ia), std::end(ia), std::begin(ic));
  23. // return std::equal(std::begin(ia), std::end(ia), std::begin(ic), p)
  24. // && std::all_of(p, std::end(ic), [](int a){return a == 6;})
  25. // ;
  26. // }
  27. // #endif
  28. template <class InIter, class OutIter>
  29. void
  30. test()
  31. {
  32. const unsigned N = 1000;
  33. int ia[N];
  34. for (unsigned i = 0; i < N; ++i)
  35. ia[i] = i;
  36. int ib[N] = {0};
  37. OutIter r = std::copy(InIter(ia), InIter(ia+N), OutIter(ib));
  38. assert(base(r) == ib+N);
  39. for (unsigned i = 0; i < N; ++i)
  40. assert(ia[i] == ib[i]);
  41. }
  42. int main()
  43. {
  44. test<input_iterator<const int*>, output_iterator<int*> >();
  45. test<input_iterator<const int*>, input_iterator<int*> >();
  46. test<input_iterator<const int*>, forward_iterator<int*> >();
  47. test<input_iterator<const int*>, bidirectional_iterator<int*> >();
  48. test<input_iterator<const int*>, random_access_iterator<int*> >();
  49. test<input_iterator<const int*>, int*>();
  50. test<forward_iterator<const int*>, output_iterator<int*> >();
  51. test<forward_iterator<const int*>, input_iterator<int*> >();
  52. test<forward_iterator<const int*>, forward_iterator<int*> >();
  53. test<forward_iterator<const int*>, bidirectional_iterator<int*> >();
  54. test<forward_iterator<const int*>, random_access_iterator<int*> >();
  55. test<forward_iterator<const int*>, int*>();
  56. test<bidirectional_iterator<const int*>, output_iterator<int*> >();
  57. test<bidirectional_iterator<const int*>, input_iterator<int*> >();
  58. test<bidirectional_iterator<const int*>, forward_iterator<int*> >();
  59. test<bidirectional_iterator<const int*>, bidirectional_iterator<int*> >();
  60. test<bidirectional_iterator<const int*>, random_access_iterator<int*> >();
  61. test<bidirectional_iterator<const int*>, int*>();
  62. test<random_access_iterator<const int*>, output_iterator<int*> >();
  63. test<random_access_iterator<const int*>, input_iterator<int*> >();
  64. test<random_access_iterator<const int*>, forward_iterator<int*> >();
  65. test<random_access_iterator<const int*>, bidirectional_iterator<int*> >();
  66. test<random_access_iterator<const int*>, random_access_iterator<int*> >();
  67. test<random_access_iterator<const int*>, int*>();
  68. test<const int*, output_iterator<int*> >();
  69. test<const int*, input_iterator<int*> >();
  70. test<const int*, forward_iterator<int*> >();
  71. test<const int*, bidirectional_iterator<int*> >();
  72. test<const int*, random_access_iterator<int*> >();
  73. test<const int*, int*>();
  74. // #if TEST_STD_VER > 17
  75. // static_assert(test_constexpr());
  76. // #endif
  77. }