blob: 412d51bd02772e3c1aae93a829c4fa6a026dfa0d [file] [log] [blame]
Howard Hinnantc51e1022010-05-11 19:42:16 +00001// -*- C++ -*-
2//===----------------------------- new ------------------------------------===//
3//
Howard Hinnantc566dc32010-05-11 21:36:01 +00004// The LLVM Compiler Infrastructure
Howard Hinnantc51e1022010-05-11 19:42:16 +00005//
Howard Hinnantee11c312010-11-16 22:09:02 +00006// This file is dual licensed under the MIT and the University of Illinois Open
7// Source Licenses. See LICENSE.TXT for details.
Howard Hinnantc51e1022010-05-11 19:42:16 +00008//
9//===----------------------------------------------------------------------===//
10
11#ifndef _LIBCPP_NEW
12#define _LIBCPP_NEW
13
14/*
15 new synopsis
16
17namespace std
18{
19
20class bad_alloc
21 : public exception
22{
23public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000024 bad_alloc() noexcept;
25 bad_alloc(const bad_alloc&) noexcept;
26 bad_alloc& operator=(const bad_alloc&) noexcept;
27 virtual const char* what() const noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000028};
29
Eric Fiselier162922f2016-10-14 06:46:30 +000030class bad_array_length : public bad_alloc // FIXME: Not part of C++
Marshall Clow3bf77132013-09-11 01:38:42 +000031{
32public:
33 bad_array_length() noexcept;
34};
35
Eric Fiselier162922f2016-10-14 06:46:30 +000036class bad_array_new_length : public bad_alloc // C++14
Marshall Clow3bf77132013-09-11 01:38:42 +000037{
38public:
39 bad_array_new_length() noexcept;
40};
41
Eric Fiselier162922f2016-10-14 06:46:30 +000042enum class align_val_t : size_t {}; // C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000043struct nothrow_t {};
44extern const nothrow_t nothrow;
45typedef void (*new_handler)();
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000046new_handler set_new_handler(new_handler new_p) noexcept;
47new_handler get_new_handler() noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000048
Marshall Clowdf5a11f2017-11-22 19:49:03 +000049// 21.6.4, pointer optimization barrier
50template <class T> constexpr T* launder(T* p) noexcept; // C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000051} // std
52
Marshall Clowbe8b84d2017-12-04 23:03:42 +000053void* operator new(std::size_t size); // replaceable, nodiscard in C++2a
54void* operator new(std::size_t size, std::align_val_t alignment); // replaceable, C++17, nodiscard in C++2a
55void* operator new(std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000056void* operator new(std::size_t size, std::align_val_t alignment,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000057 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000058void operator delete(void* ptr) noexcept; // replaceable
Larisse Voufo574190d2015-02-15 05:18:55 +000059void operator delete(void* ptr, std::size_t size) noexcept; // replaceable, C++14
Eric Fiselier162922f2016-10-14 06:46:30 +000060void operator delete(void* ptr, std::align_val_t alignment) noexcept; // replaceable, C++17
61void operator delete(void* ptr, std::size_t size,
62 std::align_val_t alignment) noexcept; // replaceable, C++17
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000063void operator delete(void* ptr, const std::nothrow_t&) noexcept; // replaceable
Eric Fiselier162922f2016-10-14 06:46:30 +000064void operator delete(void* ptr, std:align_val_t alignment,
65 const std::nothrow_t&) noexcept; // replaceable, C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000066
Marshall Clowbe8b84d2017-12-04 23:03:42 +000067void* operator new[](std::size_t size); // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000068void* operator new[](std::size_t size,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000069 std::align_val_t alignment) noexcept; // replaceable, C++17, nodiscard in C++2a
70void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a
Eric Fiselier162922f2016-10-14 06:46:30 +000071void* operator new[](std::size_t size, std::align_val_t alignment,
Marshall Clowbe8b84d2017-12-04 23:03:42 +000072 const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000073void operator delete[](void* ptr) noexcept; // replaceable
Larisse Voufo574190d2015-02-15 05:18:55 +000074void operator delete[](void* ptr, std::size_t size) noexcept; // replaceable, C++14
Eric Fiselier162922f2016-10-14 06:46:30 +000075void operator delete[](void* ptr,
76 std::align_val_t alignment) noexcept; // replaceable, C++17
77void operator delete[](void* ptr, std::size_t size,
78 std::align_val_t alignment) noexcept; // replaceable, C++17
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000079void operator delete[](void* ptr, const std::nothrow_t&) noexcept; // replaceable
Eric Fiselier162922f2016-10-14 06:46:30 +000080void operator delete[](void* ptr, std::align_val_t alignment,
81 const std::nothrow_t&) noexcept; // replaceable, C++17
Howard Hinnantc51e1022010-05-11 19:42:16 +000082
Marshall Clowbe8b84d2017-12-04 23:03:42 +000083void* operator new (std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
84void* operator new[](std::size_t size, void* ptr) noexcept; // nodiscard in C++2a
Howard Hinnant1bc52cf2011-05-26 18:23:59 +000085void operator delete (void* ptr, void*) noexcept;
86void operator delete[](void* ptr, void*) noexcept;
Howard Hinnantc51e1022010-05-11 19:42:16 +000087
88*/
89
90#include <__config>
91#include <exception>
Eric Fiselier06548ab2018-03-22 04:42:56 +000092#include <type_traits>
Howard Hinnantc51e1022010-05-11 19:42:16 +000093#include <cstddef>
Marshall Clow0a1e7502018-09-12 19:41:40 +000094#include <version>
Eric Fiselier279c3192016-09-06 21:25:27 +000095#ifdef _LIBCPP_NO_EXCEPTIONS
96#include <cstdlib>
97#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +000098
Shoaib Meenaicfd19602017-10-09 19:25:17 +000099#if defined(_LIBCPP_ABI_MICROSOFT) && !defined(_LIBCPP_NO_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +0000100#include <new.h>
101#endif
102
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000103#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
Howard Hinnantc51e1022010-05-11 19:42:16 +0000104#pragma GCC system_header
Howard Hinnantaaaa52b2011-10-17 20:05:10 +0000105#endif
Howard Hinnantc51e1022010-05-11 19:42:16 +0000106
Eric Fiselier01744a72018-10-24 22:44:01 +0000107#if !defined(__cpp_sized_deallocation) || __cpp_sized_deallocation < 201309L
108#define _LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION
109#endif
110
111#if !defined(_LIBCPP_BUILDING_LIBRARY) && _LIBCPP_STD_VER < 14 && \
112 defined(_LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION)
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000113# define _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
114#endif
115
116#if defined(_LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION) || \
Eric Fiselier01744a72018-10-24 22:44:01 +0000117 defined(_LIBCPP_HAS_NO_LANGUAGE_SIZED_DEALLOCATION)
Eric Fiselier162922f2016-10-14 06:46:30 +0000118# define _LIBCPP_HAS_NO_SIZED_DEALLOCATION
119#endif
120
Eric Fiselier06548ab2018-03-22 04:42:56 +0000121#if !__has_builtin(__builtin_operator_new) || \
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000122 __has_builtin(__builtin_operator_new) < 201802L
123#define _LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE
Eric Fiselier06548ab2018-03-22 04:42:56 +0000124#endif
125
Howard Hinnantc51e1022010-05-11 19:42:16 +0000126namespace std // purposefully not using versioning namespace
127{
128
Shoaib Meenaicfd19602017-10-09 19:25:17 +0000129#if !defined(_LIBCPP_ABI_MICROSOFT) || defined(_LIBCPP_NO_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +0000130struct _LIBCPP_TYPE_VIS nothrow_t {};
131extern _LIBCPP_FUNC_VIS const nothrow_t nothrow;
132
Howard Hinnantc51e1022010-05-11 19:42:16 +0000133class _LIBCPP_EXCEPTION_ABI bad_alloc
134 : public exception
135{
136public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000137 bad_alloc() _NOEXCEPT;
138 virtual ~bad_alloc() _NOEXCEPT;
139 virtual const char* what() const _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000140};
141
142class _LIBCPP_EXCEPTION_ABI bad_array_new_length
143 : public bad_alloc
144{
145public:
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000146 bad_array_new_length() _NOEXCEPT;
147 virtual ~bad_array_new_length() _NOEXCEPT;
148 virtual const char* what() const _NOEXCEPT;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000149};
150
Eric Fiselierec3a1672017-02-10 08:57:35 +0000151typedef void (*new_handler)();
152_LIBCPP_FUNC_VIS new_handler set_new_handler(new_handler) _NOEXCEPT;
153_LIBCPP_FUNC_VIS new_handler get_new_handler() _NOEXCEPT;
154
Shoaib Meenaicfd19602017-10-09 19:25:17 +0000155#endif // !_LIBCPP_ABI_MICROSOFT || _LIBCPP_NO_VCRUNTIME
Eric Fiselierec3a1672017-02-10 08:57:35 +0000156
Marshall Clow8fea1612016-08-25 15:09:01 +0000157_LIBCPP_NORETURN _LIBCPP_FUNC_VIS void __throw_bad_alloc(); // not in C++ spec
158
Eric Fiselierec3a1672017-02-10 08:57:35 +0000159#if defined(_LIBCPP_BUILDING_LIBRARY) || (_LIBCPP_STD_VER > 11)
Howard Hinnant4582a2b2013-11-07 17:15:51 +0000160
Mehdi Amini228053d2017-05-04 17:08:54 +0000161class _LIBCPP_EXCEPTION_ABI _LIBCPP_AVAILABILITY_BAD_ARRAY_LENGTH
162 bad_array_length : public bad_alloc {
Marshall Clow3bf77132013-09-11 01:38:42 +0000163public:
164 bad_array_length() _NOEXCEPT;
165 virtual ~bad_array_length() _NOEXCEPT;
166 virtual const char* what() const _NOEXCEPT;
167};
Howard Hinnant4582a2b2013-11-07 17:15:51 +0000168
169#define _LIBCPP_BAD_ARRAY_LENGTH_DEFINED
170
Louis Dionne5e0eadd2018-08-01 02:08:59 +0000171#endif // defined(_LIBCPP_BUILDING_LIBRARY) || (_LIBCPP_STD_VER > 11)
Marshall Clow3bf77132013-09-11 01:38:42 +0000172
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000173#if !defined(_LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION) && \
174 !defined(_LIBCPP_DEFER_NEW_TO_VCRUNTIME)
Eric Fiselier162922f2016-10-14 06:46:30 +0000175#ifndef _LIBCPP_CXX03_LANG
176enum class _LIBCPP_ENUM_VIS align_val_t : size_t { };
177#else
178enum align_val_t { __zero = 0, __max = (size_t)-1 };
179#endif
180#endif
181
Howard Hinnantc51e1022010-05-11 19:42:16 +0000182} // std
183
Eric Fiselier499a0a52017-01-02 23:27:42 +0000184#if defined(_LIBCPP_CXX03_LANG)
Eric Fiselier162922f2016-10-14 06:46:30 +0000185#define _THROW_BAD_ALLOC throw(std::bad_alloc)
186#else
187#define _THROW_BAD_ALLOC
Howard Hinnant1bc52cf2011-05-26 18:23:59 +0000188#endif
Eric Fiselier162922f2016-10-14 06:46:30 +0000189
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000190#if !defined(_LIBCPP_DEFER_NEW_TO_VCRUNTIME)
Eric Fiselierec3a1672017-02-10 08:57:35 +0000191
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000192_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz) _THROW_BAD_ALLOC;
193_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
Shoaib Meenai2d71db42016-11-16 22:18:10 +0000194_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p) _NOEXCEPT;
195_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000196#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Mehdi Amini228053d2017-05-04 17:08:54 +0000197_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 +0000198#endif
Howard Hinnanta37d3cf2013-08-12 18:38:34 +0000199
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000200_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz) _THROW_BAD_ALLOC;
201_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
Shoaib Meenai2d71db42016-11-16 22:18:10 +0000202_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p) _NOEXCEPT;
203_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, const std::nothrow_t&) _NOEXCEPT;
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000204#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Mehdi Amini228053d2017-05-04 17:08:54 +0000205_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 +0000206#endif
Howard Hinnanta37d3cf2013-08-12 18:38:34 +0000207
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000208#ifndef _LIBCPP_HAS_NO_LIBRARY_ALIGNED_ALLOCATION
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000209_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
210_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new(std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000211_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete(void* __p, std::align_val_t) _NOEXCEPT;
212_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 +0000213#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000214_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 +0000215#endif
216
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000217_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t) _THROW_BAD_ALLOC;
218_LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_OVERRIDABLE_FUNC_VIS void* operator new[](std::size_t __sz, std::align_val_t, const std::nothrow_t&) _NOEXCEPT _NOALIAS;
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000219_LIBCPP_OVERRIDABLE_FUNC_VIS void operator delete[](void* __p, std::align_val_t) _NOEXCEPT;
220_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 +0000221#ifndef _LIBCPP_HAS_NO_LIBRARY_SIZED_DEALLOCATION
Akira Hatanaka8c77d152017-06-30 18:50:23 +0000222_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 +0000223#endif
224#endif
225
Marshall Clowbe8b84d2017-12-04 23:03:42 +0000226_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY void* operator new (std::size_t, void* __p) _NOEXCEPT {return __p;}
227_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 +0000228inline _LIBCPP_INLINE_VISIBILITY void operator delete (void*, void*) _NOEXCEPT {}
229inline _LIBCPP_INLINE_VISIBILITY void operator delete[](void*, void*) _NOEXCEPT {}
Howard Hinnantc51e1022010-05-11 19:42:16 +0000230
Eric Fiselierff4c8a22018-10-11 00:17:24 +0000231#endif // !_LIBCPP_DEFER_NEW_TO_VCRUNTIME
Eric Fiselierec3a1672017-02-10 08:57:35 +0000232
Richard Smith1f1c1472014-06-04 19:54:15 +0000233_LIBCPP_BEGIN_NAMESPACE_STD
234
Eric Fiselier06548ab2018-03-22 04:42:56 +0000235_LIBCPP_CONSTEXPR inline _LIBCPP_INLINE_VISIBILITY bool __is_overaligned_for_new(size_t __align) _NOEXCEPT {
236#ifdef __STDCPP_DEFAULT_NEW_ALIGNMENT__
237 return __align > __STDCPP_DEFAULT_NEW_ALIGNMENT__;
238#else
239 return __align > alignment_of<max_align_t>::value;
240#endif
241}
242
243inline _LIBCPP_INLINE_VISIBILITY void *__libcpp_allocate(size_t __size, size_t __align) {
244#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
245 if (__is_overaligned_for_new(__align)) {
246 const align_val_t __align_val = static_cast<align_val_t>(__align);
Eric Fiselier6535ce22018-10-11 01:48:00 +0000247# ifdef _LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE
Eric Fiselier06548ab2018-03-22 04:42:56 +0000248 return ::operator new(__size, __align_val);
249# else
250 return __builtin_operator_new(__size, __align_val);
251# endif
252 }
253#else
254 ((void)__align);
255#endif
Richard Smith1f1c1472014-06-04 19:54:15 +0000256#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
257 return ::operator new(__size);
258#else
259 return __builtin_operator_new(__size);
260#endif
261}
262
Eric Fiselier01744a72018-10-24 22:44:01 +0000263struct _DeallocateCaller {
264 static inline _LIBCPP_INLINE_VISIBILITY
265 void __do_deallocate_handle_size_align(void *__ptr, size_t __size, size_t __align) {
266#if defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION)
267 ((void)__align);
268 return __do_deallocate_handle_size(__ptr, __size);
269#else
270 if (__is_overaligned_for_new(__align)) {
271 const align_val_t __align_val = static_cast<align_val_t>(__align);
272 return __do_deallocate_handle_size(__ptr, __size, __align_val);
273 } else {
274 return __do_deallocate_handle_size(__ptr, __size);
275 }
276#endif
Eric Fiselier06548ab2018-03-22 04:42:56 +0000277 }
Eric Fiselier01744a72018-10-24 22:44:01 +0000278
279 static inline _LIBCPP_INLINE_VISIBILITY
280 void __do_deallocate_handle_align(void *__ptr, size_t __align) {
281#if defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION)
282 ((void)__align);
283 return __do_call(__ptr);
Richard Smith1f1c1472014-06-04 19:54:15 +0000284#else
Eric Fiselier01744a72018-10-24 22:44:01 +0000285 if (__is_overaligned_for_new(__align)) {
286 const align_val_t __align_val = static_cast<align_val_t>(__align);
287 return __do_call(__ptr, __align_val);
288 } else {
289 return __do_call(__ptr);
290 }
Eric Fiselier06548ab2018-03-22 04:42:56 +0000291#endif
Eric Fiselier01744a72018-10-24 22:44:01 +0000292 }
293
294 private:
295 static inline void __do_deallocate_handle_size(void *__ptr, size_t __size) {
296#ifdef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
297 ((void)__size);
298 return __do_call(__ptr);
299#else
300 return __do_call(__ptr, __size);
301#endif
302 }
303
304#ifndef _LIBCPP_HAS_NO_ALIGNED_ALLOCATION
305 static inline void __do_deallocate_handle_size(void *__ptr, size_t __size, align_val_t __align) {
306#ifdef _LIBCPP_HAS_NO_SIZED_DEALLOCATION
307 ((void)__size);
308 return __do_call(__ptr, __align);
309#else
310 return __do_call(__ptr, __size, __align);
311#endif
312 }
313#endif
314
315private:
316 template <class _A1, class _A2>
317 static inline void __do_call(void *__ptr, _A1 __a1, _A2 __a2) {
318#if defined(_LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE) || \
319 defined(_LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE)
320 return ::operator delete(__ptr, __a1, __a2);
321#else
322 return __builtin_operator_delete(__ptr, __a1, __a2);
323#endif
324 }
325
326 template <class _A1>
327 static inline void __do_call(void *__ptr, _A1 __a1) {
328#if defined(_LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE) || \
329 defined(_LIBCPP_HAS_NO_BUILTIN_OVERLOADED_OPERATOR_NEW_DELETE)
330 return ::operator delete(__ptr, __a1);
331#else
332 return __builtin_operator_delete(__ptr, __a1);
333#endif
334 }
335
336 static inline void __do_call(void *__ptr) {
Eric Fiselier06548ab2018-03-22 04:42:56 +0000337#ifdef _LIBCPP_HAS_NO_BUILTIN_OPERATOR_NEW_DELETE
Eric Fiselier01744a72018-10-24 22:44:01 +0000338 return ::operator delete(__ptr);
Eric Fiselier06548ab2018-03-22 04:42:56 +0000339#else
Eric Fiselier01744a72018-10-24 22:44:01 +0000340 return __builtin_operator_delete(__ptr);
Richard Smith1f1c1472014-06-04 19:54:15 +0000341#endif
Eric Fiselier01744a72018-10-24 22:44:01 +0000342 }
343};
344
345inline _LIBCPP_INLINE_VISIBILITY void __libcpp_deallocate(void* __ptr, size_t __size, size_t __align) {
346 _DeallocateCaller::__do_deallocate_handle_size_align(__ptr, __size, __align);
347}
348
349inline _LIBCPP_INLINE_VISIBILITY void __libcpp_deallocate_unsized(void* __ptr, size_t __align) {
350 _DeallocateCaller::__do_deallocate_handle_align(__ptr, __align);
Richard Smith1f1c1472014-06-04 19:54:15 +0000351}
352
Marshall Clow8fea1612016-08-25 15:09:01 +0000353#ifdef _LIBCPP_BAD_ARRAY_LENGTH_DEFINED
Louis Dionne16fe2952018-07-11 23:14:33 +0000354_LIBCPP_NORETURN inline _LIBCPP_INLINE_VISIBILITY
Mehdi Amini228053d2017-05-04 17:08:54 +0000355#ifndef _LIBCPP_NO_EXCEPTIONS
356_LIBCPP_AVAILABILITY_BAD_ARRAY_LENGTH
357#endif
Marshall Clow8fea1612016-08-25 15:09:01 +0000358void __throw_bad_array_length()
359{
360#ifndef _LIBCPP_NO_EXCEPTIONS
361 throw bad_array_length();
362#else
Louis Dionne44bcff92018-08-03 22:36:53 +0000363 _VSTD::abort();
Marshall Clow8fea1612016-08-25 15:09:01 +0000364#endif
365}
366#endif
367
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000368template <class _Tp>
Louis Dionne44bcff92018-08-03 22:36:53 +0000369_LIBCPP_NODISCARD_AFTER_CXX17 inline
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000370_LIBCPP_CONSTEXPR _Tp* __launder(_Tp* __p) _NOEXCEPT
371{
372 static_assert (!(is_function<_Tp>::value), "can't launder functions" );
373 static_assert (!(is_same<void, typename remove_cv<_Tp>::type>::value), "can't launder cv-void" );
374#ifdef _LIBCPP_COMPILER_HAS_BUILTIN_LAUNDER
375 return __builtin_launder(__p);
376#else
377 return __p;
378#endif
379}
380
381
382#if _LIBCPP_STD_VER > 14
383template <class _Tp>
384_LIBCPP_NODISCARD_AFTER_CXX17 inline _LIBCPP_INLINE_VISIBILITY
385constexpr _Tp* launder(_Tp* __p) noexcept
386{
Marshall Clow6ac349c2017-11-23 01:25:03 +0000387 return _VSTD::__launder(__p);
Marshall Clowdf5a11f2017-11-22 19:49:03 +0000388}
389#endif
390
Richard Smith1f1c1472014-06-04 19:54:15 +0000391_LIBCPP_END_NAMESPACE_STD
392
Howard Hinnantc51e1022010-05-11 19:42:16 +0000393#endif // _LIBCPP_NEW