blob: 85e4c4b3fcf2adae39f760ae3fb77fc004afba7c [file] [log] [blame]
Howard Hinnantc51e1022010-05-11 19:42:16 +00001// -*- C++ -*-
2//===----------------------------- new ------------------------------------===//
3//
Chandler Carruthd2012102019-01-19 10:56:40 +00004// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5// See https://llvm.org/LICENSE.txt for license information.
6// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Howard Hinnantc51e1022010-05-11 19:42:16 +00007//
8//===----------------------------------------------------------------------===//
9
10#ifndef _LIBCPP_NEW
11#define _LIBCPP_NEW
12
13/*
14 new synopsis
15
16namespace std
17{
18
19class bad_alloc
20 : public exception
21{
22public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000023 bad_alloc() noexcept;
24 bad_alloc(const bad_alloc&) noexcept;
25 bad_alloc& operator=(const bad_alloc&) noexcept;
26 virtual const char* what() const noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000027};
28
Eric Fiselier162922f2016-10-14 06:46:30 +000029class bad_array_new_length : public bad_alloc // C++14
Marshall Clow3bf77132013-09-11 01:38:42 +000030{
31public:
32 bad_array_new_length() noexcept;
33};
34
Eric Fiselier162922f2016-10-14 06:46:30 +000035enum class align_val_t : size_t {}; // C++17
Eric Fiselier02a8a2c2019-05-23 23:46:44 +000036
37struct destroying_delete_t { // C++20
38 explicit destroying_delete_t() = default;
39};
40inline constexpr destroying_delete_t destroying_delete{}; // C++20
41
Howard Hinnantc51e1022010-05-11 19:42:16 +000042struct nothrow_t {};
43extern const nothrow_t nothrow;
44typedef void (*new_handler)();
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000045new_handler set_new_handler(new_handler new_p) noexcept;
46new_handler get_new_handler() noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000047
Marshall Clowdf5a11f2017-11-22 19:49:03 +000048// 21.6.4, pointer optimization barrier
49template <class T> constexpr T* launder(T* p) noexcept; // C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000050} // std
51
Marshall Clowbe8b84d2017-12-04 23:03:42 +000052void* operator new(std::size_t size); // replaceable, nodiscard in C++2a
53void* operator new(std::size_t size, std::align_val_t alignment); // replaceable, C++17, nodiscard in C++2a
54void* operator new(std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000055void* operator new(std::size_t size, std::align_val_t alignment,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000056 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000057void operator delete(void* ptr) noexcept; // replaceable
Larisse Voufo574190d2015-02-15 05:18:55 +000058void operator delete(void* ptr, std::size_t size) noexcept; // replaceable, C++14
Eric Fiselier162922f2016-10-14 06:46:30 +000059void operator delete(void* ptr, std::align_val_t alignment) noexcept; // replaceable, C++17
60void operator delete(void* ptr, std::size_t size,
61 std::align_val_t alignment) noexcept; // replaceable, C++17
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000062void operator delete(void* ptr, const std::nothrow_t&) noexcept; // replaceable
Eric Fiselier162922f2016-10-14 06:46:30 +000063void operator delete(void* ptr, std:align_val_t alignment,
64 const std::nothrow_t&) noexcept; // replaceable, C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000065
Marshall Clowbe8b84d2017-12-04 23:03:42 +000066void* operator new[](std::size_t size); // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000067void* operator new[](std::size_t size,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000068 std::align_val_t alignment) noexcept; // replaceable, C++17, nodiscard in C++2a
69void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000070void* operator new[](std::size_t size, std::align_val_t alignment,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000071 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000072void operator delete[](void* ptr) noexcept; // replaceable
Larisse Voufo574190d2015-02-15 05:18:55 +000073void operator delete[](void* ptr, std::size_t size) noexcept; // replaceable, C++14
Eric Fiselier162922f2016-10-14 06:46:30 +000074void operator delete[](void* ptr,
75 std::align_val_t alignment) noexcept; // replaceable, C++17
76void operator delete[](void* ptr, std::size_t size,
77 std::align_val_t alignment) noexcept; // replaceable, C++17
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000078void operator delete[](void* ptr, const std::nothrow_t&) noexcept; // replaceable
Eric Fiselier162922f2016-10-14 06:46:30 +000079void operator delete[](void* ptr, std::align_val_t alignment,
80 const std::nothrow_t&) noexcept; // replaceable, C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000081
Marshall Clowbe8b84d2017-12-04 23:03:42 +000082void* operator new (std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
83void* operator new[](std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000084void operator delete (void* ptr, void*) noexcept;
85void operator delete[](void* ptr, void*) noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000086
87*/
88
89#include <__config>
90#include <exception>
Eric Fiselier06548ab2018-03-22 04:42:56 +000091#include <type_traits>
Howard Hinnantc51e1022010-05-11 19:42:16 +000092#include <cstddef>
Marshall Clow0a1e7502018-09-12 19:41:40 +000093#include <version>
Eric Fiselier279c3192016-09-06 21:25:27 +000094#ifdef _LIBCPP_NO_EXCEPTIONS
95#include <cstdlib>
96#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +000097
Eric Fiselier85f66332019-03-05 01:57:01 +000098#if defined(_LIBCPP_ABI_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +000099#include <new.h>
100#endif
101
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000102#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000103#pragma GCC system_header
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000104#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +0000105
Eric Fiselier2856ef82018-10-25 17:21:30 +0000106#if !defined(__cpp_sized_deallocation) || __cpp_sized_deallocation < 201309L
107#define _LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION
108#endif
109
110#if !defined(_LIBCPP_BUILDING_LIBRARY) && _LIBCPP_STD_VER < 14 && \
111 defined(_LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION)
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000112# define _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
113#endif
114
115#if defined(_LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION) || \
Eric Fiselier2856ef82018-10-25 17:21:30 +0000116 defined(_LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION)
Eric Fiselier162922f2016-10-14 06:46:30 +0000117# define _LIBCPP_HAS_NO_SIZED_DEALLOCATION
118#endif
119
Eric Fiselier06548ab2018-03-22 04:42:56 +0000120#if !__has_builtin(__builtin_operator_new) || \
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000121 __has_builtin(__builtin_operator_new) < 201802L
122#define _LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE
Eric Fiselier06548ab2018-03-22 04:42:56 +0000123#endif
124
Howard Hinnantc51e1022010-05-11 19:42:16 +0000125namespace std // purposefully not using versioning namespace
126{
127
Eric Fiselier85f66332019-03-05 01:57:01 +0000128#if !defined(_LIBCPP_ABI_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +0000129struct _LIBCPP_TYPE_VIS nothrow_t {};
130extern _LIBCPP_FUNC_VIS const nothrow_t nothrow;
131
Howard Hinnantc51e1022010-05-11 19:42:16 +0000132class _LIBCPP_EXCEPTION_ABI bad_alloc
133 : public exception
134{
135public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000136 bad_alloc() _NOEXCEPT;
137 virtual ~bad_alloc() _NOEXCEPT;
138 virtual const char* what() const _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000139};
140
141class _LIBCPP_EXCEPTION_ABI bad_array_new_length
142 : public bad_alloc
143{
144public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000145 bad_array_new_length() _NOEXCEPT;
146 virtual ~bad_array_new_length() _NOEXCEPT;
147 virtual const char* what() const _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000148};
149
Eric Fiselierec3a1672017-02-10 08:57:35 +0000150typedef void (*new_handler)();
151_LIBCPP_FUNC_VIS new_handler set_new_handler(new_handler) _NOEXCEPT;
152_LIBCPP_FUNC_VIS new_handler get_new_handler() _NOEXCEPT;
153
Eric Fiselier85f66332019-03-05 01:57:01 +0000154#endif // !_LIBCPP_ABI_VCRUNTIME
Eric Fiselierec3a1672017-02-10 08:57:35 +0000155
Marshall Clow8fea1612016-08-25 15:09:01 +0000156_LIBCPP_NORETURN _LIBCPP_FUNC_VIS void __throw_bad_alloc(); // not in C++ spec
157
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000158#if !defined(_LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION) && \
Eric Fiselier85f66332019-03-05 01:57:01 +0000159 !defined(_LIBCPP_ABI_VCRUNTIME)
Eric Fiselier162922f2016-10-14 06:46:30 +0000160#ifndef _LIBCPP_CXX03_LANG
161enum class _LIBCPP_ENUM_VIS align_val_t : size_t { };
162#else
163enum align_val_t { __zero = 0, __max = (size_t)-1 };
164#endif
165#endif
166
Eric Fiselier02a8a2c2019-05-23 23:46:44 +0000167#if _LIBCPP_STD_VER > 17
168// Enable the declaration even if the compiler doesn't support the language
169// feature.
170struct destroying_delete_t {
171 explicit destroying_delete_t() = default;
172};
173_LIBCPP_INLINE_VAR constexpr destroying_delete_t destroying_delete{};
174#endif // _LIBCPP_STD_VER > 17
175
Howard Hinnantc51e1022010-05-11 19:42:16 +0000176} // std
177
Eric Fiselier499a0a52017-01-02 23:27:42 +0000178#if defined(_LIBCPP_CXX03_LANG)
Eric Fiselier162922f2016-10-14 06:46:30 +0000179#define _THROW_BAD_ALLOC throw(std::bad_alloc)
180#else
181#define _THROW_BAD_ALLOC
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000182#endif
Eric Fiselier162922f2016-10-14 06:46:30 +0000183
Eric Fiselier85f66332019-03-05 01:57:01 +0000184#if !defined(_LIBCPP_ABI_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +0000185
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000186_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz) _THROW_BAD_ALLOC;
Louis Dionnee147b352019-02-26 06:34:42 +0000187_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _LIBCPP_NOALIAS;
Shoaib Meenai2d71db42016-11-16 22:18:10 +0000188_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p) _NOEXCEPT;
189_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000190#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Mehdi Amini228053d2017-05-04 17:08:54 +0000191_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete(void* __p, std::size_t __sz) _NOEXCEPT;
Larisse Voufoa744a7e2015-02-20 06:13:05 +0000192#endif
Howard Hinnanta37d3cf2013-08-12 18:38:34 +0000193
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000194_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz) _THROW_BAD_ALLOC;
Louis Dionnee147b352019-02-26 06:34:42 +0000195_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _LIBCPP_NOALIAS;
Shoaib Meenai2d71db42016-11-16 22:18:10 +0000196_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p) _NOEXCEPT;
197_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000198#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Mehdi Amini228053d2017-05-04 17:08:54 +0000199_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete[](void* __p, std::size_t __sz) _NOEXCEPT;
Larisse Voufoa744a7e2015-02-20 06:13:05 +0000200#endif
Howard Hinnanta37d3cf2013-08-12 18:38:34 +0000201
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000202#ifndef _LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000203_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
Louis Dionnee147b352019-02-26 06:34:42 +0000204_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _LIBCPP_NOALIAS;
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000205_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, std::align_val_t) _NOEXCEPT;
206_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, std::align_val_t, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000207#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000208_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete(void* __p, std::size_t __sz, std::align_val_t) _NOEXCEPT;
Eric Fiselier162922f2016-10-14 06:46:30 +0000209#endif
210
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000211_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
Louis Dionnee147b352019-02-26 06:34:42 +0000212_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _LIBCPP_NOALIAS;
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000213_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, std::align_val_t) _NOEXCEPT;
214_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, std::align_val_t, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000215#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000216_LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_AVAILABILITY_SIZED_NEW_DELETE void operator delete[](void* __p, std::size_t __sz, std::align_val_t) _NOEXCEPT;
Eric Fiselier162922f2016-10-14 06:46:30 +0000217#endif
218#endif
219
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000220_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY void* operator new (std::size_t, void* __p) _NOEXCEPT {return __p;}
221_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY void* operator new[](std::size_t, void* __p) _NOEXCEPT {return __p;}
Howard Hinnantb8a8ca22013-10-04 22:09:00 +0000222inline _LIBCPP_INLINE_VISIBILITY void operator delete (void*, void*) _NOEXCEPT {}
223inline _LIBCPP_INLINE_VISIBILITY void operator delete[](void*, void*) _NOEXCEPT {}
Howard Hinnantc51e1022010-05-11 19:42:16 +0000224
Eric Fiselier85f66332019-03-05 01:57:01 +0000225#endif // !_LIBCPP_ABI_VCRUNTIME
Eric Fiselierec3a1672017-02-10 08:57:35 +0000226
Richard Smith1f1c1472014-06-04 19:54:15 +0000227_LIBCPP_BEGIN_NAMESPACE_STD
228
Eric Fiselier06548ab2018-03-22 04:42:56 +0000229_LIBCPP_CONSTEXPR inline _LIBCPP_INLINE_VISIBILITY bool __is_overaligned_for_new(size_t __align) _NOEXCEPT {
230#ifdef __STDCPP_DEFAULT_NEW_ALIGNMENT__
231 return __align > __STDCPP_DEFAULT_NEW_ALIGNMENT__;
232#else
233 return __align > alignment_of<max_align_t>::value;
234#endif
235}
236
237inline _LIBCPP_INLINE_VISIBILITY void *__libcpp_allocate(size_t __size, size_t __align) {
238#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
239 if (__is_overaligned_for_new(__align)) {
240 const align_val_t __align_val = static_cast<align_val_t>(__align);
Eric Fiselier6535ce22018-10-11 01:48:00 +0000241# ifdef _LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE
Eric Fiselier06548ab2018-03-22 04:42:56 +0000242 return ::operator new(__size, __align_val);
243# else
244 return __builtin_operator_new(__size, __align_val);
245# endif
246 }
247#else
248 ((void)__align);
249#endif
Richard Smith1f1c1472014-06-04 19:54:15 +0000250#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
251 return ::operator new(__size);
252#else
253 return __builtin_operator_new(__size);
254#endif
255}
256
Eric Fiselier2856ef82018-10-25 17:21:30 +0000257struct _DeallocateCaller {
258 static inline _LIBCPP_INLINE_VISIBILITY
259 void __do_deallocate_handle_size_align(void *__ptr, size_t __size, size_t __align) {
260#if defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION)
261 ((void)__align);
262 return __do_deallocate_handle_size(__ptr, __size);
263#else
264 if (__is_overaligned_for_new(__align)) {
265 const align_val_t __align_val = static_cast<align_val_t>(__align);
266 return __do_deallocate_handle_size(__ptr, __size, __align_val);
267 } else {
268 return __do_deallocate_handle_size(__ptr, __size);
269 }
270#endif
Eric Fiselier01744a72018-10-24 22:44:01 +0000271 }
Eric Fiselier2856ef82018-10-25 17:21:30 +0000272
273 static inline _LIBCPP_INLINE_VISIBILITY
274 void __do_deallocate_handle_align(void *__ptr, size_t __align) {
275#if defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION)
276 ((void)__align);
277 return __do_call(__ptr);
Eric Fiselier01744a72018-10-24 22:44:01 +0000278#else
Eric Fiselier2856ef82018-10-25 17:21:30 +0000279 if (__is_overaligned_for_new(__align)) {
280 const align_val_t __align_val = static_cast<align_val_t>(__align);
281 return __do_call(__ptr, __align_val);
282 } else {
283 return __do_call(__ptr);
284 }
Eric Fiselier01744a72018-10-24 22:44:01 +0000285#endif
Eric Fiselier2856ef82018-10-25 17:21:30 +0000286 }
287
288 private:
289 static inline void __do_deallocate_handle_size(void *__ptr, size_t __size) {
290#ifdef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
291 ((void)__size);
292 return __do_call(__ptr);
293#else
294 return __do_call(__ptr, __size);
295#endif
296 }
297
298#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
299 static inline void __do_deallocate_handle_size(void *__ptr, size_t __size, align_val_t __align) {
300#ifdef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
301 ((void)__size);
302 return __do_call(__ptr, __align);
303#else
304 return __do_call(__ptr, __size, __align);
305#endif
306 }
307#endif
308
309private:
310 template <class _A1, class _A2>
311 static inline void __do_call(void *__ptr, _A1 __a1, _A2 __a2) {
312#if defined(_LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE) || \
313 defined(_LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE)
314 return ::operator delete(__ptr, __a1, __a2);
315#else
316 return __builtin_operator_delete(__ptr, __a1, __a2);
317#endif
318 }
319
320 template <class _A1>
321 static inline void __do_call(void *__ptr, _A1 __a1) {
322#if defined(_LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE) || \
323 defined(_LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE)
324 return ::operator delete(__ptr, __a1);
325#else
326 return __builtin_operator_delete(__ptr, __a1);
327#endif
328 }
329
330 static inline void __do_call(void *__ptr) {
Eric Fiselier06548ab2018-03-22 04:42:56 +0000331#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
Eric Fiselier2856ef82018-10-25 17:21:30 +0000332 return ::operator delete(__ptr);
Eric Fiselier06548ab2018-03-22 04:42:56 +0000333#else
Eric Fiselier2856ef82018-10-25 17:21:30 +0000334 return __builtin_operator_delete(__ptr);
Richard Smith1f1c1472014-06-04 19:54:15 +0000335#endif
Eric Fiselier2856ef82018-10-25 17:21:30 +0000336 }
337};
338
339inline _LIBCPP_INLINE_VISIBILITY void __libcpp_deallocate(void* __ptr, size_t __size, size_t __align) {
340 _DeallocateCaller::__do_deallocate_handle_size_align(__ptr, __size, __align);
341}
342
343inline _LIBCPP_INLINE_VISIBILITY void __libcpp_deallocate_unsized(void* __ptr, size_t __align) {
344 _DeallocateCaller::__do_deallocate_handle_align(__ptr, __align);
Richard Smith1f1c1472014-06-04 19:54:15 +0000345}
346
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000347template <class _Tp>
Louis Dionne44bcff92018-08-03 22:36:53 +0000348_LIBCPP_NODISCARD_AFTER_CXX17 inline
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000349_LIBCPP_CONSTEXPR _Tp* __launder(_Tp* __p) _NOEXCEPT
350{
351 static_assert (!(is_function<_Tp>::value), "can't launder functions" );
352 static_assert (!(is_same<void, typename remove_cv<_Tp>::type>::value), "can't launder cv-void" );
353#ifdef _LIBCPP_COMPILER_HAS_BUILTIN_LAUNDER
354 return __builtin_launder(__p);
355#else
356 return __p;
357#endif
358}
359
360
361#if _LIBCPP_STD_VER > 14
362template <class _Tp>
363_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY
364constexpr _Tp* launder(_Tp* __p) noexcept
365{
Marshall Clow6ac349c2017-11-23 01:25:03 +0000366 return _VSTD::__launder(__p);
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000367}
368#endif
369
Richard Smith1f1c1472014-06-04 19:54:15 +0000370_LIBCPP_END_NAMESPACE_STD
371
Howard Hinnantc51e1022010-05-11 19:42:16 +0000372#endif // _LIBCPP_NEW