search_n.pass.cpp 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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<class ForwardIterator, class Size, class T>
  11. // constexpr ForwardIterator // constexpr after C++17
  12. // search_n(ForwardIterator first, ForwardIterator last, Size count,
  13. // const T& value);
  14. #include <algorithm>
  15. #include <cassert>
  16. #include "test_macros.h"
  17. #include "test_iterators.h"
  18. #include "user_defined_integral.hpp"
  19. #if TEST_STD_VER > 17
  20. TEST_CONSTEXPR bool test_constexpr() {
  21. int ia[] = {0, 0, 1, 1, 2, 2};
  22. return (std::search_n(std::begin(ia), std::end(ia), 1, 0) == ia)
  23. && (std::search_n(std::begin(ia), std::end(ia), 2, 1) == ia+2)
  24. && (std::search_n(std::begin(ia), std::end(ia), 1, 3) == std::end(ia))
  25. ;
  26. }
  27. #endif
  28. template <class Iter>
  29. void
  30. test()
  31. {
  32. int ia[] = {0, 1, 2, 3, 4, 5};
  33. const unsigned sa = sizeof(ia)/sizeof(ia[0]);
  34. assert(std::search_n(Iter(ia), Iter(ia+sa), 0, 0) == Iter(ia));
  35. assert(std::search_n(Iter(ia), Iter(ia+sa), 1, 0) == Iter(ia+0));
  36. assert(std::search_n(Iter(ia), Iter(ia+sa), 2, 0) == Iter(ia+sa));
  37. assert(std::search_n(Iter(ia), Iter(ia+sa), sa, 0) == Iter(ia+sa));
  38. assert(std::search_n(Iter(ia), Iter(ia+sa), 0, 3) == Iter(ia));
  39. assert(std::search_n(Iter(ia), Iter(ia+sa), 1, 3) == Iter(ia+3));
  40. assert(std::search_n(Iter(ia), Iter(ia+sa), 2, 3) == Iter(ia+sa));
  41. assert(std::search_n(Iter(ia), Iter(ia+sa), sa, 3) == Iter(ia+sa));
  42. assert(std::search_n(Iter(ia), Iter(ia+sa), 0, 5) == Iter(ia));
  43. assert(std::search_n(Iter(ia), Iter(ia+sa), 1, 5) == Iter(ia+5));
  44. assert(std::search_n(Iter(ia), Iter(ia+sa), 2, 5) == Iter(ia+sa));
  45. assert(std::search_n(Iter(ia), Iter(ia+sa), sa, 5) == Iter(ia+sa));
  46. int ib[] = {0, 0, 1, 1, 2, 2};
  47. const unsigned sb = sizeof(ib)/sizeof(ib[0]);
  48. assert(std::search_n(Iter(ib), Iter(ib+sb), 0, 0) == Iter(ib));
  49. assert(std::search_n(Iter(ib), Iter(ib+sb), 1, 0) == Iter(ib+0));
  50. assert(std::search_n(Iter(ib), Iter(ib+sb), 2, 0) == Iter(ib+0));
  51. assert(std::search_n(Iter(ib), Iter(ib+sb), 3, 0) == Iter(ib+sb));
  52. assert(std::search_n(Iter(ib), Iter(ib+sb), sb, 0) == Iter(ib+sb));
  53. assert(std::search_n(Iter(ib), Iter(ib+sb), 0, 1) == Iter(ib));
  54. assert(std::search_n(Iter(ib), Iter(ib+sb), 1, 1) == Iter(ib+2));
  55. assert(std::search_n(Iter(ib), Iter(ib+sb), 2, 1) == Iter(ib+2));
  56. assert(std::search_n(Iter(ib), Iter(ib+sb), 3, 1) == Iter(ib+sb));
  57. assert(std::search_n(Iter(ib), Iter(ib+sb), sb, 1) == Iter(ib+sb));
  58. assert(std::search_n(Iter(ib), Iter(ib+sb), 0, 2) == Iter(ib));
  59. assert(std::search_n(Iter(ib), Iter(ib+sb), 1, 2) == Iter(ib+4));
  60. assert(std::search_n(Iter(ib), Iter(ib+sb), 2, 2) == Iter(ib+4));
  61. assert(std::search_n(Iter(ib), Iter(ib+sb), 3, 2) == Iter(ib+sb));
  62. assert(std::search_n(Iter(ib), Iter(ib+sb), sb, 2) == Iter(ib+sb));
  63. int ic[] = {0, 0, 0};
  64. const unsigned sc = sizeof(ic)/sizeof(ic[0]);
  65. assert(std::search_n(Iter(ic), Iter(ic+sc), 0, 0) == Iter(ic));
  66. assert(std::search_n(Iter(ic), Iter(ic+sc), 1, 0) == Iter(ic));
  67. assert(std::search_n(Iter(ic), Iter(ic+sc), 2, 0) == Iter(ic));
  68. assert(std::search_n(Iter(ic), Iter(ic+sc), 3, 0) == Iter(ic));
  69. assert(std::search_n(Iter(ic), Iter(ic+sc), 4, 0) == Iter(ic+sc));
  70. // Check that we properly convert the size argument to an integral.
  71. (void)std::search_n(Iter(ic), Iter(ic+sc), UserDefinedIntegral<unsigned>(0), 0);
  72. }
  73. int main()
  74. {
  75. test<forward_iterator<const int*> >();
  76. test<bidirectional_iterator<const int*> >();
  77. test<random_access_iterator<const int*> >();
  78. #if TEST_STD_VER > 17
  79. static_assert(test_constexpr());
  80. #endif
  81. }