swap_ranges.pass.cpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <algorithm>
  10. // template<ForwardIterator Iter1, ForwardIterator Iter2>
  11. // requires HasSwap<Iter1::reference, Iter2::reference>
  12. // Iter2
  13. // swap_ranges(Iter1 first1, Iter1 last1, Iter2 first2);
  14. #include <algorithm>
  15. #include <cassert>
  16. #ifdef _LIBCPP_MOVE
  17. #include <memory>
  18. #endif
  19. #include "../../iterators.h"
  20. template<class Iter1, class Iter2>
  21. void
  22. test()
  23. {
  24. int i[3] = {1, 2, 3};
  25. int j[3] = {4, 5, 6};
  26. Iter2 r = std::swap_ranges(Iter1(i), Iter1(i+3), Iter2(j));
  27. assert(base(r) == j+3);
  28. assert(i[0] == 4);
  29. assert(i[1] == 5);
  30. assert(i[2] == 6);
  31. assert(j[0] == 1);
  32. assert(j[1] == 2);
  33. assert(j[2] == 3);
  34. }
  35. #ifdef _LIBCPP_MOVE
  36. template<class Iter1, class Iter2>
  37. void
  38. test1()
  39. {
  40. std::unique_ptr<int> i[3];
  41. for (int k = 0; k < 3; ++k)
  42. i[k].reset(new int(k+1));
  43. std::unique_ptr<int> j[3];
  44. for (int k = 0; k < 3; ++k)
  45. j[k].reset(new int(k+4));
  46. Iter2 r = std::swap_ranges(Iter1(i), Iter1(i+3), Iter2(j));
  47. assert(base(r) == j+3);
  48. assert(*i[0] == 4);
  49. assert(*i[1] == 5);
  50. assert(*i[2] == 6);
  51. assert(*j[0] == 1);
  52. assert(*j[1] == 2);
  53. assert(*j[2] == 3);
  54. }
  55. #endif // _LIBCPP_MOVE
  56. int main()
  57. {
  58. test<forward_iterator<int*>, forward_iterator<int*> >();
  59. test<forward_iterator<int*>, bidirectional_iterator<int*> >();
  60. test<forward_iterator<int*>, random_access_iterator<int*> >();
  61. test<forward_iterator<int*>, int*>();
  62. test<bidirectional_iterator<int*>, forward_iterator<int*> >();
  63. test<bidirectional_iterator<int*>, bidirectional_iterator<int*> >();
  64. test<bidirectional_iterator<int*>, random_access_iterator<int*> >();
  65. test<bidirectional_iterator<int*>, int*>();
  66. test<random_access_iterator<int*>, forward_iterator<int*> >();
  67. test<random_access_iterator<int*>, bidirectional_iterator<int*> >();
  68. test<random_access_iterator<int*>, random_access_iterator<int*> >();
  69. test<random_access_iterator<int*>, int*>();
  70. test<int*, forward_iterator<int*> >();
  71. test<int*, bidirectional_iterator<int*> >();
  72. test<int*, random_access_iterator<int*> >();
  73. test<int*, int*>();
  74. #ifdef _LIBCPP_MOVE
  75. test1<forward_iterator<std::unique_ptr<int>*>, forward_iterator<std::unique_ptr<int>*> >();
  76. test1<forward_iterator<std::unique_ptr<int>*>, bidirectional_iterator<std::unique_ptr<int>*> >();
  77. test1<forward_iterator<std::unique_ptr<int>*>, random_access_iterator<std::unique_ptr<int>*> >();
  78. test1<forward_iterator<std::unique_ptr<int>*>, std::unique_ptr<int>*>();
  79. test1<bidirectional_iterator<std::unique_ptr<int>*>, forward_iterator<std::unique_ptr<int>*> >();
  80. test1<bidirectional_iterator<std::unique_ptr<int>*>, bidirectional_iterator<std::unique_ptr<int>*> >();
  81. test1<bidirectional_iterator<std::unique_ptr<int>*>, random_access_iterator<std::unique_ptr<int>*> >();
  82. test1<bidirectional_iterator<std::unique_ptr<int>*>, std::unique_ptr<int>*>();
  83. test1<random_access_iterator<std::unique_ptr<int>*>, forward_iterator<std::unique_ptr<int>*> >();
  84. test1<random_access_iterator<std::unique_ptr<int>*>, bidirectional_iterator<std::unique_ptr<int>*> >();
  85. test1<random_access_iterator<std::unique_ptr<int>*>, random_access_iterator<std::unique_ptr<int>*> >();
  86. test1<random_access_iterator<std::unique_ptr<int>*>, std::unique_ptr<int>*>();
  87. test1<std::unique_ptr<int>*, forward_iterator<std::unique_ptr<int>*> >();
  88. test1<std::unique_ptr<int>*, bidirectional_iterator<std::unique_ptr<int>*> >();
  89. test1<std::unique_ptr<int>*, random_access_iterator<std::unique_ptr<int>*> >();
  90. test1<std::unique_ptr<int>*, std::unique_ptr<int>*>();
  91. #endif // _LIBCPP_MOVE
  92. }