erase_iter.pass.cpp 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. // <vector>
  9. // vector<bool>
  10. // iterator erase(const_iterator position);
  11. #include <vector>
  12. #include <cassert>
  13. #include "test_macros.h"
  14. #include "min_allocator.h"
  15. int main(int, char**)
  16. {
  17. bool a1[] = {1, 0, 1};
  18. {
  19. std::vector<bool> l1(a1, a1+3);
  20. std::vector<bool>::const_iterator i = l1.begin();
  21. ++i;
  22. std::vector<bool>::iterator j = l1.erase(i);
  23. assert(l1.size() == 2);
  24. assert(distance(l1.begin(), l1.end()) == 2);
  25. assert(*j == true);
  26. assert(*l1.begin() == 1);
  27. assert(*next(l1.begin()) == true);
  28. j = l1.erase(j);
  29. assert(j == l1.end());
  30. assert(l1.size() == 1);
  31. assert(distance(l1.begin(), l1.end()) == 1);
  32. assert(*l1.begin() == true);
  33. j = l1.erase(l1.begin());
  34. assert(j == l1.end());
  35. assert(l1.size() == 0);
  36. assert(distance(l1.begin(), l1.end()) == 0);
  37. }
  38. #if TEST_STD_VER >= 11
  39. {
  40. std::vector<bool, min_allocator<bool>> l1(a1, a1+3);
  41. std::vector<bool, min_allocator<bool>>::const_iterator i = l1.begin();
  42. ++i;
  43. std::vector<bool, min_allocator<bool>>::iterator j = l1.erase(i);
  44. assert(l1.size() == 2);
  45. assert(distance(l1.begin(), l1.end()) == 2);
  46. assert(*j == true);
  47. assert(*l1.begin() == 1);
  48. assert(*next(l1.begin()) == true);
  49. j = l1.erase(j);
  50. assert(j == l1.end());
  51. assert(l1.size() == 1);
  52. assert(distance(l1.begin(), l1.end()) == 1);
  53. assert(*l1.begin() == true);
  54. j = l1.erase(l1.begin());
  55. assert(j == l1.end());
  56. assert(l1.size() == 0);
  57. assert(distance(l1.begin(), l1.end()) == 0);
  58. }
  59. #endif
  60. return 0;
  61. }