construct.pass.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. // <memory>
  9. // allocator:
  10. // template <class... Args> void construct(pointer p, Args&&... args);
  11. #include <memory>
  12. #include <cassert>
  13. #include "test_macros.h"
  14. #include "count_new.h"
  15. int A_constructed = 0;
  16. struct A
  17. {
  18. int data;
  19. A() {++A_constructed;}
  20. A(const A&) {++A_constructed;}
  21. explicit A(int) {++A_constructed;}
  22. A(int, int*) {++A_constructed;}
  23. ~A() {--A_constructed;}
  24. };
  25. int move_only_constructed = 0;
  26. #if TEST_STD_VER >= 11
  27. class move_only
  28. {
  29. move_only(const move_only&) = delete;
  30. move_only& operator=(const move_only&)= delete;
  31. public:
  32. move_only(move_only&&) {++move_only_constructed;}
  33. move_only& operator=(move_only&&) {return *this;}
  34. move_only() {++move_only_constructed;}
  35. ~move_only() {--move_only_constructed;}
  36. public:
  37. int data; // unused other than to make sizeof(move_only) == sizeof(int).
  38. // but public to suppress "-Wunused-private-field"
  39. };
  40. #endif // TEST_STD_VER >= 11
  41. int main(int, char**)
  42. {
  43. {
  44. std::allocator<A> a;
  45. assert(globalMemCounter.checkOutstandingNewEq(0));
  46. assert(A_constructed == 0);
  47. globalMemCounter.last_new_size = 0;
  48. A* ap = a.allocate(3);
  49. DoNotOptimize(ap);
  50. assert(globalMemCounter.checkOutstandingNewEq(1));
  51. assert(globalMemCounter.checkLastNewSizeEq(3 * sizeof(int)));
  52. assert(A_constructed == 0);
  53. a.construct(ap);
  54. assert(globalMemCounter.checkOutstandingNewEq(1));
  55. assert(A_constructed == 1);
  56. a.destroy(ap);
  57. assert(globalMemCounter.checkOutstandingNewEq(1));
  58. assert(A_constructed == 0);
  59. a.construct(ap, A());
  60. assert(globalMemCounter.checkOutstandingNewEq(1));
  61. assert(A_constructed == 1);
  62. a.destroy(ap);
  63. assert(globalMemCounter.checkOutstandingNewEq(1));
  64. assert(A_constructed == 0);
  65. a.construct(ap, 5);
  66. assert(globalMemCounter.checkOutstandingNewEq(1));
  67. assert(A_constructed == 1);
  68. a.destroy(ap);
  69. assert(globalMemCounter.checkOutstandingNewEq(1));
  70. assert(A_constructed == 0);
  71. a.construct(ap, 5, (int*)0);
  72. assert(globalMemCounter.checkOutstandingNewEq(1));
  73. assert(A_constructed == 1);
  74. a.destroy(ap);
  75. assert(globalMemCounter.checkOutstandingNewEq(1));
  76. assert(A_constructed == 0);
  77. a.deallocate(ap, 3);
  78. DoNotOptimize(ap);
  79. assert(globalMemCounter.checkOutstandingNewEq(0));
  80. assert(A_constructed == 0);
  81. }
  82. #if TEST_STD_VER >= 11
  83. {
  84. std::allocator<move_only> a;
  85. assert(globalMemCounter.checkOutstandingNewEq(0));
  86. assert(move_only_constructed == 0);
  87. globalMemCounter.last_new_size = 0;
  88. move_only* ap = a.allocate(3);
  89. DoNotOptimize(ap);
  90. assert(globalMemCounter.checkOutstandingNewEq(1));
  91. assert(globalMemCounter.checkLastNewSizeEq(3 * sizeof(int)));
  92. assert(move_only_constructed == 0);
  93. a.construct(ap);
  94. assert(globalMemCounter.checkOutstandingNewEq(1));
  95. assert(move_only_constructed == 1);
  96. a.destroy(ap);
  97. assert(globalMemCounter.checkOutstandingNewEq(1));
  98. assert(move_only_constructed == 0);
  99. a.construct(ap, move_only());
  100. assert(globalMemCounter.checkOutstandingNewEq(1));
  101. assert(move_only_constructed == 1);
  102. a.destroy(ap);
  103. assert(globalMemCounter.checkOutstandingNewEq(1));
  104. assert(move_only_constructed == 0);
  105. a.deallocate(ap, 3);
  106. DoNotOptimize(ap);
  107. assert(globalMemCounter.checkOutstandingNewEq(0));
  108. assert(move_only_constructed == 0);
  109. }
  110. #endif
  111. return 0;
  112. }