123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- //===----------------------------------------------------------------------===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- // UNSUPPORTED: c++98, c++03, c++11, c++14
- // <memory>
- // template <class ForwardIt>
- // void destroy(ForwardIt, ForwardIt);
- #include <memory>
- #include <cstdlib>
- #include <cassert>
- #include "test_macros.h"
- #include "test_iterators.h"
- struct Counted {
- static int count;
- static void reset() { count = 0; }
- Counted() { ++count; }
- Counted(Counted const&) { ++count; }
- ~Counted() { --count; }
- friend void operator&(Counted) = delete;
- };
- int Counted::count = 0;
- int main(int, char**)
- {
- using It = forward_iterator<Counted*>;
- const int N = 5;
- alignas(Counted) char pool[sizeof(Counted)*N] = {};
- Counted* p = (Counted*)pool;
- std::uninitialized_fill(p, p+N, Counted());
- assert(Counted::count == 5);
- std::destroy(p, p+1);
- p += 1;
- assert(Counted::count == 4);
- std::destroy(It(p), It(p + 4));
- assert(Counted::count == 0);
- return 0;
- }
|