construct.pass.cpp 3.7 KB

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