unique.pass.cpp 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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<ForwardIterator Iter>
  11. // requires OutputIterator<Iter, Iter::reference>
  12. // && EqualityComparable<Iter::value_type>
  13. // constexpr Iter // constexpr after C++17
  14. // unique(Iter first, Iter last);
  15. #include <algorithm>
  16. #include <cassert>
  17. #include <memory>
  18. #include "test_macros.h"
  19. #include "test_iterators.h"
  20. #if TEST_STD_VER > 17
  21. TEST_CONSTEXPR bool test_constexpr() {
  22. int ia[] = {0, 1, 1, 3, 4};
  23. const int expected[] = {0, 1, 3, 4};
  24. const size_t N = 4;
  25. auto it = std::unique(std::begin(ia), std::end(ia));
  26. return it == (std::begin(ia) + N)
  27. && std::equal(std::begin(ia), it, std::begin(expected), std::end(expected))
  28. ;
  29. }
  30. #endif
  31. template <class Iter>
  32. void
  33. test()
  34. {
  35. int ia[] = {0};
  36. const unsigned sa = sizeof(ia)/sizeof(ia[0]);
  37. Iter r = std::unique(Iter(ia), Iter(ia+sa));
  38. assert(base(r) == ia + sa);
  39. assert(ia[0] == 0);
  40. int ib[] = {0, 1};
  41. const unsigned sb = sizeof(ib)/sizeof(ib[0]);
  42. r = std::unique(Iter(ib), Iter(ib+sb));
  43. assert(base(r) == ib + sb);
  44. assert(ib[0] == 0);
  45. assert(ib[1] == 1);
  46. int ic[] = {0, 0};
  47. const unsigned sc = sizeof(ic)/sizeof(ic[0]);
  48. r = std::unique(Iter(ic), Iter(ic+sc));
  49. assert(base(r) == ic + 1);
  50. assert(ic[0] == 0);
  51. int id[] = {0, 0, 1};
  52. const unsigned sd = sizeof(id)/sizeof(id[0]);
  53. r = std::unique(Iter(id), Iter(id+sd));
  54. assert(base(r) == id + 2);
  55. assert(id[0] == 0);
  56. assert(id[1] == 1);
  57. int ie[] = {0, 0, 1, 0};
  58. const unsigned se = sizeof(ie)/sizeof(ie[0]);
  59. r = std::unique(Iter(ie), Iter(ie+se));
  60. assert(base(r) == ie + 3);
  61. assert(ie[0] == 0);
  62. assert(ie[1] == 1);
  63. assert(ie[2] == 0);
  64. int ig[] = {0, 0, 1, 1};
  65. const unsigned sg = sizeof(ig)/sizeof(ig[0]);
  66. r = std::unique(Iter(ig), Iter(ig+sg));
  67. assert(base(r) == ig + 2);
  68. assert(ig[0] == 0);
  69. assert(ig[1] == 1);
  70. int ih[] = {0, 1, 1};
  71. const unsigned sh = sizeof(ih)/sizeof(ih[0]);
  72. r = std::unique(Iter(ih), Iter(ih+sh));
  73. assert(base(r) == ih + 2);
  74. assert(ih[0] == 0);
  75. assert(ih[1] == 1);
  76. int ii[] = {0, 1, 1, 1, 2, 2, 2};
  77. const unsigned si = sizeof(ii)/sizeof(ii[0]);
  78. r = std::unique(Iter(ii), Iter(ii+si));
  79. assert(base(r) == ii + 3);
  80. assert(ii[0] == 0);
  81. assert(ii[1] == 1);
  82. assert(ii[2] == 2);
  83. }
  84. #if TEST_STD_VER >= 11
  85. struct do_nothing
  86. {
  87. void operator()(void*) const {}
  88. };
  89. typedef std::unique_ptr<int, do_nothing> Ptr;
  90. template <class Iter>
  91. void
  92. test1()
  93. {
  94. int one = 1;
  95. int two = 2;
  96. Ptr ia[1];
  97. const unsigned sa = sizeof(ia)/sizeof(ia[0]);
  98. Iter r = std::unique(Iter(ia), Iter(ia+sa));
  99. assert(base(r) == ia + sa);
  100. assert(ia[0] == 0);
  101. Ptr ib[2];
  102. ib[1].reset(&one);
  103. const unsigned sb = sizeof(ib)/sizeof(ib[0]);
  104. r = std::unique(Iter(ib), Iter(ib+sb));
  105. assert(base(r) == ib + sb);
  106. assert(ib[0] == 0);
  107. assert(*ib[1] == 1);
  108. Ptr ic[2];
  109. const unsigned sc = sizeof(ic)/sizeof(ic[0]);
  110. r = std::unique(Iter(ic), Iter(ic+sc));
  111. assert(base(r) == ic + 1);
  112. assert(ic[0] == 0);
  113. Ptr id[3];
  114. id[2].reset(&one);
  115. const unsigned sd = sizeof(id)/sizeof(id[0]);
  116. r = std::unique(Iter(id), Iter(id+sd));
  117. assert(base(r) == id + 2);
  118. assert(id[0] == 0);
  119. assert(*id[1] == 1);
  120. Ptr ie[4];
  121. ie[2].reset(&one);
  122. const unsigned se = sizeof(ie)/sizeof(ie[0]);
  123. r = std::unique(Iter(ie), Iter(ie+se));
  124. assert(base(r) == ie + 3);
  125. assert(ie[0] == 0);
  126. assert(*ie[1] == 1);
  127. assert(ie[2] == 0);
  128. Ptr ig[4];
  129. ig[2].reset(&one);
  130. ig[3].reset(&one);
  131. const unsigned sg = sizeof(ig)/sizeof(ig[0]);
  132. r = std::unique(Iter(ig), Iter(ig+sg));
  133. assert(base(r) == ig + 2);
  134. assert(ig[0] == 0);
  135. assert(*ig[1] == 1);
  136. Ptr ih[3];
  137. ih[1].reset(&one);
  138. ih[2].reset(&one);
  139. const unsigned sh = sizeof(ih)/sizeof(ih[0]);
  140. r = std::unique(Iter(ih), Iter(ih+sh));
  141. assert(base(r) == ih + 2);
  142. assert(ih[0] == 0);
  143. assert(*ih[1] == 1);
  144. Ptr ii[7];
  145. ii[1].reset(&one);
  146. ii[2].reset(&one);
  147. ii[3].reset(&one);
  148. ii[4].reset(&two);
  149. ii[5].reset(&two);
  150. ii[6].reset(&two);
  151. const unsigned si = sizeof(ii)/sizeof(ii[0]);
  152. r = std::unique(Iter(ii), Iter(ii+si));
  153. assert(base(r) == ii + 3);
  154. assert(ii[0] == 0);
  155. assert(*ii[1] == 1);
  156. assert(*ii[2] == 2);
  157. }
  158. #endif // TEST_STD_VER >= 11
  159. int main()
  160. {
  161. test<forward_iterator<int*> >();
  162. test<bidirectional_iterator<int*> >();
  163. test<random_access_iterator<int*> >();
  164. test<int*>();
  165. #if TEST_STD_VER >= 11
  166. test1<forward_iterator<Ptr*> >();
  167. test1<bidirectional_iterator<Ptr*> >();
  168. test1<random_access_iterator<Ptr*> >();
  169. test1<Ptr*>();
  170. #endif
  171. #if TEST_STD_VER > 17
  172. static_assert(test_constexpr());
  173. #endif
  174. }