unique.pass.cpp 5.1 KB

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