1// -*- C++ -*- 2//===-------------------------- memory ------------------------------------===// 3// 4// 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 7// 8//===----------------------------------------------------------------------===// 9 10#ifndef _LIBCPP_MEMORY 11#define _LIBCPP_MEMORY 12 13/* 14 memory synopsis 15 16namespace std 17{ 18 19struct allocator_arg_t { }; 20inline constexpr allocator_arg_t allocator_arg = allocator_arg_t(); 21 22template <class T, class Alloc> struct uses_allocator; 23 24template <class Ptr> 25struct pointer_traits 26{ 27 typedef Ptr pointer; 28 typedef <details> element_type; 29 typedef <details> difference_type; 30 31 template <class U> using rebind = <details>; 32 33 static pointer pointer_to(<details>); 34}; 35 36template <class T> 37struct pointer_traits<T*> 38{ 39 typedef T* pointer; 40 typedef T element_type; 41 typedef ptrdiff_t difference_type; 42 43 template <class U> using rebind = U*; 44 45 static pointer pointer_to(<details>) noexcept; // constexpr in C++20 46}; 47 48template <class T> constexpr T* to_address(T* p) noexcept; // C++20 49template <class Ptr> constexpr auto to_address(const Ptr& p) noexcept; // C++20 50 51template <class Alloc> 52struct allocator_traits 53{ 54 typedef Alloc allocator_type; 55 typedef typename allocator_type::value_type 56 value_type; 57 58 typedef Alloc::pointer | value_type* pointer; 59 typedef Alloc::const_pointer 60 | pointer_traits<pointer>::rebind<const value_type> 61 const_pointer; 62 typedef Alloc::void_pointer 63 | pointer_traits<pointer>::rebind<void> 64 void_pointer; 65 typedef Alloc::const_void_pointer 66 | pointer_traits<pointer>::rebind<const void> 67 const_void_pointer; 68 typedef Alloc::difference_type 69 | pointer_traits<pointer>::difference_type 70 difference_type; 71 typedef Alloc::size_type 72 | make_unsigned<difference_type>::type 73 size_type; 74 typedef Alloc::propagate_on_container_copy_assignment 75 | false_type propagate_on_container_copy_assignment; 76 typedef Alloc::propagate_on_container_move_assignment 77 | false_type propagate_on_container_move_assignment; 78 typedef Alloc::propagate_on_container_swap 79 | false_type propagate_on_container_swap; 80 typedef Alloc::is_always_equal 81 | is_empty is_always_equal; 82 83 template <class T> using rebind_alloc = Alloc::rebind<T>::other | Alloc<T, Args...>; 84 template <class T> using rebind_traits = allocator_traits<rebind_alloc<T>>; 85 86 static pointer allocate(allocator_type& a, size_type n); // constexpr and [[nodiscard]] in C++20 87 static pointer allocate(allocator_type& a, size_type n, const_void_pointer hint); // constexpr and [[nodiscard]] in C++20 88 89 static void deallocate(allocator_type& a, pointer p, size_type n) noexcept; // constexpr in C++20 90 91 template <class T, class... Args> 92 static void construct(allocator_type& a, T* p, Args&&... args); // constexpr in C++20 93 94 template <class T> 95 static void destroy(allocator_type& a, T* p); // constexpr in C++20 96 97 static size_type max_size(const allocator_type& a); // noexcept in C++14, constexpr in C++20 98 static allocator_type select_on_container_copy_construction(const allocator_type& a); // constexpr in C++20 99}; 100 101template <> 102class allocator<void> // deprecated in C++17, removed in C++20 103{ 104public: 105 typedef void* pointer; 106 typedef const void* const_pointer; 107 typedef void value_type; 108 109 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 110}; 111 112template <class T> 113class allocator 114{ 115public: 116 typedef size_t size_type; 117 typedef ptrdiff_t difference_type; 118 typedef T* pointer; // deprecated in C++17, removed in C++20 119 typedef const T* const_pointer; // deprecated in C++17, removed in C++20 120 typedef typename add_lvalue_reference<T>::type 121 reference; // deprecated in C++17, removed in C++20 122 typedef typename add_lvalue_reference<const T>::type 123 const_reference; // deprecated in C++17, removed in C++20 124 125 typedef T value_type; 126 127 template <class U> struct rebind {typedef allocator<U> other;}; // deprecated in C++17, removed in C++20 128 129 typedef true_type propagate_on_container_move_assignment; 130 typedef true_type is_always_equal; 131 132 constexpr allocator() noexcept; // constexpr in C++20 133 constexpr allocator(const allocator&) noexcept; // constexpr in C++20 134 template <class U> 135 constexpr allocator(const allocator<U>&) noexcept; // constexpr in C++20 136 ~allocator(); // constexpr in C++20 137 pointer address(reference x) const noexcept; // deprecated in C++17, removed in C++20 138 const_pointer address(const_reference x) const noexcept; // deprecated in C++17, removed in C++20 139 T* allocate(size_t n, const void* hint); // deprecated in C++17, removed in C++20 140 T* allocate(size_t n); // constexpr in C++20 141 void deallocate(T* p, size_t n) noexcept; // constexpr in C++20 142 size_type max_size() const noexcept; // deprecated in C++17, removed in C++20 143 template<class U, class... Args> 144 void construct(U* p, Args&&... args); // deprecated in C++17, removed in C++20 145 template <class U> 146 void destroy(U* p); // deprecated in C++17, removed in C++20 147}; 148 149template <class T, class U> 150bool operator==(const allocator<T>&, const allocator<U>&) noexcept; // constexpr in C++20 151 152template <class T, class U> 153bool operator!=(const allocator<T>&, const allocator<U>&) noexcept; // constexpr in C++20 154 155template <class OutputIterator, class T> 156class raw_storage_iterator 157 : public iterator<output_iterator_tag, 158 T, // purposefully not C++03 159 ptrdiff_t, // purposefully not C++03 160 T*, // purposefully not C++03 161 raw_storage_iterator&> // purposefully not C++03 162{ 163public: 164 explicit raw_storage_iterator(OutputIterator x); 165 raw_storage_iterator& operator*(); 166 raw_storage_iterator& operator=(const T& element); 167 raw_storage_iterator& operator++(); 168 raw_storage_iterator operator++(int); 169}; 170 171template <class T> pair<T*,ptrdiff_t> get_temporary_buffer(ptrdiff_t n) noexcept; 172template <class T> void return_temporary_buffer(T* p) noexcept; 173 174template <class T> T* addressof(T& r) noexcept; 175template <class T> T* addressof(const T&& r) noexcept = delete; 176 177template <class InputIterator, class ForwardIterator> 178ForwardIterator 179uninitialized_copy(InputIterator first, InputIterator last, ForwardIterator result); 180 181template <class InputIterator, class Size, class ForwardIterator> 182ForwardIterator 183uninitialized_copy_n(InputIterator first, Size n, ForwardIterator result); 184 185template <class ForwardIterator, class T> 186void uninitialized_fill(ForwardIterator first, ForwardIterator last, const T& x); 187 188template <class ForwardIterator, class Size, class T> 189ForwardIterator 190uninitialized_fill_n(ForwardIterator first, Size n, const T& x); 191 192template <class T, class ...Args> 193constexpr T* construct_at(T* location, Args&& ...args); // since C++20 194 195template <class T> 196void destroy_at(T* location); // constexpr in C++20 197 198template <class ForwardIterator> 199void destroy(ForwardIterator first, ForwardIterator last); // constexpr in C++20 200 201template <class ForwardIterator, class Size> 202ForwardIterator destroy_n(ForwardIterator first, Size n); // constexpr in C++20 203 204template <class InputIterator, class ForwardIterator> 205 ForwardIterator uninitialized_move(InputIterator first, InputIterator last, ForwardIterator result); 206 207template <class InputIterator, class Size, class ForwardIterator> 208 pair<InputIterator,ForwardIterator> uninitialized_move_n(InputIterator first, Size n, ForwardIterator result); 209 210template <class ForwardIterator> 211 void uninitialized_value_construct(ForwardIterator first, ForwardIterator last); 212 213template <class ForwardIterator, class Size> 214 ForwardIterator uninitialized_value_construct_n(ForwardIterator first, Size n); 215 216template <class ForwardIterator> 217 void uninitialized_default_construct(ForwardIterator first, ForwardIterator last); 218 219template <class ForwardIterator, class Size> 220 ForwardIterator uninitialized_default_construct_n(ForwardIterator first, Size n); 221 222template <class Y> struct auto_ptr_ref {}; // deprecated in C++11, removed in C++17 223 224template<class X> 225class auto_ptr // deprecated in C++11, removed in C++17 226{ 227public: 228 typedef X element_type; 229 230 explicit auto_ptr(X* p =0) throw(); 231 auto_ptr(auto_ptr&) throw(); 232 template<class Y> auto_ptr(auto_ptr<Y>&) throw(); 233 auto_ptr& operator=(auto_ptr&) throw(); 234 template<class Y> auto_ptr& operator=(auto_ptr<Y>&) throw(); 235 auto_ptr& operator=(auto_ptr_ref<X> r) throw(); 236 ~auto_ptr() throw(); 237 238 typename add_lvalue_reference<X>::type operator*() const throw(); 239 X* operator->() const throw(); 240 X* get() const throw(); 241 X* release() throw(); 242 void reset(X* p =0) throw(); 243 244 auto_ptr(auto_ptr_ref<X>) throw(); 245 template<class Y> operator auto_ptr_ref<Y>() throw(); 246 template<class Y> operator auto_ptr<Y>() throw(); 247}; 248 249template <class T> 250struct default_delete 251{ 252 constexpr default_delete() noexcept = default; 253 template <class U> default_delete(const default_delete<U>&) noexcept; 254 255 void operator()(T*) const noexcept; 256}; 257 258template <class T> 259struct default_delete<T[]> 260{ 261 constexpr default_delete() noexcept = default; 262 void operator()(T*) const noexcept; 263 template <class U> void operator()(U*) const = delete; 264}; 265 266template <class T, class D = default_delete<T>> 267class unique_ptr 268{ 269public: 270 typedef see below pointer; 271 typedef T element_type; 272 typedef D deleter_type; 273 274 // constructors 275 constexpr unique_ptr() noexcept; 276 explicit unique_ptr(pointer p) noexcept; 277 unique_ptr(pointer p, see below d1) noexcept; 278 unique_ptr(pointer p, see below d2) noexcept; 279 unique_ptr(unique_ptr&& u) noexcept; 280 unique_ptr(nullptr_t) noexcept : unique_ptr() { } 281 template <class U, class E> 282 unique_ptr(unique_ptr<U, E>&& u) noexcept; 283 template <class U> 284 unique_ptr(auto_ptr<U>&& u) noexcept; // removed in C++17 285 286 // destructor 287 ~unique_ptr(); 288 289 // assignment 290 unique_ptr& operator=(unique_ptr&& u) noexcept; 291 template <class U, class E> unique_ptr& operator=(unique_ptr<U, E>&& u) noexcept; 292 unique_ptr& operator=(nullptr_t) noexcept; 293 294 // observers 295 typename add_lvalue_reference<T>::type operator*() const; 296 pointer operator->() const noexcept; 297 pointer get() const noexcept; 298 deleter_type& get_deleter() noexcept; 299 const deleter_type& get_deleter() const noexcept; 300 explicit operator bool() const noexcept; 301 302 // modifiers 303 pointer release() noexcept; 304 void reset(pointer p = pointer()) noexcept; 305 void swap(unique_ptr& u) noexcept; 306}; 307 308template <class T, class D> 309class unique_ptr<T[], D> 310{ 311public: 312 typedef implementation-defined pointer; 313 typedef T element_type; 314 typedef D deleter_type; 315 316 // constructors 317 constexpr unique_ptr() noexcept; 318 explicit unique_ptr(pointer p) noexcept; 319 unique_ptr(pointer p, see below d) noexcept; 320 unique_ptr(pointer p, see below d) noexcept; 321 unique_ptr(unique_ptr&& u) noexcept; 322 unique_ptr(nullptr_t) noexcept : unique_ptr() { } 323 324 // destructor 325 ~unique_ptr(); 326 327 // assignment 328 unique_ptr& operator=(unique_ptr&& u) noexcept; 329 unique_ptr& operator=(nullptr_t) noexcept; 330 331 // observers 332 T& operator[](size_t i) const; 333 pointer get() const noexcept; 334 deleter_type& get_deleter() noexcept; 335 const deleter_type& get_deleter() const noexcept; 336 explicit operator bool() const noexcept; 337 338 // modifiers 339 pointer release() noexcept; 340 void reset(pointer p = pointer()) noexcept; 341 void reset(nullptr_t) noexcept; 342 template <class U> void reset(U) = delete; 343 void swap(unique_ptr& u) noexcept; 344}; 345 346template <class T, class D> 347 void swap(unique_ptr<T, D>& x, unique_ptr<T, D>& y) noexcept; 348 349template <class T1, class D1, class T2, class D2> 350 bool operator==(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 351template <class T1, class D1, class T2, class D2> 352 bool operator!=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 353template <class T1, class D1, class T2, class D2> 354 bool operator<(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 355template <class T1, class D1, class T2, class D2> 356 bool operator<=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 357template <class T1, class D1, class T2, class D2> 358 bool operator>(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 359template <class T1, class D1, class T2, class D2> 360 bool operator>=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 361 362template <class T, class D> 363 bool operator==(const unique_ptr<T, D>& x, nullptr_t) noexcept; 364template <class T, class D> 365 bool operator==(nullptr_t, const unique_ptr<T, D>& y) noexcept; 366template <class T, class D> 367 bool operator!=(const unique_ptr<T, D>& x, nullptr_t) noexcept; 368template <class T, class D> 369 bool operator!=(nullptr_t, const unique_ptr<T, D>& y) noexcept; 370 371template <class T, class D> 372 bool operator<(const unique_ptr<T, D>& x, nullptr_t); 373template <class T, class D> 374 bool operator<(nullptr_t, const unique_ptr<T, D>& y); 375template <class T, class D> 376 bool operator<=(const unique_ptr<T, D>& x, nullptr_t); 377template <class T, class D> 378 bool operator<=(nullptr_t, const unique_ptr<T, D>& y); 379template <class T, class D> 380 bool operator>(const unique_ptr<T, D>& x, nullptr_t); 381template <class T, class D> 382 bool operator>(nullptr_t, const unique_ptr<T, D>& y); 383template <class T, class D> 384 bool operator>=(const unique_ptr<T, D>& x, nullptr_t); 385template <class T, class D> 386 bool operator>=(nullptr_t, const unique_ptr<T, D>& y); 387 388class bad_weak_ptr 389 : public std::exception 390{ 391 bad_weak_ptr() noexcept; 392}; 393 394template<class T, class... Args> unique_ptr<T> make_unique(Args&&... args); // C++14 395template<class T> unique_ptr<T> make_unique(size_t n); // C++14 396template<class T, class... Args> unspecified make_unique(Args&&...) = delete; // C++14, T == U[N] 397 398template<class E, class T, class Y, class D> 399 basic_ostream<E, T>& operator<< (basic_ostream<E, T>& os, unique_ptr<Y, D> const& p); 400 401template<class T> 402class shared_ptr 403{ 404public: 405 typedef T element_type; 406 typedef weak_ptr<T> weak_type; // C++17 407 408 // constructors: 409 constexpr shared_ptr() noexcept; 410 template<class Y> explicit shared_ptr(Y* p); 411 template<class Y, class D> shared_ptr(Y* p, D d); 412 template<class Y, class D, class A> shared_ptr(Y* p, D d, A a); 413 template <class D> shared_ptr(nullptr_t p, D d); 414 template <class D, class A> shared_ptr(nullptr_t p, D d, A a); 415 template<class Y> shared_ptr(const shared_ptr<Y>& r, T *p) noexcept; 416 shared_ptr(const shared_ptr& r) noexcept; 417 template<class Y> shared_ptr(const shared_ptr<Y>& r) noexcept; 418 shared_ptr(shared_ptr&& r) noexcept; 419 template<class Y> shared_ptr(shared_ptr<Y>&& r) noexcept; 420 template<class Y> explicit shared_ptr(const weak_ptr<Y>& r); 421 template<class Y> shared_ptr(auto_ptr<Y>&& r); // removed in C++17 422 template <class Y, class D> shared_ptr(unique_ptr<Y, D>&& r); 423 shared_ptr(nullptr_t) : shared_ptr() { } 424 425 // destructor: 426 ~shared_ptr(); 427 428 // assignment: 429 shared_ptr& operator=(const shared_ptr& r) noexcept; 430 template<class Y> shared_ptr& operator=(const shared_ptr<Y>& r) noexcept; 431 shared_ptr& operator=(shared_ptr&& r) noexcept; 432 template<class Y> shared_ptr& operator=(shared_ptr<Y>&& r); 433 template<class Y> shared_ptr& operator=(auto_ptr<Y>&& r); // removed in C++17 434 template <class Y, class D> shared_ptr& operator=(unique_ptr<Y, D>&& r); 435 436 // modifiers: 437 void swap(shared_ptr& r) noexcept; 438 void reset() noexcept; 439 template<class Y> void reset(Y* p); 440 template<class Y, class D> void reset(Y* p, D d); 441 template<class Y, class D, class A> void reset(Y* p, D d, A a); 442 443 // observers: 444 T* get() const noexcept; 445 T& operator*() const noexcept; 446 T* operator->() const noexcept; 447 long use_count() const noexcept; 448 bool unique() const noexcept; 449 explicit operator bool() const noexcept; 450 template<class U> bool owner_before(shared_ptr<U> const& b) const noexcept; 451 template<class U> bool owner_before(weak_ptr<U> const& b) const noexcept; 452}; 453 454template<class T> 455shared_ptr(weak_ptr<T>) -> shared_ptr<T>; 456template<class T, class D> 457shared_ptr(unique_ptr<T, D>) -> shared_ptr<T>; 458 459// shared_ptr comparisons: 460template<class T, class U> 461 bool operator==(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 462template<class T, class U> 463 bool operator!=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 464template<class T, class U> 465 bool operator<(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 466template<class T, class U> 467 bool operator>(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 468template<class T, class U> 469 bool operator<=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 470template<class T, class U> 471 bool operator>=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 472 473template <class T> 474 bool operator==(const shared_ptr<T>& x, nullptr_t) noexcept; 475template <class T> 476 bool operator==(nullptr_t, const shared_ptr<T>& y) noexcept; 477template <class T> 478 bool operator!=(const shared_ptr<T>& x, nullptr_t) noexcept; 479template <class T> 480 bool operator!=(nullptr_t, const shared_ptr<T>& y) noexcept; 481template <class T> 482 bool operator<(const shared_ptr<T>& x, nullptr_t) noexcept; 483template <class T> 484bool operator<(nullptr_t, const shared_ptr<T>& y) noexcept; 485template <class T> 486 bool operator<=(const shared_ptr<T>& x, nullptr_t) noexcept; 487template <class T> 488 bool operator<=(nullptr_t, const shared_ptr<T>& y) noexcept; 489template <class T> 490 bool operator>(const shared_ptr<T>& x, nullptr_t) noexcept; 491template <class T> 492 bool operator>(nullptr_t, const shared_ptr<T>& y) noexcept; 493template <class T> 494 bool operator>=(const shared_ptr<T>& x, nullptr_t) noexcept; 495template <class T> 496 bool operator>=(nullptr_t, const shared_ptr<T>& y) noexcept; 497 498// shared_ptr specialized algorithms: 499template<class T> void swap(shared_ptr<T>& a, shared_ptr<T>& b) noexcept; 500 501// shared_ptr casts: 502template<class T, class U> 503 shared_ptr<T> static_pointer_cast(shared_ptr<U> const& r) noexcept; 504template<class T, class U> 505 shared_ptr<T> dynamic_pointer_cast(shared_ptr<U> const& r) noexcept; 506template<class T, class U> 507 shared_ptr<T> const_pointer_cast(shared_ptr<U> const& r) noexcept; 508 509// shared_ptr I/O: 510template<class E, class T, class Y> 511 basic_ostream<E, T>& operator<< (basic_ostream<E, T>& os, shared_ptr<Y> const& p); 512 513// shared_ptr get_deleter: 514template<class D, class T> D* get_deleter(shared_ptr<T> const& p) noexcept; 515 516template<class T, class... Args> 517 shared_ptr<T> make_shared(Args&&... args); 518template<class T, class A, class... Args> 519 shared_ptr<T> allocate_shared(const A& a, Args&&... args); 520 521template<class T> 522class weak_ptr 523{ 524public: 525 typedef T element_type; 526 527 // constructors 528 constexpr weak_ptr() noexcept; 529 template<class Y> weak_ptr(shared_ptr<Y> const& r) noexcept; 530 weak_ptr(weak_ptr const& r) noexcept; 531 template<class Y> weak_ptr(weak_ptr<Y> const& r) noexcept; 532 weak_ptr(weak_ptr&& r) noexcept; // C++14 533 template<class Y> weak_ptr(weak_ptr<Y>&& r) noexcept; // C++14 534 535 // destructor 536 ~weak_ptr(); 537 538 // assignment 539 weak_ptr& operator=(weak_ptr const& r) noexcept; 540 template<class Y> weak_ptr& operator=(weak_ptr<Y> const& r) noexcept; 541 template<class Y> weak_ptr& operator=(shared_ptr<Y> const& r) noexcept; 542 weak_ptr& operator=(weak_ptr&& r) noexcept; // C++14 543 template<class Y> weak_ptr& operator=(weak_ptr<Y>&& r) noexcept; // C++14 544 545 // modifiers 546 void swap(weak_ptr& r) noexcept; 547 void reset() noexcept; 548 549 // observers 550 long use_count() const noexcept; 551 bool expired() const noexcept; 552 shared_ptr<T> lock() const noexcept; 553 template<class U> bool owner_before(shared_ptr<U> const& b) const noexcept; 554 template<class U> bool owner_before(weak_ptr<U> const& b) const noexcept; 555}; 556 557template<class T> 558weak_ptr(shared_ptr<T>) -> weak_ptr<T>; 559 560// weak_ptr specialized algorithms: 561template<class T> void swap(weak_ptr<T>& a, weak_ptr<T>& b) noexcept; 562 563// class owner_less: 564template<class T> struct owner_less; 565 566template<class T> 567struct owner_less<shared_ptr<T> > 568 : binary_function<shared_ptr<T>, shared_ptr<T>, bool> 569{ 570 typedef bool result_type; 571 bool operator()(shared_ptr<T> const&, shared_ptr<T> const&) const noexcept; 572 bool operator()(shared_ptr<T> const&, weak_ptr<T> const&) const noexcept; 573 bool operator()(weak_ptr<T> const&, shared_ptr<T> const&) const noexcept; 574}; 575 576template<class T> 577struct owner_less<weak_ptr<T> > 578 : binary_function<weak_ptr<T>, weak_ptr<T>, bool> 579{ 580 typedef bool result_type; 581 bool operator()(weak_ptr<T> const&, weak_ptr<T> const&) const noexcept; 582 bool operator()(shared_ptr<T> const&, weak_ptr<T> const&) const noexcept; 583 bool operator()(weak_ptr<T> const&, shared_ptr<T> const&) const noexcept; 584}; 585 586template <> // Added in C++14 587struct owner_less<void> 588{ 589 template <class _Tp, class _Up> 590 bool operator()( shared_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const noexcept; 591 template <class _Tp, class _Up> 592 bool operator()( shared_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const noexcept; 593 template <class _Tp, class _Up> 594 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const noexcept; 595 template <class _Tp, class _Up> 596 bool operator()( weak_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const noexcept; 597 598 typedef void is_transparent; 599}; 600 601template<class T> 602class enable_shared_from_this 603{ 604protected: 605 constexpr enable_shared_from_this() noexcept; 606 enable_shared_from_this(enable_shared_from_this const&) noexcept; 607 enable_shared_from_this& operator=(enable_shared_from_this const&) noexcept; 608 ~enable_shared_from_this(); 609public: 610 shared_ptr<T> shared_from_this(); 611 shared_ptr<T const> shared_from_this() const; 612}; 613 614template<class T> 615 bool atomic_is_lock_free(const shared_ptr<T>* p); 616template<class T> 617 shared_ptr<T> atomic_load(const shared_ptr<T>* p); 618template<class T> 619 shared_ptr<T> atomic_load_explicit(const shared_ptr<T>* p, memory_order mo); 620template<class T> 621 void atomic_store(shared_ptr<T>* p, shared_ptr<T> r); 622template<class T> 623 void atomic_store_explicit(shared_ptr<T>* p, shared_ptr<T> r, memory_order mo); 624template<class T> 625 shared_ptr<T> atomic_exchange(shared_ptr<T>* p, shared_ptr<T> r); 626template<class T> 627 shared_ptr<T> 628 atomic_exchange_explicit(shared_ptr<T>* p, shared_ptr<T> r, memory_order mo); 629template<class T> 630 bool 631 atomic_compare_exchange_weak(shared_ptr<T>* p, shared_ptr<T>* v, shared_ptr<T> w); 632template<class T> 633 bool 634 atomic_compare_exchange_strong( shared_ptr<T>* p, shared_ptr<T>* v, shared_ptr<T> w); 635template<class T> 636 bool 637 atomic_compare_exchange_weak_explicit(shared_ptr<T>* p, shared_ptr<T>* v, 638 shared_ptr<T> w, memory_order success, 639 memory_order failure); 640template<class T> 641 bool 642 atomic_compare_exchange_strong_explicit(shared_ptr<T>* p, shared_ptr<T>* v, 643 shared_ptr<T> w, memory_order success, 644 memory_order failure); 645// Hash support 646template <class T> struct hash; 647template <class T, class D> struct hash<unique_ptr<T, D> >; 648template <class T> struct hash<shared_ptr<T> >; 649 650template <class T, class Alloc> 651 inline constexpr bool uses_allocator_v = uses_allocator<T, Alloc>::value; 652 653// Pointer safety 654enum class pointer_safety { relaxed, preferred, strict }; 655void declare_reachable(void *p); 656template <class T> T *undeclare_reachable(T *p); 657void declare_no_pointers(char *p, size_t n); 658void undeclare_no_pointers(char *p, size_t n); 659pointer_safety get_pointer_safety() noexcept; 660 661void* align(size_t alignment, size_t size, void*& ptr, size_t& space); 662 663} // std 664 665*/ 666 667#include <__config> 668#include <__availability> 669#include <type_traits> 670#include <typeinfo> 671#include <cstddef> 672#include <cstdint> 673#include <new> 674#include <utility> 675#include <limits> 676#include <iterator> 677#include <__functional_base> 678#include <iosfwd> 679#include <tuple> 680#include <stdexcept> 681#include <cstring> 682#include <__memory/allocator_traits.h> 683#include <__memory/base.h> 684#include <__memory/pointer_traits.h> 685#include <__memory/utilities.h> 686#if !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 687# include <atomic> 688#endif 689#include <version> 690 691#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 692#pragma GCC system_header 693#endif 694 695_LIBCPP_PUSH_MACROS 696#include <__undef_macros> 697 698 699_LIBCPP_BEGIN_NAMESPACE_STD 700 701template <class _ValueType> 702inline _LIBCPP_INLINE_VISIBILITY 703_ValueType __libcpp_relaxed_load(_ValueType const* __value) { 704#if !defined(_LIBCPP_HAS_NO_THREADS) && \ 705 defined(__ATOMIC_RELAXED) && \ 706 (__has_builtin(__atomic_load_n) || defined(_LIBCPP_COMPILER_GCC)) 707 return __atomic_load_n(__value, __ATOMIC_RELAXED); 708#else 709 return *__value; 710#endif 711} 712 713template <class _ValueType> 714inline _LIBCPP_INLINE_VISIBILITY 715_ValueType __libcpp_acquire_load(_ValueType const* __value) { 716#if !defined(_LIBCPP_HAS_NO_THREADS) && \ 717 defined(__ATOMIC_ACQUIRE) && \ 718 (__has_builtin(__atomic_load_n) || defined(_LIBCPP_COMPILER_GCC)) 719 return __atomic_load_n(__value, __ATOMIC_ACQUIRE); 720#else 721 return *__value; 722#endif 723} 724 725template <class _Tp> class allocator; 726 727#if _LIBCPP_STD_VER <= 17 || defined(_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_MEMBERS) 728template <> 729class _LIBCPP_TEMPLATE_VIS _LIBCPP_DEPRECATED_IN_CXX17 allocator<void> 730{ 731public: 732 typedef void* pointer; 733 typedef const void* const_pointer; 734 typedef void value_type; 735 736 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 737}; 738 739template <> 740class _LIBCPP_TEMPLATE_VIS _LIBCPP_DEPRECATED_IN_CXX17 allocator<const void> 741{ 742public: 743 typedef const void* pointer; 744 typedef const void* const_pointer; 745 typedef const void value_type; 746 747 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 748}; 749#endif 750 751// allocator 752 753template <class _Tp> 754class _LIBCPP_TEMPLATE_VIS allocator 755{ 756public: 757 typedef size_t size_type; 758 typedef ptrdiff_t difference_type; 759 typedef _Tp value_type; 760 typedef true_type propagate_on_container_move_assignment; 761 typedef true_type is_always_equal; 762 763 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 764 allocator() _NOEXCEPT { } 765 766 template <class _Up> 767 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 768 allocator(const allocator<_Up>&) _NOEXCEPT { } 769 770 _LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 771 _Tp* allocate(size_t __n) { 772 if (__n > allocator_traits<allocator>::max_size(*this)) 773 __throw_length_error("allocator<T>::allocate(size_t n)" 774 " 'n' exceeds maximum supported size"); 775 if (__libcpp_is_constant_evaluated()) { 776 return static_cast<_Tp*>(::operator new(__n * sizeof(_Tp))); 777 } else { 778 return static_cast<_Tp*>(_VSTD::__libcpp_allocate(__n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp))); 779 } 780 } 781 782 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 783 void deallocate(_Tp* __p, size_t __n) _NOEXCEPT { 784 if (__libcpp_is_constant_evaluated()) { 785 ::operator delete(__p); 786 } else { 787 _VSTD::__libcpp_deallocate((void*)__p, __n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp)); 788 } 789 } 790 791 // C++20 Removed members 792#if _LIBCPP_STD_VER <= 17 || defined(_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_MEMBERS) 793 _LIBCPP_DEPRECATED_IN_CXX17 typedef _Tp* pointer; 794 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp* const_pointer; 795 _LIBCPP_DEPRECATED_IN_CXX17 typedef _Tp& reference; 796 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp& const_reference; 797 798 template <class _Up> 799 struct _LIBCPP_DEPRECATED_IN_CXX17 rebind { 800 typedef allocator<_Up> other; 801 }; 802 803 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 804 pointer address(reference __x) const _NOEXCEPT { 805 return _VSTD::addressof(__x); 806 } 807 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 808 const_pointer address(const_reference __x) const _NOEXCEPT { 809 return _VSTD::addressof(__x); 810 } 811 812 _LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_INLINE_VISIBILITY _LIBCPP_DEPRECATED_IN_CXX17 813 _Tp* allocate(size_t __n, const void*) { 814 return allocate(__n); 815 } 816 817 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY size_type max_size() const _NOEXCEPT { 818 return size_type(~0) / sizeof(_Tp); 819 } 820 821 template <class _Up, class... _Args> 822 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 823 void construct(_Up* __p, _Args&&... __args) { 824 ::new ((void*)__p) _Up(_VSTD::forward<_Args>(__args)...); 825 } 826 827 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 828 void destroy(pointer __p) { 829 __p->~_Tp(); 830 } 831#endif 832}; 833 834template <class _Tp> 835class _LIBCPP_TEMPLATE_VIS allocator<const _Tp> 836{ 837public: 838 typedef size_t size_type; 839 typedef ptrdiff_t difference_type; 840 typedef const _Tp value_type; 841 typedef true_type propagate_on_container_move_assignment; 842 typedef true_type is_always_equal; 843 844 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 845 allocator() _NOEXCEPT { } 846 847 template <class _Up> 848 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 849 allocator(const allocator<_Up>&) _NOEXCEPT { } 850 851 _LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 852 const _Tp* allocate(size_t __n) { 853 if (__n > allocator_traits<allocator>::max_size(*this)) 854 __throw_length_error("allocator<const T>::allocate(size_t n)" 855 " 'n' exceeds maximum supported size"); 856 if (__libcpp_is_constant_evaluated()) { 857 return static_cast<const _Tp*>(::operator new(__n * sizeof(_Tp))); 858 } else { 859 return static_cast<const _Tp*>(_VSTD::__libcpp_allocate(__n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp))); 860 } 861 } 862 863 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 864 void deallocate(const _Tp* __p, size_t __n) { 865 if (__libcpp_is_constant_evaluated()) { 866 ::operator delete(const_cast<_Tp*>(__p)); 867 } else { 868 _VSTD::__libcpp_deallocate((void*) const_cast<_Tp *>(__p), __n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp)); 869 } 870 } 871 872 // C++20 Removed members 873#if _LIBCPP_STD_VER <= 17 || defined(_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_MEMBERS) 874 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp* pointer; 875 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp* const_pointer; 876 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp& reference; 877 _LIBCPP_DEPRECATED_IN_CXX17 typedef const _Tp& const_reference; 878 879 template <class _Up> 880 struct _LIBCPP_DEPRECATED_IN_CXX17 rebind { 881 typedef allocator<_Up> other; 882 }; 883 884 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 885 const_pointer address(const_reference __x) const _NOEXCEPT { 886 return _VSTD::addressof(__x); 887 } 888 889 _LIBCPP_NODISCARD_AFTER_CXX17 _LIBCPP_INLINE_VISIBILITY _LIBCPP_DEPRECATED_IN_CXX17 890 const _Tp* allocate(size_t __n, const void*) { 891 return allocate(__n); 892 } 893 894 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY size_type max_size() const _NOEXCEPT { 895 return size_type(~0) / sizeof(_Tp); 896 } 897 898 template <class _Up, class... _Args> 899 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 900 void construct(_Up* __p, _Args&&... __args) { 901 ::new ((void*)__p) _Up(_VSTD::forward<_Args>(__args)...); 902 } 903 904 _LIBCPP_DEPRECATED_IN_CXX17 _LIBCPP_INLINE_VISIBILITY 905 void destroy(pointer __p) { 906 __p->~_Tp(); 907 } 908#endif 909}; 910 911template <class _Tp, class _Up> 912inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 913bool operator==(const allocator<_Tp>&, const allocator<_Up>&) _NOEXCEPT {return true;} 914 915template <class _Tp, class _Up> 916inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 917bool operator!=(const allocator<_Tp>&, const allocator<_Up>&) _NOEXCEPT {return false;} 918 919template <class _Alloc, class _Ptr> 920_LIBCPP_INLINE_VISIBILITY 921void __construct_forward_with_exception_guarantees(_Alloc& __a, _Ptr __begin1, _Ptr __end1, _Ptr& __begin2) { 922 static_assert(__is_cpp17_move_insertable<_Alloc>::value, 923 "The specified type does not meet the requirements of Cpp17MoveInsertable"); 924 typedef allocator_traits<_Alloc> _Traits; 925 for (; __begin1 != __end1; ++__begin1, (void)++__begin2) { 926 _Traits::construct(__a, _VSTD::__to_address(__begin2), 927#ifdef _LIBCPP_NO_EXCEPTIONS 928 _VSTD::move(*__begin1) 929#else 930 _VSTD::move_if_noexcept(*__begin1) 931#endif 932 ); 933 } 934} 935 936template <class _Alloc, class _Tp, typename enable_if< 937 (__is_default_allocator<_Alloc>::value || !__has_construct<_Alloc, _Tp*, _Tp>::value) && 938 is_trivially_move_constructible<_Tp>::value 939>::type> 940_LIBCPP_INLINE_VISIBILITY 941void __construct_forward_with_exception_guarantees(_Alloc&, _Tp* __begin1, _Tp* __end1, _Tp*& __begin2) { 942 ptrdiff_t _Np = __end1 - __begin1; 943 if (_Np > 0) { 944 _VSTD::memcpy(__begin2, __begin1, _Np * sizeof(_Tp)); 945 __begin2 += _Np; 946 } 947} 948 949template <class _Alloc, class _Iter, class _Ptr> 950_LIBCPP_INLINE_VISIBILITY 951void __construct_range_forward(_Alloc& __a, _Iter __begin1, _Iter __end1, _Ptr& __begin2) { 952 typedef allocator_traits<_Alloc> _Traits; 953 for (; __begin1 != __end1; ++__begin1, (void) ++__begin2) { 954 _Traits::construct(__a, _VSTD::__to_address(__begin2), *__begin1); 955 } 956} 957 958template <class _Alloc, class _Source, class _Dest, 959 class _RawSource = typename remove_const<_Source>::type, 960 class _RawDest = typename remove_const<_Dest>::type, 961 class = 962 typename enable_if< 963 is_trivially_copy_constructible<_Dest>::value && 964 is_same<_RawSource, _RawDest>::value && 965 (__is_default_allocator<_Alloc>::value || !__has_construct<_Alloc, _Dest*, _Source&>::value) 966 >::type> 967_LIBCPP_INLINE_VISIBILITY 968void __construct_range_forward(_Alloc&, _Source* __begin1, _Source* __end1, _Dest*& __begin2) { 969 ptrdiff_t _Np = __end1 - __begin1; 970 if (_Np > 0) { 971 _VSTD::memcpy(const_cast<_RawDest*>(__begin2), __begin1, _Np * sizeof(_Dest)); 972 __begin2 += _Np; 973 } 974} 975 976template <class _Alloc, class _Ptr> 977_LIBCPP_INLINE_VISIBILITY 978void __construct_backward_with_exception_guarantees(_Alloc& __a, _Ptr __begin1, _Ptr __end1, _Ptr& __end2) { 979 static_assert(__is_cpp17_move_insertable<_Alloc>::value, 980 "The specified type does not meet the requirements of Cpp17MoveInsertable"); 981 typedef allocator_traits<_Alloc> _Traits; 982 while (__end1 != __begin1) { 983 _Traits::construct(__a, _VSTD::__to_address(__end2 - 1), 984#ifdef _LIBCPP_NO_EXCEPTIONS 985 _VSTD::move(*--__end1) 986#else 987 _VSTD::move_if_noexcept(*--__end1) 988#endif 989 ); 990 --__end2; 991 } 992} 993 994template <class _Alloc, class _Tp, class = typename enable_if< 995 (__is_default_allocator<_Alloc>::value || !__has_construct<_Alloc, _Tp*, _Tp>::value) && 996 is_trivially_move_constructible<_Tp>::value 997>::type> 998_LIBCPP_INLINE_VISIBILITY 999void __construct_backward_with_exception_guarantees(_Alloc&, _Tp* __begin1, _Tp* __end1, _Tp*& __end2) { 1000 ptrdiff_t _Np = __end1 - __begin1; 1001 __end2 -= _Np; 1002 if (_Np > 0) 1003 _VSTD::memcpy(__end2, __begin1, _Np * sizeof(_Tp)); 1004} 1005 1006template <class _OutputIterator, class _Tp> 1007class _LIBCPP_TEMPLATE_VIS raw_storage_iterator 1008 : public iterator<output_iterator_tag, 1009 _Tp, // purposefully not C++03 1010 ptrdiff_t, // purposefully not C++03 1011 _Tp*, // purposefully not C++03 1012 raw_storage_iterator<_OutputIterator, _Tp>&> // purposefully not C++03 1013{ 1014private: 1015 _OutputIterator __x_; 1016public: 1017 _LIBCPP_INLINE_VISIBILITY explicit raw_storage_iterator(_OutputIterator __x) : __x_(__x) {} 1018 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator*() {return *this;} 1019 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator=(const _Tp& __element) 1020 {::new ((void*)_VSTD::addressof(*__x_)) _Tp(__element); return *this;} 1021#if _LIBCPP_STD_VER >= 14 1022 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator=(_Tp&& __element) 1023 {::new ((void*)_VSTD::addressof(*__x_)) _Tp(_VSTD::move(__element)); return *this;} 1024#endif 1025 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator++() {++__x_; return *this;} 1026 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator operator++(int) 1027 {raw_storage_iterator __t(*this); ++__x_; return __t;} 1028#if _LIBCPP_STD_VER >= 14 1029 _LIBCPP_INLINE_VISIBILITY _OutputIterator base() const { return __x_; } 1030#endif 1031}; 1032 1033template <class _Tp> 1034_LIBCPP_NODISCARD_EXT _LIBCPP_NO_CFI 1035pair<_Tp*, ptrdiff_t> 1036get_temporary_buffer(ptrdiff_t __n) _NOEXCEPT 1037{ 1038 pair<_Tp*, ptrdiff_t> __r(0, 0); 1039 const ptrdiff_t __m = (~ptrdiff_t(0) ^ 1040 ptrdiff_t(ptrdiff_t(1) << (sizeof(ptrdiff_t) * __CHAR_BIT__ - 1))) 1041 / sizeof(_Tp); 1042 if (__n > __m) 1043 __n = __m; 1044 while (__n > 0) 1045 { 1046#if !defined(_LIBCPP_HAS_NO_ALIGNED_ALLOCATION) 1047 if (__is_overaligned_for_new(_LIBCPP_ALIGNOF(_Tp))) 1048 { 1049 align_val_t __al = 1050 align_val_t(alignment_of<_Tp>::value); 1051 __r.first = static_cast<_Tp*>(::operator new( 1052 __n * sizeof(_Tp), __al, nothrow)); 1053 } else { 1054 __r.first = static_cast<_Tp*>(::operator new( 1055 __n * sizeof(_Tp), nothrow)); 1056 } 1057#else 1058 if (__is_overaligned_for_new(_LIBCPP_ALIGNOF(_Tp))) 1059 { 1060 // Since aligned operator new is unavailable, return an empty 1061 // buffer rather than one with invalid alignment. 1062 return __r; 1063 } 1064 1065 __r.first = static_cast<_Tp*>(::operator new(__n * sizeof(_Tp), nothrow)); 1066#endif 1067 1068 if (__r.first) 1069 { 1070 __r.second = __n; 1071 break; 1072 } 1073 __n /= 2; 1074 } 1075 return __r; 1076} 1077 1078template <class _Tp> 1079inline _LIBCPP_INLINE_VISIBILITY 1080void return_temporary_buffer(_Tp* __p) _NOEXCEPT 1081{ 1082 _VSTD::__libcpp_deallocate_unsized((void*)__p, _LIBCPP_ALIGNOF(_Tp)); 1083} 1084 1085#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 1086template <class _Tp> 1087struct _LIBCPP_DEPRECATED_IN_CXX11 auto_ptr_ref 1088{ 1089 _Tp* __ptr_; 1090}; 1091 1092template<class _Tp> 1093class _LIBCPP_TEMPLATE_VIS _LIBCPP_DEPRECATED_IN_CXX11 auto_ptr 1094{ 1095private: 1096 _Tp* __ptr_; 1097public: 1098 typedef _Tp element_type; 1099 1100 _LIBCPP_INLINE_VISIBILITY explicit auto_ptr(_Tp* __p = 0) _NOEXCEPT : __ptr_(__p) {} 1101 _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr& __p) _NOEXCEPT : __ptr_(__p.release()) {} 1102 template<class _Up> _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr<_Up>& __p) _NOEXCEPT 1103 : __ptr_(__p.release()) {} 1104 _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr& __p) _NOEXCEPT 1105 {reset(__p.release()); return *this;} 1106 template<class _Up> _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr<_Up>& __p) _NOEXCEPT 1107 {reset(__p.release()); return *this;} 1108 _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr_ref<_Tp> __p) _NOEXCEPT 1109 {reset(__p.__ptr_); return *this;} 1110 _LIBCPP_INLINE_VISIBILITY ~auto_ptr() _NOEXCEPT {delete __ptr_;} 1111 1112 _LIBCPP_INLINE_VISIBILITY _Tp& operator*() const _NOEXCEPT 1113 {return *__ptr_;} 1114 _LIBCPP_INLINE_VISIBILITY _Tp* operator->() const _NOEXCEPT {return __ptr_;} 1115 _LIBCPP_INLINE_VISIBILITY _Tp* get() const _NOEXCEPT {return __ptr_;} 1116 _LIBCPP_INLINE_VISIBILITY _Tp* release() _NOEXCEPT 1117 { 1118 _Tp* __t = __ptr_; 1119 __ptr_ = nullptr; 1120 return __t; 1121 } 1122 _LIBCPP_INLINE_VISIBILITY void reset(_Tp* __p = 0) _NOEXCEPT 1123 { 1124 if (__ptr_ != __p) 1125 delete __ptr_; 1126 __ptr_ = __p; 1127 } 1128 1129 _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr_ref<_Tp> __p) _NOEXCEPT : __ptr_(__p.__ptr_) {} 1130 template<class _Up> _LIBCPP_INLINE_VISIBILITY operator auto_ptr_ref<_Up>() _NOEXCEPT 1131 {auto_ptr_ref<_Up> __t; __t.__ptr_ = release(); return __t;} 1132 template<class _Up> _LIBCPP_INLINE_VISIBILITY operator auto_ptr<_Up>() _NOEXCEPT 1133 {return auto_ptr<_Up>(release());} 1134}; 1135 1136template <> 1137class _LIBCPP_TEMPLATE_VIS _LIBCPP_DEPRECATED_IN_CXX11 auto_ptr<void> 1138{ 1139public: 1140 typedef void element_type; 1141}; 1142#endif 1143 1144// Tag used to default initialize one or both of the pair's elements. 1145struct __default_init_tag {}; 1146struct __value_init_tag {}; 1147 1148template <class _Tp, int _Idx, 1149 bool _CanBeEmptyBase = 1150 is_empty<_Tp>::value && !__libcpp_is_final<_Tp>::value> 1151struct __compressed_pair_elem { 1152 typedef _Tp _ParamT; 1153 typedef _Tp& reference; 1154 typedef const _Tp& const_reference; 1155 1156 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1157 __compressed_pair_elem(__default_init_tag) {} 1158 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1159 __compressed_pair_elem(__value_init_tag) : __value_() {} 1160 1161 template <class _Up, class = typename enable_if< 1162 !is_same<__compressed_pair_elem, typename decay<_Up>::type>::value 1163 >::type> 1164 _LIBCPP_INLINE_VISIBILITY 1165 _LIBCPP_CONSTEXPR explicit 1166 __compressed_pair_elem(_Up&& __u) 1167 : __value_(_VSTD::forward<_Up>(__u)) 1168 { 1169 } 1170 1171 1172#ifndef _LIBCPP_CXX03_LANG 1173 template <class... _Args, size_t... _Indexes> 1174 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 1175 __compressed_pair_elem(piecewise_construct_t, tuple<_Args...> __args, 1176 __tuple_indices<_Indexes...>) 1177 : __value_(_VSTD::forward<_Args>(_VSTD::get<_Indexes>(__args))...) {} 1178#endif 1179 1180 1181 _LIBCPP_INLINE_VISIBILITY reference __get() _NOEXCEPT { return __value_; } 1182 _LIBCPP_INLINE_VISIBILITY 1183 const_reference __get() const _NOEXCEPT { return __value_; } 1184 1185private: 1186 _Tp __value_; 1187}; 1188 1189template <class _Tp, int _Idx> 1190struct __compressed_pair_elem<_Tp, _Idx, true> : private _Tp { 1191 typedef _Tp _ParamT; 1192 typedef _Tp& reference; 1193 typedef const _Tp& const_reference; 1194 typedef _Tp __value_type; 1195 1196 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR __compressed_pair_elem() = default; 1197 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1198 __compressed_pair_elem(__default_init_tag) {} 1199 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1200 __compressed_pair_elem(__value_init_tag) : __value_type() {} 1201 1202 template <class _Up, class = typename enable_if< 1203 !is_same<__compressed_pair_elem, typename decay<_Up>::type>::value 1204 >::type> 1205 _LIBCPP_INLINE_VISIBILITY 1206 _LIBCPP_CONSTEXPR explicit 1207 __compressed_pair_elem(_Up&& __u) 1208 : __value_type(_VSTD::forward<_Up>(__u)) 1209 {} 1210 1211#ifndef _LIBCPP_CXX03_LANG 1212 template <class... _Args, size_t... _Indexes> 1213 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 1214 __compressed_pair_elem(piecewise_construct_t, tuple<_Args...> __args, 1215 __tuple_indices<_Indexes...>) 1216 : __value_type(_VSTD::forward<_Args>(_VSTD::get<_Indexes>(__args))...) {} 1217#endif 1218 1219 _LIBCPP_INLINE_VISIBILITY reference __get() _NOEXCEPT { return *this; } 1220 _LIBCPP_INLINE_VISIBILITY 1221 const_reference __get() const _NOEXCEPT { return *this; } 1222}; 1223 1224template <class _T1, class _T2> 1225class __compressed_pair : private __compressed_pair_elem<_T1, 0>, 1226 private __compressed_pair_elem<_T2, 1> { 1227public: 1228 // NOTE: This static assert should never fire because __compressed_pair 1229 // is *almost never* used in a scenario where it's possible for T1 == T2. 1230 // (The exception is std::function where it is possible that the function 1231 // object and the allocator have the same type). 1232 static_assert((!is_same<_T1, _T2>::value), 1233 "__compressed_pair cannot be instantiated when T1 and T2 are the same type; " 1234 "The current implementation is NOT ABI-compatible with the previous " 1235 "implementation for this configuration"); 1236 1237 typedef _LIBCPP_NODEBUG_TYPE __compressed_pair_elem<_T1, 0> _Base1; 1238 typedef _LIBCPP_NODEBUG_TYPE __compressed_pair_elem<_T2, 1> _Base2; 1239 1240 template <bool _Dummy = true, 1241 class = typename enable_if< 1242 __dependent_type<is_default_constructible<_T1>, _Dummy>::value && 1243 __dependent_type<is_default_constructible<_T2>, _Dummy>::value 1244 >::type 1245 > 1246 _LIBCPP_INLINE_VISIBILITY 1247 _LIBCPP_CONSTEXPR __compressed_pair() : _Base1(__value_init_tag()), _Base2(__value_init_tag()) {} 1248 1249 template <class _U1, class _U2> 1250 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1251 __compressed_pair(_U1&& __t1, _U2&& __t2) 1252 : _Base1(_VSTD::forward<_U1>(__t1)), _Base2(_VSTD::forward<_U2>(__t2)) {} 1253 1254#ifndef _LIBCPP_CXX03_LANG 1255 template <class... _Args1, class... _Args2> 1256 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX14 1257 __compressed_pair(piecewise_construct_t __pc, tuple<_Args1...> __first_args, 1258 tuple<_Args2...> __second_args) 1259 : _Base1(__pc, _VSTD::move(__first_args), 1260 typename __make_tuple_indices<sizeof...(_Args1)>::type()), 1261 _Base2(__pc, _VSTD::move(__second_args), 1262 typename __make_tuple_indices<sizeof...(_Args2)>::type()) {} 1263#endif 1264 1265 _LIBCPP_INLINE_VISIBILITY 1266 typename _Base1::reference first() _NOEXCEPT { 1267 return static_cast<_Base1&>(*this).__get(); 1268 } 1269 1270 _LIBCPP_INLINE_VISIBILITY 1271 typename _Base1::const_reference first() const _NOEXCEPT { 1272 return static_cast<_Base1 const&>(*this).__get(); 1273 } 1274 1275 _LIBCPP_INLINE_VISIBILITY 1276 typename _Base2::reference second() _NOEXCEPT { 1277 return static_cast<_Base2&>(*this).__get(); 1278 } 1279 1280 _LIBCPP_INLINE_VISIBILITY 1281 typename _Base2::const_reference second() const _NOEXCEPT { 1282 return static_cast<_Base2 const&>(*this).__get(); 1283 } 1284 1285 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1286 static _Base1* __get_first_base(__compressed_pair* __pair) _NOEXCEPT { 1287 return static_cast<_Base1*>(__pair); 1288 } 1289 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 1290 static _Base2* __get_second_base(__compressed_pair* __pair) _NOEXCEPT { 1291 return static_cast<_Base2*>(__pair); 1292 } 1293 1294 _LIBCPP_INLINE_VISIBILITY 1295 void swap(__compressed_pair& __x) 1296 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 1297 __is_nothrow_swappable<_T2>::value) 1298 { 1299 using _VSTD::swap; 1300 swap(first(), __x.first()); 1301 swap(second(), __x.second()); 1302 } 1303}; 1304 1305template <class _T1, class _T2> 1306inline _LIBCPP_INLINE_VISIBILITY 1307void swap(__compressed_pair<_T1, _T2>& __x, __compressed_pair<_T1, _T2>& __y) 1308 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 1309 __is_nothrow_swappable<_T2>::value) { 1310 __x.swap(__y); 1311} 1312 1313// default_delete 1314 1315template <class _Tp> 1316struct _LIBCPP_TEMPLATE_VIS default_delete { 1317 static_assert(!is_function<_Tp>::value, 1318 "default_delete cannot be instantiated for function types"); 1319#ifndef _LIBCPP_CXX03_LANG 1320 _LIBCPP_INLINE_VISIBILITY constexpr default_delete() _NOEXCEPT = default; 1321#else 1322 _LIBCPP_INLINE_VISIBILITY default_delete() {} 1323#endif 1324 template <class _Up> 1325 _LIBCPP_INLINE_VISIBILITY 1326 default_delete(const default_delete<_Up>&, 1327 typename enable_if<is_convertible<_Up*, _Tp*>::value>::type* = 1328 0) _NOEXCEPT {} 1329 1330 _LIBCPP_INLINE_VISIBILITY void operator()(_Tp* __ptr) const _NOEXCEPT { 1331 static_assert(sizeof(_Tp) > 0, 1332 "default_delete can not delete incomplete type"); 1333 static_assert(!is_void<_Tp>::value, 1334 "default_delete can not delete incomplete type"); 1335 delete __ptr; 1336 } 1337}; 1338 1339template <class _Tp> 1340struct _LIBCPP_TEMPLATE_VIS default_delete<_Tp[]> { 1341private: 1342 template <class _Up> 1343 struct _EnableIfConvertible 1344 : enable_if<is_convertible<_Up(*)[], _Tp(*)[]>::value> {}; 1345 1346public: 1347#ifndef _LIBCPP_CXX03_LANG 1348 _LIBCPP_INLINE_VISIBILITY constexpr default_delete() _NOEXCEPT = default; 1349#else 1350 _LIBCPP_INLINE_VISIBILITY default_delete() {} 1351#endif 1352 1353 template <class _Up> 1354 _LIBCPP_INLINE_VISIBILITY 1355 default_delete(const default_delete<_Up[]>&, 1356 typename _EnableIfConvertible<_Up>::type* = 0) _NOEXCEPT {} 1357 1358 template <class _Up> 1359 _LIBCPP_INLINE_VISIBILITY 1360 typename _EnableIfConvertible<_Up>::type 1361 operator()(_Up* __ptr) const _NOEXCEPT { 1362 static_assert(sizeof(_Tp) > 0, 1363 "default_delete can not delete incomplete type"); 1364 static_assert(!is_void<_Tp>::value, 1365 "default_delete can not delete void type"); 1366 delete[] __ptr; 1367 } 1368}; 1369 1370template <class _Deleter> 1371struct __unique_ptr_deleter_sfinae { 1372 static_assert(!is_reference<_Deleter>::value, "incorrect specialization"); 1373 typedef const _Deleter& __lval_ref_type; 1374 typedef _Deleter&& __good_rval_ref_type; 1375 typedef true_type __enable_rval_overload; 1376}; 1377 1378template <class _Deleter> 1379struct __unique_ptr_deleter_sfinae<_Deleter const&> { 1380 typedef const _Deleter& __lval_ref_type; 1381 typedef const _Deleter&& __bad_rval_ref_type; 1382 typedef false_type __enable_rval_overload; 1383}; 1384 1385template <class _Deleter> 1386struct __unique_ptr_deleter_sfinae<_Deleter&> { 1387 typedef _Deleter& __lval_ref_type; 1388 typedef _Deleter&& __bad_rval_ref_type; 1389 typedef false_type __enable_rval_overload; 1390}; 1391 1392#if defined(_LIBCPP_ABI_ENABLE_UNIQUE_PTR_TRIVIAL_ABI) 1393# define _LIBCPP_UNIQUE_PTR_TRIVIAL_ABI __attribute__((trivial_abi)) 1394#else 1395# define _LIBCPP_UNIQUE_PTR_TRIVIAL_ABI 1396#endif 1397 1398template <class _Tp, class _Dp = default_delete<_Tp> > 1399class _LIBCPP_UNIQUE_PTR_TRIVIAL_ABI _LIBCPP_TEMPLATE_VIS unique_ptr { 1400public: 1401 typedef _Tp element_type; 1402 typedef _Dp deleter_type; 1403 typedef _LIBCPP_NODEBUG_TYPE typename __pointer<_Tp, deleter_type>::type pointer; 1404 1405 static_assert(!is_rvalue_reference<deleter_type>::value, 1406 "the specified deleter type cannot be an rvalue reference"); 1407 1408private: 1409 __compressed_pair<pointer, deleter_type> __ptr_; 1410 1411 struct __nat { int __for_bool_; }; 1412 1413 typedef _LIBCPP_NODEBUG_TYPE __unique_ptr_deleter_sfinae<_Dp> _DeleterSFINAE; 1414 1415 template <bool _Dummy> 1416 using _LValRefType _LIBCPP_NODEBUG_TYPE = 1417 typename __dependent_type<_DeleterSFINAE, _Dummy>::__lval_ref_type; 1418 1419 template <bool _Dummy> 1420 using _GoodRValRefType _LIBCPP_NODEBUG_TYPE = 1421 typename __dependent_type<_DeleterSFINAE, _Dummy>::__good_rval_ref_type; 1422 1423 template <bool _Dummy> 1424 using _BadRValRefType _LIBCPP_NODEBUG_TYPE = 1425 typename __dependent_type<_DeleterSFINAE, _Dummy>::__bad_rval_ref_type; 1426 1427 template <bool _Dummy, class _Deleter = typename __dependent_type< 1428 __identity<deleter_type>, _Dummy>::type> 1429 using _EnableIfDeleterDefaultConstructible _LIBCPP_NODEBUG_TYPE = 1430 typename enable_if<is_default_constructible<_Deleter>::value && 1431 !is_pointer<_Deleter>::value>::type; 1432 1433 template <class _ArgType> 1434 using _EnableIfDeleterConstructible _LIBCPP_NODEBUG_TYPE = 1435 typename enable_if<is_constructible<deleter_type, _ArgType>::value>::type; 1436 1437 template <class _UPtr, class _Up> 1438 using _EnableIfMoveConvertible _LIBCPP_NODEBUG_TYPE = typename enable_if< 1439 is_convertible<typename _UPtr::pointer, pointer>::value && 1440 !is_array<_Up>::value 1441 >::type; 1442 1443 template <class _UDel> 1444 using _EnableIfDeleterConvertible _LIBCPP_NODEBUG_TYPE = typename enable_if< 1445 (is_reference<_Dp>::value && is_same<_Dp, _UDel>::value) || 1446 (!is_reference<_Dp>::value && is_convertible<_UDel, _Dp>::value) 1447 >::type; 1448 1449 template <class _UDel> 1450 using _EnableIfDeleterAssignable = typename enable_if< 1451 is_assignable<_Dp&, _UDel&&>::value 1452 >::type; 1453 1454public: 1455 template <bool _Dummy = true, 1456 class = _EnableIfDeleterDefaultConstructible<_Dummy> > 1457 _LIBCPP_INLINE_VISIBILITY 1458 _LIBCPP_CONSTEXPR unique_ptr() _NOEXCEPT : __ptr_(pointer(), __default_init_tag()) {} 1459 1460 template <bool _Dummy = true, 1461 class = _EnableIfDeleterDefaultConstructible<_Dummy> > 1462 _LIBCPP_INLINE_VISIBILITY 1463 _LIBCPP_CONSTEXPR unique_ptr(nullptr_t) _NOEXCEPT : __ptr_(pointer(), __default_init_tag()) {} 1464 1465 template <bool _Dummy = true, 1466 class = _EnableIfDeleterDefaultConstructible<_Dummy> > 1467 _LIBCPP_INLINE_VISIBILITY 1468 explicit unique_ptr(pointer __p) _NOEXCEPT : __ptr_(__p, __default_init_tag()) {} 1469 1470 template <bool _Dummy = true, 1471 class = _EnableIfDeleterConstructible<_LValRefType<_Dummy> > > 1472 _LIBCPP_INLINE_VISIBILITY 1473 unique_ptr(pointer __p, _LValRefType<_Dummy> __d) _NOEXCEPT 1474 : __ptr_(__p, __d) {} 1475 1476 template <bool _Dummy = true, 1477 class = _EnableIfDeleterConstructible<_GoodRValRefType<_Dummy> > > 1478 _LIBCPP_INLINE_VISIBILITY 1479 unique_ptr(pointer __p, _GoodRValRefType<_Dummy> __d) _NOEXCEPT 1480 : __ptr_(__p, _VSTD::move(__d)) { 1481 static_assert(!is_reference<deleter_type>::value, 1482 "rvalue deleter bound to reference"); 1483 } 1484 1485 template <bool _Dummy = true, 1486 class = _EnableIfDeleterConstructible<_BadRValRefType<_Dummy> > > 1487 _LIBCPP_INLINE_VISIBILITY 1488 unique_ptr(pointer __p, _BadRValRefType<_Dummy> __d) = delete; 1489 1490 _LIBCPP_INLINE_VISIBILITY 1491 unique_ptr(unique_ptr&& __u) _NOEXCEPT 1492 : __ptr_(__u.release(), _VSTD::forward<deleter_type>(__u.get_deleter())) { 1493 } 1494 1495 template <class _Up, class _Ep, 1496 class = _EnableIfMoveConvertible<unique_ptr<_Up, _Ep>, _Up>, 1497 class = _EnableIfDeleterConvertible<_Ep> 1498 > 1499 _LIBCPP_INLINE_VISIBILITY 1500 unique_ptr(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT 1501 : __ptr_(__u.release(), _VSTD::forward<_Ep>(__u.get_deleter())) {} 1502 1503#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 1504 template <class _Up> 1505 _LIBCPP_INLINE_VISIBILITY 1506 unique_ptr(auto_ptr<_Up>&& __p, 1507 typename enable_if<is_convertible<_Up*, _Tp*>::value && 1508 is_same<_Dp, default_delete<_Tp> >::value, 1509 __nat>::type = __nat()) _NOEXCEPT 1510 : __ptr_(__p.release(), __default_init_tag()) {} 1511#endif 1512 1513 _LIBCPP_INLINE_VISIBILITY 1514 unique_ptr& operator=(unique_ptr&& __u) _NOEXCEPT { 1515 reset(__u.release()); 1516 __ptr_.second() = _VSTD::forward<deleter_type>(__u.get_deleter()); 1517 return *this; 1518 } 1519 1520 template <class _Up, class _Ep, 1521 class = _EnableIfMoveConvertible<unique_ptr<_Up, _Ep>, _Up>, 1522 class = _EnableIfDeleterAssignable<_Ep> 1523 > 1524 _LIBCPP_INLINE_VISIBILITY 1525 unique_ptr& operator=(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT { 1526 reset(__u.release()); 1527 __ptr_.second() = _VSTD::forward<_Ep>(__u.get_deleter()); 1528 return *this; 1529 } 1530 1531#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 1532 template <class _Up> 1533 _LIBCPP_INLINE_VISIBILITY 1534 typename enable_if<is_convertible<_Up*, _Tp*>::value && 1535 is_same<_Dp, default_delete<_Tp> >::value, 1536 unique_ptr&>::type 1537 operator=(auto_ptr<_Up> __p) { 1538 reset(__p.release()); 1539 return *this; 1540 } 1541#endif 1542 1543#ifdef _LIBCPP_CXX03_LANG 1544 unique_ptr(unique_ptr const&) = delete; 1545 unique_ptr& operator=(unique_ptr const&) = delete; 1546#endif 1547 1548 1549 _LIBCPP_INLINE_VISIBILITY 1550 ~unique_ptr() { reset(); } 1551 1552 _LIBCPP_INLINE_VISIBILITY 1553 unique_ptr& operator=(nullptr_t) _NOEXCEPT { 1554 reset(); 1555 return *this; 1556 } 1557 1558 _LIBCPP_INLINE_VISIBILITY 1559 typename add_lvalue_reference<_Tp>::type 1560 operator*() const { 1561 return *__ptr_.first(); 1562 } 1563 _LIBCPP_INLINE_VISIBILITY 1564 pointer operator->() const _NOEXCEPT { 1565 return __ptr_.first(); 1566 } 1567 _LIBCPP_INLINE_VISIBILITY 1568 pointer get() const _NOEXCEPT { 1569 return __ptr_.first(); 1570 } 1571 _LIBCPP_INLINE_VISIBILITY 1572 deleter_type& get_deleter() _NOEXCEPT { 1573 return __ptr_.second(); 1574 } 1575 _LIBCPP_INLINE_VISIBILITY 1576 const deleter_type& get_deleter() const _NOEXCEPT { 1577 return __ptr_.second(); 1578 } 1579 _LIBCPP_INLINE_VISIBILITY 1580 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT { 1581 return __ptr_.first() != nullptr; 1582 } 1583 1584 _LIBCPP_INLINE_VISIBILITY 1585 pointer release() _NOEXCEPT { 1586 pointer __t = __ptr_.first(); 1587 __ptr_.first() = pointer(); 1588 return __t; 1589 } 1590 1591 _LIBCPP_INLINE_VISIBILITY 1592 void reset(pointer __p = pointer()) _NOEXCEPT { 1593 pointer __tmp = __ptr_.first(); 1594 __ptr_.first() = __p; 1595 if (__tmp) 1596 __ptr_.second()(__tmp); 1597 } 1598 1599 _LIBCPP_INLINE_VISIBILITY 1600 void swap(unique_ptr& __u) _NOEXCEPT { 1601 __ptr_.swap(__u.__ptr_); 1602 } 1603}; 1604 1605 1606template <class _Tp, class _Dp> 1607class _LIBCPP_UNIQUE_PTR_TRIVIAL_ABI _LIBCPP_TEMPLATE_VIS unique_ptr<_Tp[], _Dp> { 1608public: 1609 typedef _Tp element_type; 1610 typedef _Dp deleter_type; 1611 typedef typename __pointer<_Tp, deleter_type>::type pointer; 1612 1613private: 1614 __compressed_pair<pointer, deleter_type> __ptr_; 1615 1616 template <class _From> 1617 struct _CheckArrayPointerConversion : is_same<_From, pointer> {}; 1618 1619 template <class _FromElem> 1620 struct _CheckArrayPointerConversion<_FromElem*> 1621 : integral_constant<bool, 1622 is_same<_FromElem*, pointer>::value || 1623 (is_same<pointer, element_type*>::value && 1624 is_convertible<_FromElem(*)[], element_type(*)[]>::value) 1625 > 1626 {}; 1627 1628 typedef __unique_ptr_deleter_sfinae<_Dp> _DeleterSFINAE; 1629 1630 template <bool _Dummy> 1631 using _LValRefType _LIBCPP_NODEBUG_TYPE = 1632 typename __dependent_type<_DeleterSFINAE, _Dummy>::__lval_ref_type; 1633 1634 template <bool _Dummy> 1635 using _GoodRValRefType _LIBCPP_NODEBUG_TYPE = 1636 typename __dependent_type<_DeleterSFINAE, _Dummy>::__good_rval_ref_type; 1637 1638 template <bool _Dummy> 1639 using _BadRValRefType _LIBCPP_NODEBUG_TYPE = 1640 typename __dependent_type<_DeleterSFINAE, _Dummy>::__bad_rval_ref_type; 1641 1642 template <bool _Dummy, class _Deleter = typename __dependent_type< 1643 __identity<deleter_type>, _Dummy>::type> 1644 using _EnableIfDeleterDefaultConstructible _LIBCPP_NODEBUG_TYPE = 1645 typename enable_if<is_default_constructible<_Deleter>::value && 1646 !is_pointer<_Deleter>::value>::type; 1647 1648 template <class _ArgType> 1649 using _EnableIfDeleterConstructible _LIBCPP_NODEBUG_TYPE = 1650 typename enable_if<is_constructible<deleter_type, _ArgType>::value>::type; 1651 1652 template <class _Pp> 1653 using _EnableIfPointerConvertible _LIBCPP_NODEBUG_TYPE = typename enable_if< 1654 _CheckArrayPointerConversion<_Pp>::value 1655 >::type; 1656 1657 template <class _UPtr, class _Up, 1658 class _ElemT = typename _UPtr::element_type> 1659 using _EnableIfMoveConvertible _LIBCPP_NODEBUG_TYPE = typename enable_if< 1660 is_array<_Up>::value && 1661 is_same<pointer, element_type*>::value && 1662 is_same<typename _UPtr::pointer, _ElemT*>::value && 1663 is_convertible<_ElemT(*)[], element_type(*)[]>::value 1664 >::type; 1665 1666 template <class _UDel> 1667 using _EnableIfDeleterConvertible _LIBCPP_NODEBUG_TYPE = typename enable_if< 1668 (is_reference<_Dp>::value && is_same<_Dp, _UDel>::value) || 1669 (!is_reference<_Dp>::value && is_convertible<_UDel, _Dp>::value) 1670 >::type; 1671 1672 template <class _UDel> 1673 using _EnableIfDeleterAssignable _LIBCPP_NODEBUG_TYPE = typename enable_if< 1674 is_assignable<_Dp&, _UDel&&>::value 1675 >::type; 1676 1677public: 1678 template <bool _Dummy = true, 1679 class = _EnableIfDeleterDefaultConstructible<_Dummy> > 1680 _LIBCPP_INLINE_VISIBILITY 1681 _LIBCPP_CONSTEXPR unique_ptr() _NOEXCEPT : __ptr_(pointer(), __default_init_tag()) {} 1682 1683 template <bool _Dummy = true, 1684 class = _EnableIfDeleterDefaultConstructible<_Dummy> > 1685 _LIBCPP_INLINE_VISIBILITY 1686 _LIBCPP_CONSTEXPR unique_ptr(nullptr_t) _NOEXCEPT : __ptr_(pointer(), __default_init_tag()) {} 1687 1688 template <class _Pp, bool _Dummy = true, 1689 class = _EnableIfDeleterDefaultConstructible<_Dummy>, 1690 class = _EnableIfPointerConvertible<_Pp> > 1691 _LIBCPP_INLINE_VISIBILITY 1692 explicit unique_ptr(_Pp __p) _NOEXCEPT 1693 : __ptr_(__p, __default_init_tag()) {} 1694 1695 template <class _Pp, bool _Dummy = true, 1696 class = _EnableIfDeleterConstructible<_LValRefType<_Dummy> >, 1697 class = _EnableIfPointerConvertible<_Pp> > 1698 _LIBCPP_INLINE_VISIBILITY 1699 unique_ptr(_Pp __p, _LValRefType<_Dummy> __d) _NOEXCEPT 1700 : __ptr_(__p, __d) {} 1701 1702 template <bool _Dummy = true, 1703 class = _EnableIfDeleterConstructible<_LValRefType<_Dummy> > > 1704 _LIBCPP_INLINE_VISIBILITY 1705 unique_ptr(nullptr_t, _LValRefType<_Dummy> __d) _NOEXCEPT 1706 : __ptr_(nullptr, __d) {} 1707 1708 template <class _Pp, bool _Dummy = true, 1709 class = _EnableIfDeleterConstructible<_GoodRValRefType<_Dummy> >, 1710 class = _EnableIfPointerConvertible<_Pp> > 1711 _LIBCPP_INLINE_VISIBILITY 1712 unique_ptr(_Pp __p, _GoodRValRefType<_Dummy> __d) _NOEXCEPT 1713 : __ptr_(__p, _VSTD::move(__d)) { 1714 static_assert(!is_reference<deleter_type>::value, 1715 "rvalue deleter bound to reference"); 1716 } 1717 1718 template <bool _Dummy = true, 1719 class = _EnableIfDeleterConstructible<_GoodRValRefType<_Dummy> > > 1720 _LIBCPP_INLINE_VISIBILITY 1721 unique_ptr(nullptr_t, _GoodRValRefType<_Dummy> __d) _NOEXCEPT 1722 : __ptr_(nullptr, _VSTD::move(__d)) { 1723 static_assert(!is_reference<deleter_type>::value, 1724 "rvalue deleter bound to reference"); 1725 } 1726 1727 template <class _Pp, bool _Dummy = true, 1728 class = _EnableIfDeleterConstructible<_BadRValRefType<_Dummy> >, 1729 class = _EnableIfPointerConvertible<_Pp> > 1730 _LIBCPP_INLINE_VISIBILITY 1731 unique_ptr(_Pp __p, _BadRValRefType<_Dummy> __d) = delete; 1732 1733 _LIBCPP_INLINE_VISIBILITY 1734 unique_ptr(unique_ptr&& __u) _NOEXCEPT 1735 : __ptr_(__u.release(), _VSTD::forward<deleter_type>(__u.get_deleter())) { 1736 } 1737 1738 _LIBCPP_INLINE_VISIBILITY 1739 unique_ptr& operator=(unique_ptr&& __u) _NOEXCEPT { 1740 reset(__u.release()); 1741 __ptr_.second() = _VSTD::forward<deleter_type>(__u.get_deleter()); 1742 return *this; 1743 } 1744 1745 template <class _Up, class _Ep, 1746 class = _EnableIfMoveConvertible<unique_ptr<_Up, _Ep>, _Up>, 1747 class = _EnableIfDeleterConvertible<_Ep> 1748 > 1749 _LIBCPP_INLINE_VISIBILITY 1750 unique_ptr(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT 1751 : __ptr_(__u.release(), _VSTD::forward<_Ep>(__u.get_deleter())) { 1752 } 1753 1754 template <class _Up, class _Ep, 1755 class = _EnableIfMoveConvertible<unique_ptr<_Up, _Ep>, _Up>, 1756 class = _EnableIfDeleterAssignable<_Ep> 1757 > 1758 _LIBCPP_INLINE_VISIBILITY 1759 unique_ptr& 1760 operator=(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT { 1761 reset(__u.release()); 1762 __ptr_.second() = _VSTD::forward<_Ep>(__u.get_deleter()); 1763 return *this; 1764 } 1765 1766#ifdef _LIBCPP_CXX03_LANG 1767 unique_ptr(unique_ptr const&) = delete; 1768 unique_ptr& operator=(unique_ptr const&) = delete; 1769#endif 1770 1771public: 1772 _LIBCPP_INLINE_VISIBILITY 1773 ~unique_ptr() { reset(); } 1774 1775 _LIBCPP_INLINE_VISIBILITY 1776 unique_ptr& operator=(nullptr_t) _NOEXCEPT { 1777 reset(); 1778 return *this; 1779 } 1780 1781 _LIBCPP_INLINE_VISIBILITY 1782 typename add_lvalue_reference<_Tp>::type 1783 operator[](size_t __i) const { 1784 return __ptr_.first()[__i]; 1785 } 1786 _LIBCPP_INLINE_VISIBILITY 1787 pointer get() const _NOEXCEPT { 1788 return __ptr_.first(); 1789 } 1790 1791 _LIBCPP_INLINE_VISIBILITY 1792 deleter_type& get_deleter() _NOEXCEPT { 1793 return __ptr_.second(); 1794 } 1795 1796 _LIBCPP_INLINE_VISIBILITY 1797 const deleter_type& get_deleter() const _NOEXCEPT { 1798 return __ptr_.second(); 1799 } 1800 _LIBCPP_INLINE_VISIBILITY 1801 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT { 1802 return __ptr_.first() != nullptr; 1803 } 1804 1805 _LIBCPP_INLINE_VISIBILITY 1806 pointer release() _NOEXCEPT { 1807 pointer __t = __ptr_.first(); 1808 __ptr_.first() = pointer(); 1809 return __t; 1810 } 1811 1812 template <class _Pp> 1813 _LIBCPP_INLINE_VISIBILITY 1814 typename enable_if< 1815 _CheckArrayPointerConversion<_Pp>::value 1816 >::type 1817 reset(_Pp __p) _NOEXCEPT { 1818 pointer __tmp = __ptr_.first(); 1819 __ptr_.first() = __p; 1820 if (__tmp) 1821 __ptr_.second()(__tmp); 1822 } 1823 1824 _LIBCPP_INLINE_VISIBILITY 1825 void reset(nullptr_t = nullptr) _NOEXCEPT { 1826 pointer __tmp = __ptr_.first(); 1827 __ptr_.first() = nullptr; 1828 if (__tmp) 1829 __ptr_.second()(__tmp); 1830 } 1831 1832 _LIBCPP_INLINE_VISIBILITY 1833 void swap(unique_ptr& __u) _NOEXCEPT { 1834 __ptr_.swap(__u.__ptr_); 1835 } 1836 1837}; 1838 1839template <class _Tp, class _Dp> 1840inline _LIBCPP_INLINE_VISIBILITY 1841typename enable_if< 1842 __is_swappable<_Dp>::value, 1843 void 1844>::type 1845swap(unique_ptr<_Tp, _Dp>& __x, unique_ptr<_Tp, _Dp>& __y) _NOEXCEPT {__x.swap(__y);} 1846 1847template <class _T1, class _D1, class _T2, class _D2> 1848inline _LIBCPP_INLINE_VISIBILITY 1849bool 1850operator==(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return __x.get() == __y.get();} 1851 1852template <class _T1, class _D1, class _T2, class _D2> 1853inline _LIBCPP_INLINE_VISIBILITY 1854bool 1855operator!=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__x == __y);} 1856 1857template <class _T1, class _D1, class _T2, class _D2> 1858inline _LIBCPP_INLINE_VISIBILITY 1859bool 1860operator< (const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) 1861{ 1862 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 1863 typedef typename unique_ptr<_T2, _D2>::pointer _P2; 1864 typedef typename common_type<_P1, _P2>::type _Vp; 1865 return less<_Vp>()(__x.get(), __y.get()); 1866} 1867 1868template <class _T1, class _D1, class _T2, class _D2> 1869inline _LIBCPP_INLINE_VISIBILITY 1870bool 1871operator> (const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return __y < __x;} 1872 1873template <class _T1, class _D1, class _T2, class _D2> 1874inline _LIBCPP_INLINE_VISIBILITY 1875bool 1876operator<=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__y < __x);} 1877 1878template <class _T1, class _D1, class _T2, class _D2> 1879inline _LIBCPP_INLINE_VISIBILITY 1880bool 1881operator>=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__x < __y);} 1882 1883template <class _T1, class _D1> 1884inline _LIBCPP_INLINE_VISIBILITY 1885bool 1886operator==(const unique_ptr<_T1, _D1>& __x, nullptr_t) _NOEXCEPT 1887{ 1888 return !__x; 1889} 1890 1891template <class _T1, class _D1> 1892inline _LIBCPP_INLINE_VISIBILITY 1893bool 1894operator==(nullptr_t, const unique_ptr<_T1, _D1>& __x) _NOEXCEPT 1895{ 1896 return !__x; 1897} 1898 1899template <class _T1, class _D1> 1900inline _LIBCPP_INLINE_VISIBILITY 1901bool 1902operator!=(const unique_ptr<_T1, _D1>& __x, nullptr_t) _NOEXCEPT 1903{ 1904 return static_cast<bool>(__x); 1905} 1906 1907template <class _T1, class _D1> 1908inline _LIBCPP_INLINE_VISIBILITY 1909bool 1910operator!=(nullptr_t, const unique_ptr<_T1, _D1>& __x) _NOEXCEPT 1911{ 1912 return static_cast<bool>(__x); 1913} 1914 1915template <class _T1, class _D1> 1916inline _LIBCPP_INLINE_VISIBILITY 1917bool 1918operator<(const unique_ptr<_T1, _D1>& __x, nullptr_t) 1919{ 1920 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 1921 return less<_P1>()(__x.get(), nullptr); 1922} 1923 1924template <class _T1, class _D1> 1925inline _LIBCPP_INLINE_VISIBILITY 1926bool 1927operator<(nullptr_t, const unique_ptr<_T1, _D1>& __x) 1928{ 1929 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 1930 return less<_P1>()(nullptr, __x.get()); 1931} 1932 1933template <class _T1, class _D1> 1934inline _LIBCPP_INLINE_VISIBILITY 1935bool 1936operator>(const unique_ptr<_T1, _D1>& __x, nullptr_t) 1937{ 1938 return nullptr < __x; 1939} 1940 1941template <class _T1, class _D1> 1942inline _LIBCPP_INLINE_VISIBILITY 1943bool 1944operator>(nullptr_t, const unique_ptr<_T1, _D1>& __x) 1945{ 1946 return __x < nullptr; 1947} 1948 1949template <class _T1, class _D1> 1950inline _LIBCPP_INLINE_VISIBILITY 1951bool 1952operator<=(const unique_ptr<_T1, _D1>& __x, nullptr_t) 1953{ 1954 return !(nullptr < __x); 1955} 1956 1957template <class _T1, class _D1> 1958inline _LIBCPP_INLINE_VISIBILITY 1959bool 1960operator<=(nullptr_t, const unique_ptr<_T1, _D1>& __x) 1961{ 1962 return !(__x < nullptr); 1963} 1964 1965template <class _T1, class _D1> 1966inline _LIBCPP_INLINE_VISIBILITY 1967bool 1968operator>=(const unique_ptr<_T1, _D1>& __x, nullptr_t) 1969{ 1970 return !(__x < nullptr); 1971} 1972 1973template <class _T1, class _D1> 1974inline _LIBCPP_INLINE_VISIBILITY 1975bool 1976operator>=(nullptr_t, const unique_ptr<_T1, _D1>& __x) 1977{ 1978 return !(nullptr < __x); 1979} 1980 1981#if _LIBCPP_STD_VER > 11 1982 1983template<class _Tp> 1984struct __unique_if 1985{ 1986 typedef unique_ptr<_Tp> __unique_single; 1987}; 1988 1989template<class _Tp> 1990struct __unique_if<_Tp[]> 1991{ 1992 typedef unique_ptr<_Tp[]> __unique_array_unknown_bound; 1993}; 1994 1995template<class _Tp, size_t _Np> 1996struct __unique_if<_Tp[_Np]> 1997{ 1998 typedef void __unique_array_known_bound; 1999}; 2000 2001template<class _Tp, class... _Args> 2002inline _LIBCPP_INLINE_VISIBILITY 2003typename __unique_if<_Tp>::__unique_single 2004make_unique(_Args&&... __args) 2005{ 2006 return unique_ptr<_Tp>(new _Tp(_VSTD::forward<_Args>(__args)...)); 2007} 2008 2009template<class _Tp> 2010inline _LIBCPP_INLINE_VISIBILITY 2011typename __unique_if<_Tp>::__unique_array_unknown_bound 2012make_unique(size_t __n) 2013{ 2014 typedef typename remove_extent<_Tp>::type _Up; 2015 return unique_ptr<_Tp>(new _Up[__n]()); 2016} 2017 2018template<class _Tp, class... _Args> 2019 typename __unique_if<_Tp>::__unique_array_known_bound 2020 make_unique(_Args&&...) = delete; 2021 2022#endif // _LIBCPP_STD_VER > 11 2023 2024template <class _Tp, class _Dp> 2025#ifdef _LIBCPP_CXX03_LANG 2026struct _LIBCPP_TEMPLATE_VIS hash<unique_ptr<_Tp, _Dp> > 2027#else 2028struct _LIBCPP_TEMPLATE_VIS hash<__enable_hash_helper< 2029 unique_ptr<_Tp, _Dp>, typename unique_ptr<_Tp, _Dp>::pointer> > 2030#endif 2031{ 2032 typedef unique_ptr<_Tp, _Dp> argument_type; 2033 typedef size_t result_type; 2034 _LIBCPP_INLINE_VISIBILITY 2035 result_type operator()(const argument_type& __ptr) const 2036 { 2037 typedef typename argument_type::pointer pointer; 2038 return hash<pointer>()(__ptr.get()); 2039 } 2040}; 2041 2042struct __destruct_n 2043{ 2044private: 2045 size_t __size_; 2046 2047 template <class _Tp> 2048 _LIBCPP_INLINE_VISIBILITY void __process(_Tp* __p, false_type) _NOEXCEPT 2049 {for (size_t __i = 0; __i < __size_; ++__i, ++__p) __p->~_Tp();} 2050 2051 template <class _Tp> 2052 _LIBCPP_INLINE_VISIBILITY void __process(_Tp*, true_type) _NOEXCEPT 2053 {} 2054 2055 _LIBCPP_INLINE_VISIBILITY void __incr(false_type) _NOEXCEPT 2056 {++__size_;} 2057 _LIBCPP_INLINE_VISIBILITY void __incr(true_type) _NOEXCEPT 2058 {} 2059 2060 _LIBCPP_INLINE_VISIBILITY void __set(size_t __s, false_type) _NOEXCEPT 2061 {__size_ = __s;} 2062 _LIBCPP_INLINE_VISIBILITY void __set(size_t, true_type) _NOEXCEPT 2063 {} 2064public: 2065 _LIBCPP_INLINE_VISIBILITY explicit __destruct_n(size_t __s) _NOEXCEPT 2066 : __size_(__s) {} 2067 2068 template <class _Tp> 2069 _LIBCPP_INLINE_VISIBILITY void __incr() _NOEXCEPT 2070 {__incr(integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 2071 2072 template <class _Tp> 2073 _LIBCPP_INLINE_VISIBILITY void __set(size_t __s, _Tp*) _NOEXCEPT 2074 {__set(__s, integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 2075 2076 template <class _Tp> 2077 _LIBCPP_INLINE_VISIBILITY void operator()(_Tp* __p) _NOEXCEPT 2078 {__process(__p, integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 2079}; 2080 2081template <class _Alloc> 2082class __allocator_destructor 2083{ 2084 typedef _LIBCPP_NODEBUG_TYPE allocator_traits<_Alloc> __alloc_traits; 2085public: 2086 typedef _LIBCPP_NODEBUG_TYPE typename __alloc_traits::pointer pointer; 2087 typedef _LIBCPP_NODEBUG_TYPE typename __alloc_traits::size_type size_type; 2088private: 2089 _Alloc& __alloc_; 2090 size_type __s_; 2091public: 2092 _LIBCPP_INLINE_VISIBILITY __allocator_destructor(_Alloc& __a, size_type __s) 2093 _NOEXCEPT 2094 : __alloc_(__a), __s_(__s) {} 2095 _LIBCPP_INLINE_VISIBILITY 2096 void operator()(pointer __p) _NOEXCEPT 2097 {__alloc_traits::deallocate(__alloc_, __p, __s_);} 2098}; 2099 2100template <class _InputIterator, class _ForwardIterator> 2101_ForwardIterator 2102uninitialized_copy(_InputIterator __f, _InputIterator __l, _ForwardIterator __r) 2103{ 2104 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 2105#ifndef _LIBCPP_NO_EXCEPTIONS 2106 _ForwardIterator __s = __r; 2107 try 2108 { 2109#endif 2110 for (; __f != __l; ++__f, (void) ++__r) 2111 ::new ((void*)_VSTD::addressof(*__r)) value_type(*__f); 2112#ifndef _LIBCPP_NO_EXCEPTIONS 2113 } 2114 catch (...) 2115 { 2116 for (; __s != __r; ++__s) 2117 __s->~value_type(); 2118 throw; 2119 } 2120#endif 2121 return __r; 2122} 2123 2124template <class _InputIterator, class _Size, class _ForwardIterator> 2125_ForwardIterator 2126uninitialized_copy_n(_InputIterator __f, _Size __n, _ForwardIterator __r) 2127{ 2128 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 2129#ifndef _LIBCPP_NO_EXCEPTIONS 2130 _ForwardIterator __s = __r; 2131 try 2132 { 2133#endif 2134 for (; __n > 0; ++__f, (void) ++__r, (void) --__n) 2135 ::new ((void*)_VSTD::addressof(*__r)) value_type(*__f); 2136#ifndef _LIBCPP_NO_EXCEPTIONS 2137 } 2138 catch (...) 2139 { 2140 for (; __s != __r; ++__s) 2141 __s->~value_type(); 2142 throw; 2143 } 2144#endif 2145 return __r; 2146} 2147 2148template <class _ForwardIterator, class _Tp> 2149void 2150uninitialized_fill(_ForwardIterator __f, _ForwardIterator __l, const _Tp& __x) 2151{ 2152 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 2153#ifndef _LIBCPP_NO_EXCEPTIONS 2154 _ForwardIterator __s = __f; 2155 try 2156 { 2157#endif 2158 for (; __f != __l; ++__f) 2159 ::new ((void*)_VSTD::addressof(*__f)) value_type(__x); 2160#ifndef _LIBCPP_NO_EXCEPTIONS 2161 } 2162 catch (...) 2163 { 2164 for (; __s != __f; ++__s) 2165 __s->~value_type(); 2166 throw; 2167 } 2168#endif 2169} 2170 2171template <class _ForwardIterator, class _Size, class _Tp> 2172_ForwardIterator 2173uninitialized_fill_n(_ForwardIterator __f, _Size __n, const _Tp& __x) 2174{ 2175 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 2176#ifndef _LIBCPP_NO_EXCEPTIONS 2177 _ForwardIterator __s = __f; 2178 try 2179 { 2180#endif 2181 for (; __n > 0; ++__f, (void) --__n) 2182 ::new ((void*)_VSTD::addressof(*__f)) value_type(__x); 2183#ifndef _LIBCPP_NO_EXCEPTIONS 2184 } 2185 catch (...) 2186 { 2187 for (; __s != __f; ++__s) 2188 __s->~value_type(); 2189 throw; 2190 } 2191#endif 2192 return __f; 2193} 2194 2195#if _LIBCPP_STD_VER > 14 2196 2197template <class _ForwardIterator> 2198inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 2199void destroy(_ForwardIterator __first, _ForwardIterator __last) { 2200 for (; __first != __last; ++__first) 2201 _VSTD::destroy_at(_VSTD::addressof(*__first)); 2202} 2203 2204template <class _ForwardIterator, class _Size> 2205inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17 2206_ForwardIterator destroy_n(_ForwardIterator __first, _Size __n) { 2207 for (; __n > 0; (void)++__first, --__n) 2208 _VSTD::destroy_at(_VSTD::addressof(*__first)); 2209 return __first; 2210} 2211 2212template <class _ForwardIterator> 2213inline _LIBCPP_INLINE_VISIBILITY 2214void uninitialized_default_construct(_ForwardIterator __first, _ForwardIterator __last) { 2215 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 2216 auto __idx = __first; 2217#ifndef _LIBCPP_NO_EXCEPTIONS 2218 try { 2219#endif 2220 for (; __idx != __last; ++__idx) 2221 ::new ((void*)_VSTD::addressof(*__idx)) _Vt; 2222#ifndef _LIBCPP_NO_EXCEPTIONS 2223 } catch (...) { 2224 _VSTD::destroy(__first, __idx); 2225 throw; 2226 } 2227#endif 2228} 2229 2230template <class _ForwardIterator, class _Size> 2231inline _LIBCPP_INLINE_VISIBILITY 2232_ForwardIterator uninitialized_default_construct_n(_ForwardIterator __first, _Size __n) { 2233 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 2234 auto __idx = __first; 2235#ifndef _LIBCPP_NO_EXCEPTIONS 2236 try { 2237#endif 2238 for (; __n > 0; (void)++__idx, --__n) 2239 ::new ((void*)_VSTD::addressof(*__idx)) _Vt; 2240 return __idx; 2241#ifndef _LIBCPP_NO_EXCEPTIONS 2242 } catch (...) { 2243 _VSTD::destroy(__first, __idx); 2244 throw; 2245 } 2246#endif 2247} 2248 2249 2250template <class _ForwardIterator> 2251inline _LIBCPP_INLINE_VISIBILITY 2252void uninitialized_value_construct(_ForwardIterator __first, _ForwardIterator __last) { 2253 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 2254 auto __idx = __first; 2255#ifndef _LIBCPP_NO_EXCEPTIONS 2256 try { 2257#endif 2258 for (; __idx != __last; ++__idx) 2259 ::new ((void*)_VSTD::addressof(*__idx)) _Vt(); 2260#ifndef _LIBCPP_NO_EXCEPTIONS 2261 } catch (...) { 2262 _VSTD::destroy(__first, __idx); 2263 throw; 2264 } 2265#endif 2266} 2267 2268template <class _ForwardIterator, class _Size> 2269inline _LIBCPP_INLINE_VISIBILITY 2270_ForwardIterator uninitialized_value_construct_n(_ForwardIterator __first, _Size __n) { 2271 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 2272 auto __idx = __first; 2273#ifndef _LIBCPP_NO_EXCEPTIONS 2274 try { 2275#endif 2276 for (; __n > 0; (void)++__idx, --__n) 2277 ::new ((void*)_VSTD::addressof(*__idx)) _Vt(); 2278 return __idx; 2279#ifndef _LIBCPP_NO_EXCEPTIONS 2280 } catch (...) { 2281 _VSTD::destroy(__first, __idx); 2282 throw; 2283 } 2284#endif 2285} 2286 2287 2288template <class _InputIt, class _ForwardIt> 2289inline _LIBCPP_INLINE_VISIBILITY 2290_ForwardIt uninitialized_move(_InputIt __first, _InputIt __last, _ForwardIt __first_res) { 2291 using _Vt = typename iterator_traits<_ForwardIt>::value_type; 2292 auto __idx = __first_res; 2293#ifndef _LIBCPP_NO_EXCEPTIONS 2294 try { 2295#endif 2296 for (; __first != __last; (void)++__idx, ++__first) 2297 ::new ((void*)_VSTD::addressof(*__idx)) _Vt(_VSTD::move(*__first)); 2298 return __idx; 2299#ifndef _LIBCPP_NO_EXCEPTIONS 2300 } catch (...) { 2301 _VSTD::destroy(__first_res, __idx); 2302 throw; 2303 } 2304#endif 2305} 2306 2307template <class _InputIt, class _Size, class _ForwardIt> 2308inline _LIBCPP_INLINE_VISIBILITY 2309pair<_InputIt, _ForwardIt> 2310uninitialized_move_n(_InputIt __first, _Size __n, _ForwardIt __first_res) { 2311 using _Vt = typename iterator_traits<_ForwardIt>::value_type; 2312 auto __idx = __first_res; 2313#ifndef _LIBCPP_NO_EXCEPTIONS 2314 try { 2315#endif 2316 for (; __n > 0; ++__idx, (void)++__first, --__n) 2317 ::new ((void*)_VSTD::addressof(*__idx)) _Vt(_VSTD::move(*__first)); 2318 return {__first, __idx}; 2319#ifndef _LIBCPP_NO_EXCEPTIONS 2320 } catch (...) { 2321 _VSTD::destroy(__first_res, __idx); 2322 throw; 2323 } 2324#endif 2325} 2326 2327 2328#endif // _LIBCPP_STD_VER > 14 2329 2330// NOTE: Relaxed and acq/rel atomics (for increment and decrement respectively) 2331// should be sufficient for thread safety. 2332// See https://llvm.org/PR22803 2333#if defined(__clang__) && __has_builtin(__atomic_add_fetch) \ 2334 && defined(__ATOMIC_RELAXED) \ 2335 && defined(__ATOMIC_ACQ_REL) 2336# define _LIBCPP_HAS_BUILTIN_ATOMIC_SUPPORT 2337#elif defined(_LIBCPP_COMPILER_GCC) 2338# define _LIBCPP_HAS_BUILTIN_ATOMIC_SUPPORT 2339#endif 2340 2341template <class _Tp> 2342inline _LIBCPP_INLINE_VISIBILITY _Tp 2343__libcpp_atomic_refcount_increment(_Tp& __t) _NOEXCEPT 2344{ 2345#if defined(_LIBCPP_HAS_BUILTIN_ATOMIC_SUPPORT) && !defined(_LIBCPP_HAS_NO_THREADS) 2346 return __atomic_add_fetch(&__t, 1, __ATOMIC_RELAXED); 2347#else 2348 return __t += 1; 2349#endif 2350} 2351 2352template <class _Tp> 2353inline _LIBCPP_INLINE_VISIBILITY _Tp 2354__libcpp_atomic_refcount_decrement(_Tp& __t) _NOEXCEPT 2355{ 2356#if defined(_LIBCPP_HAS_BUILTIN_ATOMIC_SUPPORT) && !defined(_LIBCPP_HAS_NO_THREADS) 2357 return __atomic_add_fetch(&__t, -1, __ATOMIC_ACQ_REL); 2358#else 2359 return __t -= 1; 2360#endif 2361} 2362 2363class _LIBCPP_EXCEPTION_ABI bad_weak_ptr 2364 : public std::exception 2365{ 2366public: 2367 bad_weak_ptr() _NOEXCEPT = default; 2368 bad_weak_ptr(const bad_weak_ptr&) _NOEXCEPT = default; 2369 virtual ~bad_weak_ptr() _NOEXCEPT; 2370 virtual const char* what() const _NOEXCEPT; 2371}; 2372 2373_LIBCPP_NORETURN inline _LIBCPP_INLINE_VISIBILITY 2374void __throw_bad_weak_ptr() 2375{ 2376#ifndef _LIBCPP_NO_EXCEPTIONS 2377 throw bad_weak_ptr(); 2378#else 2379 _VSTD::abort(); 2380#endif 2381} 2382 2383template<class _Tp> class _LIBCPP_TEMPLATE_VIS weak_ptr; 2384 2385class _LIBCPP_TYPE_VIS __shared_count 2386{ 2387 __shared_count(const __shared_count&); 2388 __shared_count& operator=(const __shared_count&); 2389 2390protected: 2391 long __shared_owners_; 2392 virtual ~__shared_count(); 2393private: 2394 virtual void __on_zero_shared() _NOEXCEPT = 0; 2395 2396public: 2397 _LIBCPP_INLINE_VISIBILITY 2398 explicit __shared_count(long __refs = 0) _NOEXCEPT 2399 : __shared_owners_(__refs) {} 2400 2401#if defined(_LIBCPP_BUILDING_LIBRARY) && \ 2402 defined(_LIBCPP_DEPRECATED_ABI_LEGACY_LIBRARY_DEFINITIONS_FOR_INLINE_FUNCTIONS) 2403 void __add_shared() _NOEXCEPT; 2404 bool __release_shared() _NOEXCEPT; 2405#else 2406 _LIBCPP_INLINE_VISIBILITY 2407 void __add_shared() _NOEXCEPT { 2408 __libcpp_atomic_refcount_increment(__shared_owners_); 2409 } 2410 _LIBCPP_INLINE_VISIBILITY 2411 bool __release_shared() _NOEXCEPT { 2412 if (__libcpp_atomic_refcount_decrement(__shared_owners_) == -1) { 2413 __on_zero_shared(); 2414 return true; 2415 } 2416 return false; 2417 } 2418#endif 2419 _LIBCPP_INLINE_VISIBILITY 2420 long use_count() const _NOEXCEPT { 2421 return __libcpp_relaxed_load(&__shared_owners_) + 1; 2422 } 2423}; 2424 2425class _LIBCPP_TYPE_VIS __shared_weak_count 2426 : private __shared_count 2427{ 2428 long __shared_weak_owners_; 2429 2430public: 2431 _LIBCPP_INLINE_VISIBILITY 2432 explicit __shared_weak_count(long __refs = 0) _NOEXCEPT 2433 : __shared_count(__refs), 2434 __shared_weak_owners_(__refs) {} 2435protected: 2436 virtual ~__shared_weak_count(); 2437 2438public: 2439#if defined(_LIBCPP_BUILDING_LIBRARY) && \ 2440 defined(_LIBCPP_DEPRECATED_ABI_LEGACY_LIBRARY_DEFINITIONS_FOR_INLINE_FUNCTIONS) 2441 void __add_shared() _NOEXCEPT; 2442 void __add_weak() _NOEXCEPT; 2443 void __release_shared() _NOEXCEPT; 2444#else 2445 _LIBCPP_INLINE_VISIBILITY 2446 void __add_shared() _NOEXCEPT { 2447 __shared_count::__add_shared(); 2448 } 2449 _LIBCPP_INLINE_VISIBILITY 2450 void __add_weak() _NOEXCEPT { 2451 __libcpp_atomic_refcount_increment(__shared_weak_owners_); 2452 } 2453 _LIBCPP_INLINE_VISIBILITY 2454 void __release_shared() _NOEXCEPT { 2455 if (__shared_count::__release_shared()) 2456 __release_weak(); 2457 } 2458#endif 2459 void __release_weak() _NOEXCEPT; 2460 _LIBCPP_INLINE_VISIBILITY 2461 long use_count() const _NOEXCEPT {return __shared_count::use_count();} 2462 __shared_weak_count* lock() _NOEXCEPT; 2463 2464 virtual const void* __get_deleter(const type_info&) const _NOEXCEPT; 2465private: 2466 virtual void __on_zero_shared_weak() _NOEXCEPT = 0; 2467}; 2468 2469template <class _Tp, class _Dp, class _Alloc> 2470class __shared_ptr_pointer 2471 : public __shared_weak_count 2472{ 2473 __compressed_pair<__compressed_pair<_Tp, _Dp>, _Alloc> __data_; 2474public: 2475 _LIBCPP_INLINE_VISIBILITY 2476 __shared_ptr_pointer(_Tp __p, _Dp __d, _Alloc __a) 2477 : __data_(__compressed_pair<_Tp, _Dp>(__p, _VSTD::move(__d)), _VSTD::move(__a)) {} 2478 2479#ifndef _LIBCPP_NO_RTTI 2480 virtual const void* __get_deleter(const type_info&) const _NOEXCEPT; 2481#endif 2482 2483private: 2484 virtual void __on_zero_shared() _NOEXCEPT; 2485 virtual void __on_zero_shared_weak() _NOEXCEPT; 2486}; 2487 2488#ifndef _LIBCPP_NO_RTTI 2489 2490template <class _Tp, class _Dp, class _Alloc> 2491const void* 2492__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__get_deleter(const type_info& __t) const _NOEXCEPT 2493{ 2494 return __t == typeid(_Dp) ? _VSTD::addressof(__data_.first().second()) : nullptr; 2495} 2496 2497#endif // _LIBCPP_NO_RTTI 2498 2499template <class _Tp, class _Dp, class _Alloc> 2500void 2501__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__on_zero_shared() _NOEXCEPT 2502{ 2503 __data_.first().second()(__data_.first().first()); 2504 __data_.first().second().~_Dp(); 2505} 2506 2507template <class _Tp, class _Dp, class _Alloc> 2508void 2509__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__on_zero_shared_weak() _NOEXCEPT 2510{ 2511 typedef typename __allocator_traits_rebind<_Alloc, __shared_ptr_pointer>::type _Al; 2512 typedef allocator_traits<_Al> _ATraits; 2513 typedef pointer_traits<typename _ATraits::pointer> _PTraits; 2514 2515 _Al __a(__data_.second()); 2516 __data_.second().~_Alloc(); 2517 __a.deallocate(_PTraits::pointer_to(*this), 1); 2518} 2519 2520template <class _Tp, class _Alloc> 2521struct __shared_ptr_emplace 2522 : __shared_weak_count 2523{ 2524 template<class ..._Args> 2525 _LIBCPP_HIDE_FROM_ABI 2526 explicit __shared_ptr_emplace(_Alloc __a, _Args&& ...__args) 2527 : __storage_(_VSTD::move(__a)) 2528 { 2529#if _LIBCPP_STD_VER > 17 2530 using _TpAlloc = typename __allocator_traits_rebind<_Alloc, _Tp>::type; 2531 _TpAlloc __tmp(*__get_alloc()); 2532 allocator_traits<_TpAlloc>::construct(__tmp, __get_elem(), _VSTD::forward<_Args>(__args)...); 2533#else 2534 ::new ((void*)__get_elem()) _Tp(_VSTD::forward<_Args>(__args)...); 2535#endif 2536 } 2537 2538 _LIBCPP_HIDE_FROM_ABI 2539 _Alloc* __get_alloc() _NOEXCEPT { return __storage_.__get_alloc(); } 2540 2541 _LIBCPP_HIDE_FROM_ABI 2542 _Tp* __get_elem() _NOEXCEPT { return __storage_.__get_elem(); } 2543 2544private: 2545 virtual void __on_zero_shared() _NOEXCEPT { 2546#if _LIBCPP_STD_VER > 17 2547 using _TpAlloc = typename __allocator_traits_rebind<_Alloc, _Tp>::type; 2548 _TpAlloc __tmp(*__get_alloc()); 2549 allocator_traits<_TpAlloc>::destroy(__tmp, __get_elem()); 2550#else 2551 __get_elem()->~_Tp(); 2552#endif 2553 } 2554 2555 virtual void __on_zero_shared_weak() _NOEXCEPT { 2556 using _ControlBlockAlloc = typename __allocator_traits_rebind<_Alloc, __shared_ptr_emplace>::type; 2557 using _ControlBlockPointer = typename allocator_traits<_ControlBlockAlloc>::pointer; 2558 _ControlBlockAlloc __tmp(*__get_alloc()); 2559 __storage_.~_Storage(); 2560 allocator_traits<_ControlBlockAlloc>::deallocate(__tmp, 2561 pointer_traits<_ControlBlockPointer>::pointer_to(*this), 1); 2562 } 2563 2564 // This class implements the control block for non-array shared pointers created 2565 // through `std::allocate_shared` and `std::make_shared`. 2566 // 2567 // In previous versions of the library, we used a compressed pair to store 2568 // both the _Alloc and the _Tp. This implies using EBO, which is incompatible 2569 // with Allocator construction for _Tp. To allow implementing P0674 in C++20, 2570 // we now use a properly aligned char buffer while making sure that we maintain 2571 // the same layout that we had when we used a compressed pair. 2572 using _CompressedPair = __compressed_pair<_Alloc, _Tp>; 2573 struct _ALIGNAS_TYPE(_CompressedPair) _Storage { 2574 char __blob_[sizeof(_CompressedPair)]; 2575 2576 _LIBCPP_HIDE_FROM_ABI explicit _Storage(_Alloc&& __a) { 2577 ::new ((void*)__get_alloc()) _Alloc(_VSTD::move(__a)); 2578 } 2579 _LIBCPP_HIDE_FROM_ABI ~_Storage() { 2580 __get_alloc()->~_Alloc(); 2581 } 2582 _Alloc* __get_alloc() _NOEXCEPT { 2583 _CompressedPair *__as_pair = reinterpret_cast<_CompressedPair*>(__blob_); 2584 typename _CompressedPair::_Base1* __first = _CompressedPair::__get_first_base(__as_pair); 2585 _Alloc *__alloc = reinterpret_cast<_Alloc*>(__first); 2586 return __alloc; 2587 } 2588 _LIBCPP_NO_CFI _Tp* __get_elem() _NOEXCEPT { 2589 _CompressedPair *__as_pair = reinterpret_cast<_CompressedPair*>(__blob_); 2590 typename _CompressedPair::_Base2* __second = _CompressedPair::__get_second_base(__as_pair); 2591 _Tp *__elem = reinterpret_cast<_Tp*>(__second); 2592 return __elem; 2593 } 2594 }; 2595 2596 static_assert(_LIBCPP_ALIGNOF(_Storage) == _LIBCPP_ALIGNOF(_CompressedPair), ""); 2597 static_assert(sizeof(_Storage) == sizeof(_CompressedPair), ""); 2598 _Storage __storage_; 2599}; 2600 2601struct __shared_ptr_dummy_rebind_allocator_type; 2602template <> 2603class _LIBCPP_TEMPLATE_VIS allocator<__shared_ptr_dummy_rebind_allocator_type> 2604{ 2605public: 2606 template <class _Other> 2607 struct rebind 2608 { 2609 typedef allocator<_Other> other; 2610 }; 2611}; 2612 2613template<class _Tp> class _LIBCPP_TEMPLATE_VIS enable_shared_from_this; 2614 2615template<class _Tp, class _Up> 2616struct __compatible_with 2617#if _LIBCPP_STD_VER > 14 2618 : is_convertible<remove_extent_t<_Tp>*, remove_extent_t<_Up>*> {}; 2619#else 2620 : is_convertible<_Tp*, _Up*> {}; 2621#endif // _LIBCPP_STD_VER > 14 2622 2623template <class _Dp, class _Pt, 2624 class = decltype(_VSTD::declval<_Dp>()(_VSTD::declval<_Pt>()))> 2625static true_type __well_formed_deleter_test(int); 2626 2627template <class, class> 2628static false_type __well_formed_deleter_test(...); 2629 2630template <class _Dp, class _Pt> 2631struct __well_formed_deleter : decltype(__well_formed_deleter_test<_Dp, _Pt>(0)) {}; 2632 2633template<class _Dp, class _Tp, class _Yp> 2634struct __shared_ptr_deleter_ctor_reqs 2635{ 2636 static const bool value = __compatible_with<_Tp, _Yp>::value && 2637 is_move_constructible<_Dp>::value && 2638 __well_formed_deleter<_Dp, _Tp*>::value; 2639}; 2640 2641#if defined(_LIBCPP_ABI_ENABLE_SHARED_PTR_TRIVIAL_ABI) 2642# define _LIBCPP_SHARED_PTR_TRIVIAL_ABI __attribute__((trivial_abi)) 2643#else 2644# define _LIBCPP_SHARED_PTR_TRIVIAL_ABI 2645#endif 2646 2647template<class _Tp> 2648class _LIBCPP_SHARED_PTR_TRIVIAL_ABI _LIBCPP_TEMPLATE_VIS shared_ptr 2649{ 2650public: 2651#if _LIBCPP_STD_VER > 14 2652 typedef weak_ptr<_Tp> weak_type; 2653 typedef remove_extent_t<_Tp> element_type; 2654#else 2655 typedef _Tp element_type; 2656#endif 2657 2658private: 2659 element_type* __ptr_; 2660 __shared_weak_count* __cntrl_; 2661 2662 struct __nat {int __for_bool_;}; 2663public: 2664 _LIBCPP_INLINE_VISIBILITY 2665 _LIBCPP_CONSTEXPR shared_ptr() _NOEXCEPT; 2666 _LIBCPP_INLINE_VISIBILITY 2667 _LIBCPP_CONSTEXPR shared_ptr(nullptr_t) _NOEXCEPT; 2668 template<class _Yp> 2669 explicit shared_ptr(_Yp* __p, 2670 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type = __nat()); 2671 template<class _Yp, class _Dp> 2672 shared_ptr(_Yp* __p, _Dp __d, 2673 typename enable_if<__shared_ptr_deleter_ctor_reqs<_Dp, _Yp, element_type>::value, __nat>::type = __nat()); 2674 template<class _Yp, class _Dp, class _Alloc> 2675 shared_ptr(_Yp* __p, _Dp __d, _Alloc __a, 2676 typename enable_if<__shared_ptr_deleter_ctor_reqs<_Dp, _Yp, element_type>::value, __nat>::type = __nat()); 2677 template <class _Dp> shared_ptr(nullptr_t __p, _Dp __d); 2678 template <class _Dp, class _Alloc> shared_ptr(nullptr_t __p, _Dp __d, _Alloc __a); 2679 template<class _Yp> _LIBCPP_INLINE_VISIBILITY shared_ptr(const shared_ptr<_Yp>& __r, element_type* __p) _NOEXCEPT; 2680 _LIBCPP_INLINE_VISIBILITY 2681 shared_ptr(const shared_ptr& __r) _NOEXCEPT; 2682 template<class _Yp> 2683 _LIBCPP_INLINE_VISIBILITY 2684 shared_ptr(const shared_ptr<_Yp>& __r, 2685 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type = __nat()) 2686 _NOEXCEPT; 2687 _LIBCPP_INLINE_VISIBILITY 2688 shared_ptr(shared_ptr&& __r) _NOEXCEPT; 2689 template<class _Yp> _LIBCPP_INLINE_VISIBILITY shared_ptr(shared_ptr<_Yp>&& __r, 2690 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type = __nat()) 2691 _NOEXCEPT; 2692 template<class _Yp> explicit shared_ptr(const weak_ptr<_Yp>& __r, 2693 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type= __nat()); 2694#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 2695 template<class _Yp> 2696 shared_ptr(auto_ptr<_Yp>&& __r, 2697 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 2698#endif 2699 template <class _Yp, class _Dp> 2700 shared_ptr(unique_ptr<_Yp, _Dp>&&, 2701 typename enable_if 2702 < 2703 !is_lvalue_reference<_Dp>::value && 2704 !is_array<_Yp>::value && 2705 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 2706 __nat 2707 >::type = __nat()); 2708 template <class _Yp, class _Dp> 2709 shared_ptr(unique_ptr<_Yp, _Dp>&&, 2710 typename enable_if 2711 < 2712 is_lvalue_reference<_Dp>::value && 2713 !is_array<_Yp>::value && 2714 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 2715 __nat 2716 >::type = __nat()); 2717 2718 ~shared_ptr(); 2719 2720 _LIBCPP_INLINE_VISIBILITY 2721 shared_ptr& operator=(const shared_ptr& __r) _NOEXCEPT; 2722 template<class _Yp> 2723 typename enable_if 2724 < 2725 __compatible_with<_Yp, element_type>::value, 2726 shared_ptr& 2727 >::type 2728 _LIBCPP_INLINE_VISIBILITY 2729 operator=(const shared_ptr<_Yp>& __r) _NOEXCEPT; 2730 _LIBCPP_INLINE_VISIBILITY 2731 shared_ptr& operator=(shared_ptr&& __r) _NOEXCEPT; 2732 template<class _Yp> 2733 typename enable_if 2734 < 2735 __compatible_with<_Yp, element_type>::value, 2736 shared_ptr& 2737 >::type 2738 _LIBCPP_INLINE_VISIBILITY 2739 operator=(shared_ptr<_Yp>&& __r); 2740#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 2741 template<class _Yp> 2742 _LIBCPP_INLINE_VISIBILITY 2743 typename enable_if 2744 < 2745 !is_array<_Yp>::value && 2746 is_convertible<_Yp*, element_type*>::value, 2747 shared_ptr 2748 >::type& 2749 operator=(auto_ptr<_Yp>&& __r); 2750#endif 2751 template <class _Yp, class _Dp> 2752 typename enable_if 2753 < 2754 !is_array<_Yp>::value && 2755 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 2756 shared_ptr& 2757 >::type 2758 _LIBCPP_INLINE_VISIBILITY 2759 operator=(unique_ptr<_Yp, _Dp>&& __r); 2760 2761 _LIBCPP_INLINE_VISIBILITY 2762 void swap(shared_ptr& __r) _NOEXCEPT; 2763 _LIBCPP_INLINE_VISIBILITY 2764 void reset() _NOEXCEPT; 2765 template<class _Yp> 2766 typename enable_if 2767 < 2768 __compatible_with<_Yp, element_type>::value, 2769 void 2770 >::type 2771 _LIBCPP_INLINE_VISIBILITY 2772 reset(_Yp* __p); 2773 template<class _Yp, class _Dp> 2774 typename enable_if 2775 < 2776 __compatible_with<_Yp, element_type>::value, 2777 void 2778 >::type 2779 _LIBCPP_INLINE_VISIBILITY 2780 reset(_Yp* __p, _Dp __d); 2781 template<class _Yp, class _Dp, class _Alloc> 2782 typename enable_if 2783 < 2784 __compatible_with<_Yp, element_type>::value, 2785 void 2786 >::type 2787 _LIBCPP_INLINE_VISIBILITY 2788 reset(_Yp* __p, _Dp __d, _Alloc __a); 2789 2790 _LIBCPP_INLINE_VISIBILITY 2791 element_type* get() const _NOEXCEPT {return __ptr_;} 2792 _LIBCPP_INLINE_VISIBILITY 2793 typename add_lvalue_reference<element_type>::type operator*() const _NOEXCEPT 2794 {return *__ptr_;} 2795 _LIBCPP_INLINE_VISIBILITY 2796 element_type* operator->() const _NOEXCEPT 2797 { 2798 static_assert(!_VSTD::is_array<_Tp>::value, 2799 "std::shared_ptr<T>::operator-> is only valid when T is not an array type."); 2800 return __ptr_; 2801 } 2802 _LIBCPP_INLINE_VISIBILITY 2803 long use_count() const _NOEXCEPT {return __cntrl_ ? __cntrl_->use_count() : 0;} 2804 _LIBCPP_INLINE_VISIBILITY 2805 bool unique() const _NOEXCEPT {return use_count() == 1;} 2806 _LIBCPP_INLINE_VISIBILITY 2807 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT {return get() != nullptr;} 2808 template <class _Up> 2809 _LIBCPP_INLINE_VISIBILITY 2810 bool owner_before(shared_ptr<_Up> const& __p) const _NOEXCEPT 2811 {return __cntrl_ < __p.__cntrl_;} 2812 template <class _Up> 2813 _LIBCPP_INLINE_VISIBILITY 2814 bool owner_before(weak_ptr<_Up> const& __p) const _NOEXCEPT 2815 {return __cntrl_ < __p.__cntrl_;} 2816 _LIBCPP_INLINE_VISIBILITY 2817 bool 2818 __owner_equivalent(const shared_ptr& __p) const 2819 {return __cntrl_ == __p.__cntrl_;} 2820 2821#if _LIBCPP_STD_VER > 14 2822 typename add_lvalue_reference<element_type>::type 2823 _LIBCPP_INLINE_VISIBILITY 2824 operator[](ptrdiff_t __i) const 2825 { 2826 static_assert(_VSTD::is_array<_Tp>::value, 2827 "std::shared_ptr<T>::operator[] is only valid when T is an array type."); 2828 return __ptr_[__i]; 2829 } 2830#endif 2831 2832#ifndef _LIBCPP_NO_RTTI 2833 template <class _Dp> 2834 _LIBCPP_INLINE_VISIBILITY 2835 _Dp* __get_deleter() const _NOEXCEPT 2836 {return static_cast<_Dp*>(__cntrl_ 2837 ? const_cast<void *>(__cntrl_->__get_deleter(typeid(_Dp))) 2838 : nullptr);} 2839#endif // _LIBCPP_NO_RTTI 2840 2841 template<class _Yp, class _CntrlBlk> 2842 static shared_ptr<_Tp> 2843 __create_with_control_block(_Yp* __p, _CntrlBlk* __cntrl) _NOEXCEPT 2844 { 2845 shared_ptr<_Tp> __r; 2846 __r.__ptr_ = __p; 2847 __r.__cntrl_ = __cntrl; 2848 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 2849 return __r; 2850 } 2851 2852private: 2853 template <class _Yp, bool = is_function<_Yp>::value> 2854 struct __shared_ptr_default_allocator 2855 { 2856 typedef allocator<_Yp> type; 2857 }; 2858 2859 template <class _Yp> 2860 struct __shared_ptr_default_allocator<_Yp, true> 2861 { 2862 typedef allocator<__shared_ptr_dummy_rebind_allocator_type> type; 2863 }; 2864 2865 template <class _Yp, class _OrigPtr> 2866 _LIBCPP_INLINE_VISIBILITY 2867 typename enable_if<is_convertible<_OrigPtr*, 2868 const enable_shared_from_this<_Yp>* 2869 >::value, 2870 void>::type 2871 __enable_weak_this(const enable_shared_from_this<_Yp>* __e, 2872 _OrigPtr* __ptr) _NOEXCEPT 2873 { 2874 typedef typename remove_cv<_Yp>::type _RawYp; 2875 if (__e && __e->__weak_this_.expired()) 2876 { 2877 __e->__weak_this_ = shared_ptr<_RawYp>(*this, 2878 const_cast<_RawYp*>(static_cast<const _Yp*>(__ptr))); 2879 } 2880 } 2881 2882 _LIBCPP_INLINE_VISIBILITY void __enable_weak_this(...) _NOEXCEPT {} 2883 2884 template <class, class _Yp> 2885 struct __shared_ptr_default_delete 2886 : default_delete<_Yp> {}; 2887 2888 template <class _Yp, class _Un, size_t _Sz> 2889 struct __shared_ptr_default_delete<_Yp[_Sz], _Un> 2890 : default_delete<_Yp[]> {}; 2891 2892 template <class _Yp, class _Un> 2893 struct __shared_ptr_default_delete<_Yp[], _Un> 2894 : default_delete<_Yp[]> {}; 2895 2896 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS shared_ptr; 2897 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS weak_ptr; 2898}; 2899 2900#ifndef _LIBCPP_HAS_NO_DEDUCTION_GUIDES 2901template<class _Tp> 2902shared_ptr(weak_ptr<_Tp>) -> shared_ptr<_Tp>; 2903template<class _Tp, class _Dp> 2904shared_ptr(unique_ptr<_Tp, _Dp>) -> shared_ptr<_Tp>; 2905#endif 2906 2907template<class _Tp> 2908inline 2909_LIBCPP_CONSTEXPR 2910shared_ptr<_Tp>::shared_ptr() _NOEXCEPT 2911 : __ptr_(nullptr), 2912 __cntrl_(nullptr) 2913{ 2914} 2915 2916template<class _Tp> 2917inline 2918_LIBCPP_CONSTEXPR 2919shared_ptr<_Tp>::shared_ptr(nullptr_t) _NOEXCEPT 2920 : __ptr_(nullptr), 2921 __cntrl_(nullptr) 2922{ 2923} 2924 2925template<class _Tp> 2926template<class _Yp> 2927shared_ptr<_Tp>::shared_ptr(_Yp* __p, 2928 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type) 2929 : __ptr_(__p) 2930{ 2931 unique_ptr<_Yp> __hold(__p); 2932 typedef typename __shared_ptr_default_allocator<_Yp>::type _AllocT; 2933 typedef __shared_ptr_pointer<_Yp*, __shared_ptr_default_delete<_Tp, _Yp>, _AllocT > _CntrlBlk; 2934 __cntrl_ = new _CntrlBlk(__p, __shared_ptr_default_delete<_Tp, _Yp>(), _AllocT()); 2935 __hold.release(); 2936 __enable_weak_this(__p, __p); 2937} 2938 2939template<class _Tp> 2940template<class _Yp, class _Dp> 2941shared_ptr<_Tp>::shared_ptr(_Yp* __p, _Dp __d, 2942 typename enable_if<__shared_ptr_deleter_ctor_reqs<_Dp, _Yp, element_type>::value, __nat>::type) 2943 : __ptr_(__p) 2944{ 2945#ifndef _LIBCPP_NO_EXCEPTIONS 2946 try 2947 { 2948#endif // _LIBCPP_NO_EXCEPTIONS 2949 typedef typename __shared_ptr_default_allocator<_Yp>::type _AllocT; 2950 typedef __shared_ptr_pointer<_Yp*, _Dp, _AllocT > _CntrlBlk; 2951#ifndef _LIBCPP_CXX03_LANG 2952 __cntrl_ = new _CntrlBlk(__p, _VSTD::move(__d), _AllocT()); 2953#else 2954 __cntrl_ = new _CntrlBlk(__p, __d, _AllocT()); 2955#endif // not _LIBCPP_CXX03_LANG 2956 __enable_weak_this(__p, __p); 2957#ifndef _LIBCPP_NO_EXCEPTIONS 2958 } 2959 catch (...) 2960 { 2961 __d(__p); 2962 throw; 2963 } 2964#endif // _LIBCPP_NO_EXCEPTIONS 2965} 2966 2967template<class _Tp> 2968template<class _Dp> 2969shared_ptr<_Tp>::shared_ptr(nullptr_t __p, _Dp __d) 2970 : __ptr_(nullptr) 2971{ 2972#ifndef _LIBCPP_NO_EXCEPTIONS 2973 try 2974 { 2975#endif // _LIBCPP_NO_EXCEPTIONS 2976 typedef typename __shared_ptr_default_allocator<_Tp>::type _AllocT; 2977 typedef __shared_ptr_pointer<nullptr_t, _Dp, _AllocT > _CntrlBlk; 2978#ifndef _LIBCPP_CXX03_LANG 2979 __cntrl_ = new _CntrlBlk(__p, _VSTD::move(__d), _AllocT()); 2980#else 2981 __cntrl_ = new _CntrlBlk(__p, __d, _AllocT()); 2982#endif // not _LIBCPP_CXX03_LANG 2983#ifndef _LIBCPP_NO_EXCEPTIONS 2984 } 2985 catch (...) 2986 { 2987 __d(__p); 2988 throw; 2989 } 2990#endif // _LIBCPP_NO_EXCEPTIONS 2991} 2992 2993template<class _Tp> 2994template<class _Yp, class _Dp, class _Alloc> 2995shared_ptr<_Tp>::shared_ptr(_Yp* __p, _Dp __d, _Alloc __a, 2996 typename enable_if<__shared_ptr_deleter_ctor_reqs<_Dp, _Yp, element_type>::value, __nat>::type) 2997 : __ptr_(__p) 2998{ 2999#ifndef _LIBCPP_NO_EXCEPTIONS 3000 try 3001 { 3002#endif // _LIBCPP_NO_EXCEPTIONS 3003 typedef __shared_ptr_pointer<_Yp*, _Dp, _Alloc> _CntrlBlk; 3004 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _A2; 3005 typedef __allocator_destructor<_A2> _D2; 3006 _A2 __a2(__a); 3007 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 3008 ::new ((void*)_VSTD::addressof(*__hold2.get())) 3009#ifndef _LIBCPP_CXX03_LANG 3010 _CntrlBlk(__p, _VSTD::move(__d), __a); 3011#else 3012 _CntrlBlk(__p, __d, __a); 3013#endif // not _LIBCPP_CXX03_LANG 3014 __cntrl_ = _VSTD::addressof(*__hold2.release()); 3015 __enable_weak_this(__p, __p); 3016#ifndef _LIBCPP_NO_EXCEPTIONS 3017 } 3018 catch (...) 3019 { 3020 __d(__p); 3021 throw; 3022 } 3023#endif // _LIBCPP_NO_EXCEPTIONS 3024} 3025 3026template<class _Tp> 3027template<class _Dp, class _Alloc> 3028shared_ptr<_Tp>::shared_ptr(nullptr_t __p, _Dp __d, _Alloc __a) 3029 : __ptr_(nullptr) 3030{ 3031#ifndef _LIBCPP_NO_EXCEPTIONS 3032 try 3033 { 3034#endif // _LIBCPP_NO_EXCEPTIONS 3035 typedef __shared_ptr_pointer<nullptr_t, _Dp, _Alloc> _CntrlBlk; 3036 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _A2; 3037 typedef __allocator_destructor<_A2> _D2; 3038 _A2 __a2(__a); 3039 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 3040 ::new ((void*)_VSTD::addressof(*__hold2.get())) 3041#ifndef _LIBCPP_CXX03_LANG 3042 _CntrlBlk(__p, _VSTD::move(__d), __a); 3043#else 3044 _CntrlBlk(__p, __d, __a); 3045#endif // not _LIBCPP_CXX03_LANG 3046 __cntrl_ = _VSTD::addressof(*__hold2.release()); 3047#ifndef _LIBCPP_NO_EXCEPTIONS 3048 } 3049 catch (...) 3050 { 3051 __d(__p); 3052 throw; 3053 } 3054#endif // _LIBCPP_NO_EXCEPTIONS 3055} 3056 3057template<class _Tp> 3058template<class _Yp> 3059inline 3060shared_ptr<_Tp>::shared_ptr(const shared_ptr<_Yp>& __r, element_type *__p) _NOEXCEPT 3061 : __ptr_(__p), 3062 __cntrl_(__r.__cntrl_) 3063{ 3064 if (__cntrl_) 3065 __cntrl_->__add_shared(); 3066} 3067 3068template<class _Tp> 3069inline 3070shared_ptr<_Tp>::shared_ptr(const shared_ptr& __r) _NOEXCEPT 3071 : __ptr_(__r.__ptr_), 3072 __cntrl_(__r.__cntrl_) 3073{ 3074 if (__cntrl_) 3075 __cntrl_->__add_shared(); 3076} 3077 3078template<class _Tp> 3079template<class _Yp> 3080inline 3081shared_ptr<_Tp>::shared_ptr(const shared_ptr<_Yp>& __r, 3082 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type) 3083 _NOEXCEPT 3084 : __ptr_(__r.__ptr_), 3085 __cntrl_(__r.__cntrl_) 3086{ 3087 if (__cntrl_) 3088 __cntrl_->__add_shared(); 3089} 3090 3091template<class _Tp> 3092inline 3093shared_ptr<_Tp>::shared_ptr(shared_ptr&& __r) _NOEXCEPT 3094 : __ptr_(__r.__ptr_), 3095 __cntrl_(__r.__cntrl_) 3096{ 3097 __r.__ptr_ = nullptr; 3098 __r.__cntrl_ = nullptr; 3099} 3100 3101template<class _Tp> 3102template<class _Yp> 3103inline 3104shared_ptr<_Tp>::shared_ptr(shared_ptr<_Yp>&& __r, 3105 typename enable_if<__compatible_with<_Yp, element_type>::value, __nat>::type) 3106 _NOEXCEPT 3107 : __ptr_(__r.__ptr_), 3108 __cntrl_(__r.__cntrl_) 3109{ 3110 __r.__ptr_ = nullptr; 3111 __r.__cntrl_ = nullptr; 3112} 3113 3114#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 3115template<class _Tp> 3116template<class _Yp> 3117shared_ptr<_Tp>::shared_ptr(auto_ptr<_Yp>&& __r, 3118 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 3119 : __ptr_(__r.get()) 3120{ 3121 typedef __shared_ptr_pointer<_Yp*, default_delete<_Yp>, allocator<_Yp> > _CntrlBlk; 3122 __cntrl_ = new _CntrlBlk(__r.get(), default_delete<_Yp>(), allocator<_Yp>()); 3123 __enable_weak_this(__r.get(), __r.get()); 3124 __r.release(); 3125} 3126#endif 3127 3128template<class _Tp> 3129template <class _Yp, class _Dp> 3130shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp>&& __r, 3131 typename enable_if 3132 < 3133 !is_lvalue_reference<_Dp>::value && 3134 !is_array<_Yp>::value && 3135 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3136 __nat 3137 >::type) 3138 : __ptr_(__r.get()) 3139{ 3140#if _LIBCPP_STD_VER > 11 3141 if (__ptr_ == nullptr) 3142 __cntrl_ = nullptr; 3143 else 3144#endif 3145 { 3146 typedef typename __shared_ptr_default_allocator<_Yp>::type _AllocT; 3147 typedef __shared_ptr_pointer<_Yp*, _Dp, _AllocT > _CntrlBlk; 3148 __cntrl_ = new _CntrlBlk(__r.get(), __r.get_deleter(), _AllocT()); 3149 __enable_weak_this(__r.get(), __r.get()); 3150 } 3151 __r.release(); 3152} 3153 3154template<class _Tp> 3155template <class _Yp, class _Dp> 3156shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp>&& __r, 3157 typename enable_if 3158 < 3159 is_lvalue_reference<_Dp>::value && 3160 !is_array<_Yp>::value && 3161 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3162 __nat 3163 >::type) 3164 : __ptr_(__r.get()) 3165{ 3166#if _LIBCPP_STD_VER > 11 3167 if (__ptr_ == nullptr) 3168 __cntrl_ = nullptr; 3169 else 3170#endif 3171 { 3172 typedef typename __shared_ptr_default_allocator<_Yp>::type _AllocT; 3173 typedef __shared_ptr_pointer<_Yp*, 3174 reference_wrapper<typename remove_reference<_Dp>::type>, 3175 _AllocT > _CntrlBlk; 3176 __cntrl_ = new _CntrlBlk(__r.get(), _VSTD::ref(__r.get_deleter()), _AllocT()); 3177 __enable_weak_this(__r.get(), __r.get()); 3178 } 3179 __r.release(); 3180} 3181 3182template<class _Tp> 3183shared_ptr<_Tp>::~shared_ptr() 3184{ 3185 if (__cntrl_) 3186 __cntrl_->__release_shared(); 3187} 3188 3189template<class _Tp> 3190inline 3191shared_ptr<_Tp>& 3192shared_ptr<_Tp>::operator=(const shared_ptr& __r) _NOEXCEPT 3193{ 3194 shared_ptr(__r).swap(*this); 3195 return *this; 3196} 3197 3198template<class _Tp> 3199template<class _Yp> 3200inline 3201typename enable_if 3202< 3203 __compatible_with<_Yp, typename shared_ptr<_Tp>::element_type>::value, 3204 shared_ptr<_Tp>& 3205>::type 3206shared_ptr<_Tp>::operator=(const shared_ptr<_Yp>& __r) _NOEXCEPT 3207{ 3208 shared_ptr(__r).swap(*this); 3209 return *this; 3210} 3211 3212template<class _Tp> 3213inline 3214shared_ptr<_Tp>& 3215shared_ptr<_Tp>::operator=(shared_ptr&& __r) _NOEXCEPT 3216{ 3217 shared_ptr(_VSTD::move(__r)).swap(*this); 3218 return *this; 3219} 3220 3221template<class _Tp> 3222template<class _Yp> 3223inline 3224typename enable_if 3225< 3226 __compatible_with<_Yp, typename shared_ptr<_Tp>::element_type>::value, 3227 shared_ptr<_Tp>& 3228>::type 3229shared_ptr<_Tp>::operator=(shared_ptr<_Yp>&& __r) 3230{ 3231 shared_ptr(_VSTD::move(__r)).swap(*this); 3232 return *this; 3233} 3234 3235#if _LIBCPP_STD_VER <= 14 || defined(_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR) 3236template<class _Tp> 3237template<class _Yp> 3238inline 3239typename enable_if 3240< 3241 !is_array<_Yp>::value && 3242 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 3243 shared_ptr<_Tp> 3244>::type& 3245shared_ptr<_Tp>::operator=(auto_ptr<_Yp>&& __r) 3246{ 3247 shared_ptr(_VSTD::move(__r)).swap(*this); 3248 return *this; 3249} 3250#endif 3251 3252template<class _Tp> 3253template <class _Yp, class _Dp> 3254inline 3255typename enable_if 3256< 3257 !is_array<_Yp>::value && 3258 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, 3259 typename shared_ptr<_Tp>::element_type*>::value, 3260 shared_ptr<_Tp>& 3261>::type 3262shared_ptr<_Tp>::operator=(unique_ptr<_Yp, _Dp>&& __r) 3263{ 3264 shared_ptr(_VSTD::move(__r)).swap(*this); 3265 return *this; 3266} 3267 3268template<class _Tp> 3269inline 3270void 3271shared_ptr<_Tp>::swap(shared_ptr& __r) _NOEXCEPT 3272{ 3273 _VSTD::swap(__ptr_, __r.__ptr_); 3274 _VSTD::swap(__cntrl_, __r.__cntrl_); 3275} 3276 3277template<class _Tp> 3278inline 3279void 3280shared_ptr<_Tp>::reset() _NOEXCEPT 3281{ 3282 shared_ptr().swap(*this); 3283} 3284 3285template<class _Tp> 3286template<class _Yp> 3287inline 3288typename enable_if 3289< 3290 __compatible_with<_Yp, typename shared_ptr<_Tp>::element_type>::value, 3291 void 3292>::type 3293shared_ptr<_Tp>::reset(_Yp* __p) 3294{ 3295 shared_ptr(__p).swap(*this); 3296} 3297 3298template<class _Tp> 3299template<class _Yp, class _Dp> 3300inline 3301typename enable_if 3302< 3303 __compatible_with<_Yp, typename shared_ptr<_Tp>::element_type>::value, 3304 void 3305>::type 3306shared_ptr<_Tp>::reset(_Yp* __p, _Dp __d) 3307{ 3308 shared_ptr(__p, __d).swap(*this); 3309} 3310 3311template<class _Tp> 3312template<class _Yp, class _Dp, class _Alloc> 3313inline 3314typename enable_if 3315< 3316 __compatible_with<_Yp, typename shared_ptr<_Tp>::element_type>::value, 3317 void 3318>::type 3319shared_ptr<_Tp>::reset(_Yp* __p, _Dp __d, _Alloc __a) 3320{ 3321 shared_ptr(__p, __d, __a).swap(*this); 3322} 3323 3324// 3325// std::allocate_shared and std::make_shared 3326// 3327template<class _Tp, class _Alloc, class ..._Args, class = _EnableIf<!is_array<_Tp>::value> > 3328_LIBCPP_HIDE_FROM_ABI 3329shared_ptr<_Tp> allocate_shared(const _Alloc& __a, _Args&& ...__args) 3330{ 3331 using _ControlBlock = __shared_ptr_emplace<_Tp, _Alloc>; 3332 using _ControlBlockAllocator = typename __allocator_traits_rebind<_Alloc, _ControlBlock>::type; 3333 __allocation_guard<_ControlBlockAllocator> __guard(__a, 1); 3334 ::new ((void*)_VSTD::addressof(*__guard.__get())) _ControlBlock(__a, _VSTD::forward<_Args>(__args)...); 3335 auto __control_block = __guard.__release_ptr(); 3336 return shared_ptr<_Tp>::__create_with_control_block((*__control_block).__get_elem(), _VSTD::addressof(*__control_block)); 3337} 3338 3339template<class _Tp, class ..._Args, class = _EnableIf<!is_array<_Tp>::value> > 3340_LIBCPP_HIDE_FROM_ABI 3341shared_ptr<_Tp> make_shared(_Args&& ...__args) 3342{ 3343 return _VSTD::allocate_shared<_Tp>(allocator<_Tp>(), _VSTD::forward<_Args>(__args)...); 3344} 3345 3346template<class _Tp, class _Up> 3347inline _LIBCPP_INLINE_VISIBILITY 3348bool 3349operator==(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3350{ 3351 return __x.get() == __y.get(); 3352} 3353 3354template<class _Tp, class _Up> 3355inline _LIBCPP_INLINE_VISIBILITY 3356bool 3357operator!=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3358{ 3359 return !(__x == __y); 3360} 3361 3362template<class _Tp, class _Up> 3363inline _LIBCPP_INLINE_VISIBILITY 3364bool 3365operator<(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3366{ 3367#if _LIBCPP_STD_VER <= 11 3368 typedef typename common_type<_Tp*, _Up*>::type _Vp; 3369 return less<_Vp>()(__x.get(), __y.get()); 3370#else 3371 return less<>()(__x.get(), __y.get()); 3372#endif 3373 3374} 3375 3376template<class _Tp, class _Up> 3377inline _LIBCPP_INLINE_VISIBILITY 3378bool 3379operator>(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3380{ 3381 return __y < __x; 3382} 3383 3384template<class _Tp, class _Up> 3385inline _LIBCPP_INLINE_VISIBILITY 3386bool 3387operator<=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3388{ 3389 return !(__y < __x); 3390} 3391 3392template<class _Tp, class _Up> 3393inline _LIBCPP_INLINE_VISIBILITY 3394bool 3395operator>=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 3396{ 3397 return !(__x < __y); 3398} 3399 3400template<class _Tp> 3401inline _LIBCPP_INLINE_VISIBILITY 3402bool 3403operator==(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3404{ 3405 return !__x; 3406} 3407 3408template<class _Tp> 3409inline _LIBCPP_INLINE_VISIBILITY 3410bool 3411operator==(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3412{ 3413 return !__x; 3414} 3415 3416template<class _Tp> 3417inline _LIBCPP_INLINE_VISIBILITY 3418bool 3419operator!=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3420{ 3421 return static_cast<bool>(__x); 3422} 3423 3424template<class _Tp> 3425inline _LIBCPP_INLINE_VISIBILITY 3426bool 3427operator!=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3428{ 3429 return static_cast<bool>(__x); 3430} 3431 3432template<class _Tp> 3433inline _LIBCPP_INLINE_VISIBILITY 3434bool 3435operator<(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3436{ 3437 return less<_Tp*>()(__x.get(), nullptr); 3438} 3439 3440template<class _Tp> 3441inline _LIBCPP_INLINE_VISIBILITY 3442bool 3443operator<(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3444{ 3445 return less<_Tp*>()(nullptr, __x.get()); 3446} 3447 3448template<class _Tp> 3449inline _LIBCPP_INLINE_VISIBILITY 3450bool 3451operator>(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3452{ 3453 return nullptr < __x; 3454} 3455 3456template<class _Tp> 3457inline _LIBCPP_INLINE_VISIBILITY 3458bool 3459operator>(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3460{ 3461 return __x < nullptr; 3462} 3463 3464template<class _Tp> 3465inline _LIBCPP_INLINE_VISIBILITY 3466bool 3467operator<=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3468{ 3469 return !(nullptr < __x); 3470} 3471 3472template<class _Tp> 3473inline _LIBCPP_INLINE_VISIBILITY 3474bool 3475operator<=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3476{ 3477 return !(__x < nullptr); 3478} 3479 3480template<class _Tp> 3481inline _LIBCPP_INLINE_VISIBILITY 3482bool 3483operator>=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 3484{ 3485 return !(__x < nullptr); 3486} 3487 3488template<class _Tp> 3489inline _LIBCPP_INLINE_VISIBILITY 3490bool 3491operator>=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 3492{ 3493 return !(nullptr < __x); 3494} 3495 3496template<class _Tp> 3497inline _LIBCPP_INLINE_VISIBILITY 3498void 3499swap(shared_ptr<_Tp>& __x, shared_ptr<_Tp>& __y) _NOEXCEPT 3500{ 3501 __x.swap(__y); 3502} 3503 3504template<class _Tp, class _Up> 3505inline _LIBCPP_INLINE_VISIBILITY 3506shared_ptr<_Tp> 3507static_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 3508{ 3509 return shared_ptr<_Tp>(__r, 3510 static_cast< 3511 typename shared_ptr<_Tp>::element_type*>(__r.get())); 3512} 3513 3514template<class _Tp, class _Up> 3515inline _LIBCPP_INLINE_VISIBILITY 3516shared_ptr<_Tp> 3517dynamic_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 3518{ 3519 typedef typename shared_ptr<_Tp>::element_type _ET; 3520 _ET* __p = dynamic_cast<_ET*>(__r.get()); 3521 return __p ? shared_ptr<_Tp>(__r, __p) : shared_ptr<_Tp>(); 3522} 3523 3524template<class _Tp, class _Up> 3525shared_ptr<_Tp> 3526const_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 3527{ 3528 typedef typename shared_ptr<_Tp>::element_type _RTp; 3529 return shared_ptr<_Tp>(__r, const_cast<_RTp*>(__r.get())); 3530} 3531 3532template<class _Tp, class _Up> 3533shared_ptr<_Tp> 3534reinterpret_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 3535{ 3536 return shared_ptr<_Tp>(__r, 3537 reinterpret_cast< 3538 typename shared_ptr<_Tp>::element_type*>(__r.get())); 3539} 3540 3541#ifndef _LIBCPP_NO_RTTI 3542 3543template<class _Dp, class _Tp> 3544inline _LIBCPP_INLINE_VISIBILITY 3545_Dp* 3546get_deleter(const shared_ptr<_Tp>& __p) _NOEXCEPT 3547{ 3548 return __p.template __get_deleter<_Dp>(); 3549} 3550 3551#endif // _LIBCPP_NO_RTTI 3552 3553template<class _Tp> 3554class _LIBCPP_SHARED_PTR_TRIVIAL_ABI _LIBCPP_TEMPLATE_VIS weak_ptr 3555{ 3556public: 3557 typedef _Tp element_type; 3558private: 3559 element_type* __ptr_; 3560 __shared_weak_count* __cntrl_; 3561 3562public: 3563 _LIBCPP_INLINE_VISIBILITY 3564 _LIBCPP_CONSTEXPR weak_ptr() _NOEXCEPT; 3565 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(shared_ptr<_Yp> const& __r, 3566 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 3567 _NOEXCEPT; 3568 _LIBCPP_INLINE_VISIBILITY 3569 weak_ptr(weak_ptr const& __r) _NOEXCEPT; 3570 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(weak_ptr<_Yp> const& __r, 3571 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 3572 _NOEXCEPT; 3573 3574 _LIBCPP_INLINE_VISIBILITY 3575 weak_ptr(weak_ptr&& __r) _NOEXCEPT; 3576 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(weak_ptr<_Yp>&& __r, 3577 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 3578 _NOEXCEPT; 3579 ~weak_ptr(); 3580 3581 _LIBCPP_INLINE_VISIBILITY 3582 weak_ptr& operator=(weak_ptr const& __r) _NOEXCEPT; 3583 template<class _Yp> 3584 typename enable_if 3585 < 3586 is_convertible<_Yp*, element_type*>::value, 3587 weak_ptr& 3588 >::type 3589 _LIBCPP_INLINE_VISIBILITY 3590 operator=(weak_ptr<_Yp> const& __r) _NOEXCEPT; 3591 3592 _LIBCPP_INLINE_VISIBILITY 3593 weak_ptr& operator=(weak_ptr&& __r) _NOEXCEPT; 3594 template<class _Yp> 3595 typename enable_if 3596 < 3597 is_convertible<_Yp*, element_type*>::value, 3598 weak_ptr& 3599 >::type 3600 _LIBCPP_INLINE_VISIBILITY 3601 operator=(weak_ptr<_Yp>&& __r) _NOEXCEPT; 3602 3603 template<class _Yp> 3604 typename enable_if 3605 < 3606 is_convertible<_Yp*, element_type*>::value, 3607 weak_ptr& 3608 >::type 3609 _LIBCPP_INLINE_VISIBILITY 3610 operator=(shared_ptr<_Yp> const& __r) _NOEXCEPT; 3611 3612 _LIBCPP_INLINE_VISIBILITY 3613 void swap(weak_ptr& __r) _NOEXCEPT; 3614 _LIBCPP_INLINE_VISIBILITY 3615 void reset() _NOEXCEPT; 3616 3617 _LIBCPP_INLINE_VISIBILITY 3618 long use_count() const _NOEXCEPT 3619 {return __cntrl_ ? __cntrl_->use_count() : 0;} 3620 _LIBCPP_INLINE_VISIBILITY 3621 bool expired() const _NOEXCEPT 3622 {return __cntrl_ == nullptr || __cntrl_->use_count() == 0;} 3623 shared_ptr<_Tp> lock() const _NOEXCEPT; 3624 template<class _Up> 3625 _LIBCPP_INLINE_VISIBILITY 3626 bool owner_before(const shared_ptr<_Up>& __r) const _NOEXCEPT 3627 {return __cntrl_ < __r.__cntrl_;} 3628 template<class _Up> 3629 _LIBCPP_INLINE_VISIBILITY 3630 bool owner_before(const weak_ptr<_Up>& __r) const _NOEXCEPT 3631 {return __cntrl_ < __r.__cntrl_;} 3632 3633 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS weak_ptr; 3634 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS shared_ptr; 3635}; 3636 3637#ifndef _LIBCPP_HAS_NO_DEDUCTION_GUIDES 3638template<class _Tp> 3639weak_ptr(shared_ptr<_Tp>) -> weak_ptr<_Tp>; 3640#endif 3641 3642template<class _Tp> 3643inline 3644_LIBCPP_CONSTEXPR 3645weak_ptr<_Tp>::weak_ptr() _NOEXCEPT 3646 : __ptr_(nullptr), 3647 __cntrl_(nullptr) 3648{ 3649} 3650 3651template<class _Tp> 3652inline 3653weak_ptr<_Tp>::weak_ptr(weak_ptr const& __r) _NOEXCEPT 3654 : __ptr_(__r.__ptr_), 3655 __cntrl_(__r.__cntrl_) 3656{ 3657 if (__cntrl_) 3658 __cntrl_->__add_weak(); 3659} 3660 3661template<class _Tp> 3662template<class _Yp> 3663inline 3664weak_ptr<_Tp>::weak_ptr(shared_ptr<_Yp> const& __r, 3665 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 3666 _NOEXCEPT 3667 : __ptr_(__r.__ptr_), 3668 __cntrl_(__r.__cntrl_) 3669{ 3670 if (__cntrl_) 3671 __cntrl_->__add_weak(); 3672} 3673 3674template<class _Tp> 3675template<class _Yp> 3676inline 3677weak_ptr<_Tp>::weak_ptr(weak_ptr<_Yp> const& __r, 3678 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 3679 _NOEXCEPT 3680 : __ptr_(__r.__ptr_), 3681 __cntrl_(__r.__cntrl_) 3682{ 3683 if (__cntrl_) 3684 __cntrl_->__add_weak(); 3685} 3686 3687template<class _Tp> 3688inline 3689weak_ptr<_Tp>::weak_ptr(weak_ptr&& __r) _NOEXCEPT 3690 : __ptr_(__r.__ptr_), 3691 __cntrl_(__r.__cntrl_) 3692{ 3693 __r.__ptr_ = nullptr; 3694 __r.__cntrl_ = nullptr; 3695} 3696 3697template<class _Tp> 3698template<class _Yp> 3699inline 3700weak_ptr<_Tp>::weak_ptr(weak_ptr<_Yp>&& __r, 3701 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 3702 _NOEXCEPT 3703 : __ptr_(__r.__ptr_), 3704 __cntrl_(__r.__cntrl_) 3705{ 3706 __r.__ptr_ = nullptr; 3707 __r.__cntrl_ = nullptr; 3708} 3709 3710template<class _Tp> 3711weak_ptr<_Tp>::~weak_ptr() 3712{ 3713 if (__cntrl_) 3714 __cntrl_->__release_weak(); 3715} 3716 3717template<class _Tp> 3718inline 3719weak_ptr<_Tp>& 3720weak_ptr<_Tp>::operator=(weak_ptr const& __r) _NOEXCEPT 3721{ 3722 weak_ptr(__r).swap(*this); 3723 return *this; 3724} 3725 3726template<class _Tp> 3727template<class _Yp> 3728inline 3729typename enable_if 3730< 3731 is_convertible<_Yp*, _Tp*>::value, 3732 weak_ptr<_Tp>& 3733>::type 3734weak_ptr<_Tp>::operator=(weak_ptr<_Yp> const& __r) _NOEXCEPT 3735{ 3736 weak_ptr(__r).swap(*this); 3737 return *this; 3738} 3739 3740template<class _Tp> 3741inline 3742weak_ptr<_Tp>& 3743weak_ptr<_Tp>::operator=(weak_ptr&& __r) _NOEXCEPT 3744{ 3745 weak_ptr(_VSTD::move(__r)).swap(*this); 3746 return *this; 3747} 3748 3749template<class _Tp> 3750template<class _Yp> 3751inline 3752typename enable_if 3753< 3754 is_convertible<_Yp*, _Tp*>::value, 3755 weak_ptr<_Tp>& 3756>::type 3757weak_ptr<_Tp>::operator=(weak_ptr<_Yp>&& __r) _NOEXCEPT 3758{ 3759 weak_ptr(_VSTD::move(__r)).swap(*this); 3760 return *this; 3761} 3762 3763template<class _Tp> 3764template<class _Yp> 3765inline 3766typename enable_if 3767< 3768 is_convertible<_Yp*, _Tp*>::value, 3769 weak_ptr<_Tp>& 3770>::type 3771weak_ptr<_Tp>::operator=(shared_ptr<_Yp> const& __r) _NOEXCEPT 3772{ 3773 weak_ptr(__r).swap(*this); 3774 return *this; 3775} 3776 3777template<class _Tp> 3778inline 3779void 3780weak_ptr<_Tp>::swap(weak_ptr& __r) _NOEXCEPT 3781{ 3782 _VSTD::swap(__ptr_, __r.__ptr_); 3783 _VSTD::swap(__cntrl_, __r.__cntrl_); 3784} 3785 3786template<class _Tp> 3787inline _LIBCPP_INLINE_VISIBILITY 3788void 3789swap(weak_ptr<_Tp>& __x, weak_ptr<_Tp>& __y) _NOEXCEPT 3790{ 3791 __x.swap(__y); 3792} 3793 3794template<class _Tp> 3795inline 3796void 3797weak_ptr<_Tp>::reset() _NOEXCEPT 3798{ 3799 weak_ptr().swap(*this); 3800} 3801 3802template<class _Tp> 3803template<class _Yp> 3804shared_ptr<_Tp>::shared_ptr(const weak_ptr<_Yp>& __r, 3805 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 3806 : __ptr_(__r.__ptr_), 3807 __cntrl_(__r.__cntrl_ ? __r.__cntrl_->lock() : __r.__cntrl_) 3808{ 3809 if (__cntrl_ == nullptr) 3810 __throw_bad_weak_ptr(); 3811} 3812 3813template<class _Tp> 3814shared_ptr<_Tp> 3815weak_ptr<_Tp>::lock() const _NOEXCEPT 3816{ 3817 shared_ptr<_Tp> __r; 3818 __r.__cntrl_ = __cntrl_ ? __cntrl_->lock() : __cntrl_; 3819 if (__r.__cntrl_) 3820 __r.__ptr_ = __ptr_; 3821 return __r; 3822} 3823 3824#if _LIBCPP_STD_VER > 14 3825template <class _Tp = void> struct owner_less; 3826#else 3827template <class _Tp> struct owner_less; 3828#endif 3829 3830template <class _Tp> 3831struct _LIBCPP_TEMPLATE_VIS owner_less<shared_ptr<_Tp> > 3832 : binary_function<shared_ptr<_Tp>, shared_ptr<_Tp>, bool> 3833{ 3834 typedef bool result_type; 3835 _LIBCPP_INLINE_VISIBILITY 3836 bool operator()(shared_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const _NOEXCEPT 3837 {return __x.owner_before(__y);} 3838 _LIBCPP_INLINE_VISIBILITY 3839 bool operator()(shared_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const _NOEXCEPT 3840 {return __x.owner_before(__y);} 3841 _LIBCPP_INLINE_VISIBILITY 3842 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const _NOEXCEPT 3843 {return __x.owner_before(__y);} 3844}; 3845 3846template <class _Tp> 3847struct _LIBCPP_TEMPLATE_VIS owner_less<weak_ptr<_Tp> > 3848 : binary_function<weak_ptr<_Tp>, weak_ptr<_Tp>, bool> 3849{ 3850 typedef bool result_type; 3851 _LIBCPP_INLINE_VISIBILITY 3852 bool operator()( weak_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const _NOEXCEPT 3853 {return __x.owner_before(__y);} 3854 _LIBCPP_INLINE_VISIBILITY 3855 bool operator()(shared_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const _NOEXCEPT 3856 {return __x.owner_before(__y);} 3857 _LIBCPP_INLINE_VISIBILITY 3858 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const _NOEXCEPT 3859 {return __x.owner_before(__y);} 3860}; 3861 3862#if _LIBCPP_STD_VER > 14 3863template <> 3864struct _LIBCPP_TEMPLATE_VIS owner_less<void> 3865{ 3866 template <class _Tp, class _Up> 3867 _LIBCPP_INLINE_VISIBILITY 3868 bool operator()( shared_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const _NOEXCEPT 3869 {return __x.owner_before(__y);} 3870 template <class _Tp, class _Up> 3871 _LIBCPP_INLINE_VISIBILITY 3872 bool operator()( shared_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const _NOEXCEPT 3873 {return __x.owner_before(__y);} 3874 template <class _Tp, class _Up> 3875 _LIBCPP_INLINE_VISIBILITY 3876 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const _NOEXCEPT 3877 {return __x.owner_before(__y);} 3878 template <class _Tp, class _Up> 3879 _LIBCPP_INLINE_VISIBILITY 3880 bool operator()( weak_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const _NOEXCEPT 3881 {return __x.owner_before(__y);} 3882 typedef void is_transparent; 3883}; 3884#endif 3885 3886template<class _Tp> 3887class _LIBCPP_TEMPLATE_VIS enable_shared_from_this 3888{ 3889 mutable weak_ptr<_Tp> __weak_this_; 3890protected: 3891 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 3892 enable_shared_from_this() _NOEXCEPT {} 3893 _LIBCPP_INLINE_VISIBILITY 3894 enable_shared_from_this(enable_shared_from_this const&) _NOEXCEPT {} 3895 _LIBCPP_INLINE_VISIBILITY 3896 enable_shared_from_this& operator=(enable_shared_from_this const&) _NOEXCEPT 3897 {return *this;} 3898 _LIBCPP_INLINE_VISIBILITY 3899 ~enable_shared_from_this() {} 3900public: 3901 _LIBCPP_INLINE_VISIBILITY 3902 shared_ptr<_Tp> shared_from_this() 3903 {return shared_ptr<_Tp>(__weak_this_);} 3904 _LIBCPP_INLINE_VISIBILITY 3905 shared_ptr<_Tp const> shared_from_this() const 3906 {return shared_ptr<const _Tp>(__weak_this_);} 3907 3908#if _LIBCPP_STD_VER > 14 3909 _LIBCPP_INLINE_VISIBILITY 3910 weak_ptr<_Tp> weak_from_this() _NOEXCEPT 3911 { return __weak_this_; } 3912 3913 _LIBCPP_INLINE_VISIBILITY 3914 weak_ptr<const _Tp> weak_from_this() const _NOEXCEPT 3915 { return __weak_this_; } 3916#endif // _LIBCPP_STD_VER > 14 3917 3918 template <class _Up> friend class shared_ptr; 3919}; 3920 3921template <class _Tp> 3922struct _LIBCPP_TEMPLATE_VIS hash<shared_ptr<_Tp> > 3923{ 3924 typedef shared_ptr<_Tp> argument_type; 3925 typedef size_t result_type; 3926 3927 _LIBCPP_INLINE_VISIBILITY 3928 result_type operator()(const argument_type& __ptr) const _NOEXCEPT 3929 { 3930 return hash<typename shared_ptr<_Tp>::element_type*>()(__ptr.get()); 3931 } 3932}; 3933 3934template<class _CharT, class _Traits, class _Yp> 3935inline _LIBCPP_INLINE_VISIBILITY 3936basic_ostream<_CharT, _Traits>& 3937operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Yp> const& __p); 3938 3939 3940#if !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 3941 3942class _LIBCPP_TYPE_VIS __sp_mut 3943{ 3944 void* __lx; 3945public: 3946 void lock() _NOEXCEPT; 3947 void unlock() _NOEXCEPT; 3948 3949private: 3950 _LIBCPP_CONSTEXPR __sp_mut(void*) _NOEXCEPT; 3951 __sp_mut(const __sp_mut&); 3952 __sp_mut& operator=(const __sp_mut&); 3953 3954 friend _LIBCPP_FUNC_VIS __sp_mut& __get_sp_mut(const void*); 3955}; 3956 3957_LIBCPP_FUNC_VIS _LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 3958__sp_mut& __get_sp_mut(const void*); 3959 3960template <class _Tp> 3961inline _LIBCPP_INLINE_VISIBILITY 3962bool 3963atomic_is_lock_free(const shared_ptr<_Tp>*) 3964{ 3965 return false; 3966} 3967 3968template <class _Tp> 3969_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 3970shared_ptr<_Tp> 3971atomic_load(const shared_ptr<_Tp>* __p) 3972{ 3973 __sp_mut& __m = __get_sp_mut(__p); 3974 __m.lock(); 3975 shared_ptr<_Tp> __q = *__p; 3976 __m.unlock(); 3977 return __q; 3978} 3979 3980template <class _Tp> 3981inline _LIBCPP_INLINE_VISIBILITY 3982_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 3983shared_ptr<_Tp> 3984atomic_load_explicit(const shared_ptr<_Tp>* __p, memory_order) 3985{ 3986 return atomic_load(__p); 3987} 3988 3989template <class _Tp> 3990_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 3991void 3992atomic_store(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r) 3993{ 3994 __sp_mut& __m = __get_sp_mut(__p); 3995 __m.lock(); 3996 __p->swap(__r); 3997 __m.unlock(); 3998} 3999 4000template <class _Tp> 4001inline _LIBCPP_INLINE_VISIBILITY 4002_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4003void 4004atomic_store_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r, memory_order) 4005{ 4006 atomic_store(__p, __r); 4007} 4008 4009template <class _Tp> 4010_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4011shared_ptr<_Tp> 4012atomic_exchange(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r) 4013{ 4014 __sp_mut& __m = __get_sp_mut(__p); 4015 __m.lock(); 4016 __p->swap(__r); 4017 __m.unlock(); 4018 return __r; 4019} 4020 4021template <class _Tp> 4022inline _LIBCPP_INLINE_VISIBILITY 4023_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4024shared_ptr<_Tp> 4025atomic_exchange_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r, memory_order) 4026{ 4027 return atomic_exchange(__p, __r); 4028} 4029 4030template <class _Tp> 4031_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4032bool 4033atomic_compare_exchange_strong(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, shared_ptr<_Tp> __w) 4034{ 4035 shared_ptr<_Tp> __temp; 4036 __sp_mut& __m = __get_sp_mut(__p); 4037 __m.lock(); 4038 if (__p->__owner_equivalent(*__v)) 4039 { 4040 _VSTD::swap(__temp, *__p); 4041 *__p = __w; 4042 __m.unlock(); 4043 return true; 4044 } 4045 _VSTD::swap(__temp, *__v); 4046 *__v = *__p; 4047 __m.unlock(); 4048 return false; 4049} 4050 4051template <class _Tp> 4052inline _LIBCPP_INLINE_VISIBILITY 4053_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4054bool 4055atomic_compare_exchange_weak(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, shared_ptr<_Tp> __w) 4056{ 4057 return atomic_compare_exchange_strong(__p, __v, __w); 4058} 4059 4060template <class _Tp> 4061inline _LIBCPP_INLINE_VISIBILITY 4062_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4063bool 4064atomic_compare_exchange_strong_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, 4065 shared_ptr<_Tp> __w, memory_order, memory_order) 4066{ 4067 return atomic_compare_exchange_strong(__p, __v, __w); 4068} 4069 4070template <class _Tp> 4071inline _LIBCPP_INLINE_VISIBILITY 4072_LIBCPP_AVAILABILITY_ATOMIC_SHARED_PTR 4073bool 4074atomic_compare_exchange_weak_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, 4075 shared_ptr<_Tp> __w, memory_order, memory_order) 4076{ 4077 return atomic_compare_exchange_weak(__p, __v, __w); 4078} 4079 4080#endif // !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 4081 4082//enum class 4083#if defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) 4084# ifndef _LIBCPP_CXX03_LANG 4085enum class pointer_safety : unsigned char { 4086 relaxed, 4087 preferred, 4088 strict 4089}; 4090# endif 4091#else 4092struct _LIBCPP_TYPE_VIS pointer_safety 4093{ 4094 enum __lx 4095 { 4096 relaxed, 4097 preferred, 4098 strict 4099 }; 4100 4101 __lx __v_; 4102 4103 _LIBCPP_INLINE_VISIBILITY 4104 pointer_safety() : __v_() {} 4105 4106 _LIBCPP_INLINE_VISIBILITY 4107 pointer_safety(__lx __v) : __v_(__v) {} 4108 _LIBCPP_INLINE_VISIBILITY 4109 operator int() const {return __v_;} 4110}; 4111#endif 4112 4113#if !defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) && \ 4114 defined(_LIBCPP_BUILDING_LIBRARY) 4115_LIBCPP_FUNC_VIS pointer_safety get_pointer_safety() _NOEXCEPT; 4116#else 4117// This function is only offered in C++03 under ABI v1. 4118# if !defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) || !defined(_LIBCPP_CXX03_LANG) 4119inline _LIBCPP_INLINE_VISIBILITY 4120pointer_safety get_pointer_safety() _NOEXCEPT { 4121 return pointer_safety::relaxed; 4122} 4123# endif 4124#endif 4125 4126 4127_LIBCPP_FUNC_VIS void declare_reachable(void* __p); 4128_LIBCPP_FUNC_VIS void declare_no_pointers(char* __p, size_t __n); 4129_LIBCPP_FUNC_VIS void undeclare_no_pointers(char* __p, size_t __n); 4130_LIBCPP_FUNC_VIS void* __undeclare_reachable(void* __p); 4131 4132template <class _Tp> 4133inline _LIBCPP_INLINE_VISIBILITY 4134_Tp* 4135undeclare_reachable(_Tp* __p) 4136{ 4137 return static_cast<_Tp*>(__undeclare_reachable(__p)); 4138} 4139 4140_LIBCPP_FUNC_VIS void* align(size_t __align, size_t __sz, void*& __ptr, size_t& __space); 4141 4142// --- Helper for container swap -- 4143template <typename _Alloc> 4144_LIBCPP_INLINE_VISIBILITY 4145void __swap_allocator(_Alloc & __a1, _Alloc & __a2, true_type) 4146#if _LIBCPP_STD_VER >= 14 4147 _NOEXCEPT 4148#else 4149 _NOEXCEPT_(__is_nothrow_swappable<_Alloc>::value) 4150#endif 4151{ 4152 using _VSTD::swap; 4153 swap(__a1, __a2); 4154} 4155 4156template <typename _Alloc> 4157inline _LIBCPP_INLINE_VISIBILITY 4158void __swap_allocator(_Alloc &, _Alloc &, false_type) _NOEXCEPT {} 4159 4160template <typename _Alloc> 4161inline _LIBCPP_INLINE_VISIBILITY 4162void __swap_allocator(_Alloc & __a1, _Alloc & __a2) 4163#if _LIBCPP_STD_VER >= 14 4164 _NOEXCEPT 4165#else 4166 _NOEXCEPT_(__is_nothrow_swappable<_Alloc>::value) 4167#endif 4168{ 4169 _VSTD::__swap_allocator(__a1, __a2, 4170 integral_constant<bool, _VSTD::allocator_traits<_Alloc>::propagate_on_container_swap::value>()); 4171} 4172 4173template <typename _Alloc, typename _Traits=allocator_traits<_Alloc> > 4174struct __noexcept_move_assign_container : public integral_constant<bool, 4175 _Traits::propagate_on_container_move_assignment::value 4176#if _LIBCPP_STD_VER > 14 4177 || _Traits::is_always_equal::value 4178#else 4179 && is_nothrow_move_assignable<_Alloc>::value 4180#endif 4181 > {}; 4182 4183 4184template <class _Tp, class _Alloc> 4185struct __temp_value { 4186 typedef allocator_traits<_Alloc> _Traits; 4187 4188 typename aligned_storage<sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp)>::type __v; 4189 _Alloc &__a; 4190 4191 _Tp *__addr() { return reinterpret_cast<_Tp *>(addressof(__v)); } 4192 _Tp & get() { return *__addr(); } 4193 4194 template<class... _Args> 4195 _LIBCPP_NO_CFI 4196 __temp_value(_Alloc &__alloc, _Args&& ... __args) : __a(__alloc) { 4197 _Traits::construct(__a, reinterpret_cast<_Tp*>(addressof(__v)), 4198 _VSTD::forward<_Args>(__args)...); 4199 } 4200 4201 ~__temp_value() { _Traits::destroy(__a, __addr()); } 4202 }; 4203 4204template<typename _Alloc, typename = void, typename = void> 4205struct __is_allocator : false_type {}; 4206 4207template<typename _Alloc> 4208struct __is_allocator<_Alloc, 4209 typename __void_t<typename _Alloc::value_type>::type, 4210 typename __void_t<decltype(_VSTD::declval<_Alloc&>().allocate(size_t(0)))>::type 4211 > 4212 : true_type {}; 4213 4214// __builtin_new_allocator -- A non-templated helper for allocating and 4215// deallocating memory using __builtin_operator_new and 4216// __builtin_operator_delete. It should be used in preference to 4217// `std::allocator<T>` to avoid additional instantiations. 4218struct __builtin_new_allocator { 4219 struct __builtin_new_deleter { 4220 typedef void* pointer_type; 4221 4222 _LIBCPP_CONSTEXPR explicit __builtin_new_deleter(size_t __size, size_t __align) 4223 : __size_(__size), __align_(__align) {} 4224 4225 void operator()(void* p) const _NOEXCEPT { 4226 _VSTD::__libcpp_deallocate(p, __size_, __align_); 4227 } 4228 4229 private: 4230 size_t __size_; 4231 size_t __align_; 4232 }; 4233 4234 typedef unique_ptr<void, __builtin_new_deleter> __holder_t; 4235 4236 static __holder_t __allocate_bytes(size_t __s, size_t __align) { 4237 return __holder_t(_VSTD::__libcpp_allocate(__s, __align), 4238 __builtin_new_deleter(__s, __align)); 4239 } 4240 4241 static void __deallocate_bytes(void* __p, size_t __s, 4242 size_t __align) _NOEXCEPT { 4243 _VSTD::__libcpp_deallocate(__p, __s, __align); 4244 } 4245 4246 template <class _Tp> 4247 _LIBCPP_NODEBUG _LIBCPP_ALWAYS_INLINE 4248 static __holder_t __allocate_type(size_t __n) { 4249 return __allocate_bytes(__n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp)); 4250 } 4251 4252 template <class _Tp> 4253 _LIBCPP_NODEBUG _LIBCPP_ALWAYS_INLINE 4254 static void __deallocate_type(void* __p, size_t __n) _NOEXCEPT { 4255 __deallocate_bytes(__p, __n * sizeof(_Tp), _LIBCPP_ALIGNOF(_Tp)); 4256 } 4257}; 4258 4259 4260_LIBCPP_END_NAMESPACE_STD 4261 4262_LIBCPP_POP_MACROS 4263 4264#if defined(_LIBCPP_HAS_PARALLEL_ALGORITHMS) && _LIBCPP_STD_VER >= 17 4265# include <__pstl_memory> 4266#endif 4267 4268#endif // _LIBCPP_MEMORY 4269