1// -*- C++ -*- 2//===-------------------------- memory ------------------------------------===// 3// 4// The LLVM Compiler Infrastructure 5// 6// This file is dual licensed under the MIT and the University of Illinois Open 7// Source Licenses. See LICENSE.TXT for details. 8// 9//===----------------------------------------------------------------------===// 10 11#ifndef _LIBCPP_MEMORY 12#define _LIBCPP_MEMORY 13 14/* 15 memory synopsis 16 17namespace std 18{ 19 20struct allocator_arg_t { }; 21constexpr allocator_arg_t allocator_arg = allocator_arg_t(); 22 23template <class T, class Alloc> struct uses_allocator; 24 25template <class Ptr> 26struct pointer_traits 27{ 28 typedef Ptr pointer; 29 typedef <details> element_type; 30 typedef <details> difference_type; 31 32 template <class U> using rebind = <details>; 33 34 static pointer pointer_to(<details>); 35}; 36 37template <class T> 38struct pointer_traits<T*> 39{ 40 typedef T* pointer; 41 typedef T element_type; 42 typedef ptrdiff_t difference_type; 43 44 template <class U> using rebind = U*; 45 46 static pointer pointer_to(<details>) noexcept; 47}; 48 49template <class Alloc> 50struct allocator_traits 51{ 52 typedef Alloc allocator_type; 53 typedef typename allocator_type::value_type 54 value_type; 55 56 typedef Alloc::pointer | value_type* pointer; 57 typedef Alloc::const_pointer 58 | pointer_traits<pointer>::rebind<const value_type> 59 const_pointer; 60 typedef Alloc::void_pointer 61 | pointer_traits<pointer>::rebind<void> 62 void_pointer; 63 typedef Alloc::const_void_pointer 64 | pointer_traits<pointer>::rebind<const void> 65 const_void_pointer; 66 typedef Alloc::difference_type 67 | pointer_traits<pointer>::difference_type 68 difference_type; 69 typedef Alloc::size_type 70 | make_unsigned<difference_type>::type 71 size_type; 72 typedef Alloc::propagate_on_container_copy_assignment 73 | false_type propagate_on_container_copy_assignment; 74 typedef Alloc::propagate_on_container_move_assignment 75 | false_type propagate_on_container_move_assignment; 76 typedef Alloc::propagate_on_container_swap 77 | false_type propagate_on_container_swap; 78 typedef Alloc::is_always_equal 79 | is_empty is_always_equal; 80 81 template <class T> using rebind_alloc = Alloc::rebind<U>::other | Alloc<T, Args...>; 82 template <class T> using rebind_traits = allocator_traits<rebind_alloc<T>>; 83 84 static pointer allocate(allocator_type& a, size_type n); 85 static pointer allocate(allocator_type& a, size_type n, const_void_pointer hint); 86 87 static void deallocate(allocator_type& a, pointer p, size_type n) noexcept; 88 89 template <class T, class... Args> 90 static void construct(allocator_type& a, T* p, Args&&... args); 91 92 template <class T> 93 static void destroy(allocator_type& a, T* p); 94 95 static size_type max_size(const allocator_type& a); // noexcept in C++14 96 97 static allocator_type 98 select_on_container_copy_construction(const allocator_type& a); 99}; 100 101template <> 102class allocator<void> 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; 119 typedef const T* const_pointer; 120 typedef typename add_lvalue_reference<T>::type reference; 121 typedef typename add_lvalue_reference<const T>::type const_reference; 122 typedef T value_type; 123 124 template <class U> struct rebind {typedef allocator<U> other;}; 125 126 allocator() noexcept; 127 allocator(const allocator&) noexcept; 128 template <class U> allocator(const allocator<U>&) noexcept; 129 ~allocator(); 130 pointer address(reference x) const noexcept; 131 const_pointer address(const_reference x) const noexcept; 132 pointer allocate(size_type, allocator<void>::const_pointer hint = 0); 133 void deallocate(pointer p, size_type n) noexcept; 134 size_type max_size() const noexcept; 135 template<class U, class... Args> 136 void construct(U* p, Args&&... args); 137 template <class U> 138 void destroy(U* p); 139}; 140 141template <class T, class U> 142bool operator==(const allocator<T>&, const allocator<U>&) noexcept; 143 144template <class T, class U> 145bool operator!=(const allocator<T>&, const allocator<U>&) noexcept; 146 147template <class OutputIterator, class T> 148class raw_storage_iterator 149 : public iterator<output_iterator_tag, 150 T, // purposefully not C++03 151 ptrdiff_t, // purposefully not C++03 152 T*, // purposefully not C++03 153 raw_storage_iterator&> // purposefully not C++03 154{ 155public: 156 explicit raw_storage_iterator(OutputIterator x); 157 raw_storage_iterator& operator*(); 158 raw_storage_iterator& operator=(const T& element); 159 raw_storage_iterator& operator++(); 160 raw_storage_iterator operator++(int); 161}; 162 163template <class T> pair<T*,ptrdiff_t> get_temporary_buffer(ptrdiff_t n) noexcept; 164template <class T> void return_temporary_buffer(T* p) noexcept; 165 166template <class T> T* addressof(T& r) noexcept; 167template <class T> T* addressof(const T&& r) noexcept = delete; 168 169template <class InputIterator, class ForwardIterator> 170ForwardIterator 171uninitialized_copy(InputIterator first, InputIterator last, ForwardIterator result); 172 173template <class InputIterator, class Size, class ForwardIterator> 174ForwardIterator 175uninitialized_copy_n(InputIterator first, Size n, ForwardIterator result); 176 177template <class ForwardIterator, class T> 178void uninitialized_fill(ForwardIterator first, ForwardIterator last, const T& x); 179 180template <class ForwardIterator, class Size, class T> 181ForwardIterator 182uninitialized_fill_n(ForwardIterator first, Size n, const T& x); 183 184template <class T> 185void destroy_at(T* location); 186 187template <class ForwardIterator> 188 void destroy(ForwardIterator first, ForwardIterator last); 189 190template <class ForwardIterator, class Size> 191 ForwardIterator destroy_n(ForwardIterator first, Size n); 192 193template <class InputIterator, class ForwardIterator> 194 ForwardIterator uninitialized_move(InputIterator first, InputIterator last, ForwardIterator result); 195 196template <class InputIterator, class Size, class ForwardIterator> 197 pair<InputIterator,ForwardIterator> uninitialized_move_n(InputIterator first, Size n, ForwardIterator result); 198 199template <class ForwardIterator> 200 void uninitialized_value_construct(ForwardIterator first, ForwardIterator last); 201 202template <class ForwardIterator, class Size> 203 ForwardIterator uninitialized_value_construct_n(ForwardIterator first, Size n); 204 205template <class ForwardIterator> 206 void uninitialized_default_construct(ForwardIterator first, ForwardIterator last); 207 208template <class ForwardIterator, class Size> 209 ForwardIterator uninitialized_default_construct_n(ForwardIterator first, Size n); 210 211template <class Y> struct auto_ptr_ref {}; 212 213template<class X> 214class auto_ptr 215{ 216public: 217 typedef X element_type; 218 219 explicit auto_ptr(X* p =0) throw(); 220 auto_ptr(auto_ptr&) throw(); 221 template<class Y> auto_ptr(auto_ptr<Y>&) throw(); 222 auto_ptr& operator=(auto_ptr&) throw(); 223 template<class Y> auto_ptr& operator=(auto_ptr<Y>&) throw(); 224 auto_ptr& operator=(auto_ptr_ref<X> r) throw(); 225 ~auto_ptr() throw(); 226 227 typename add_lvalue_reference<X>::type operator*() const throw(); 228 X* operator->() const throw(); 229 X* get() const throw(); 230 X* release() throw(); 231 void reset(X* p =0) throw(); 232 233 auto_ptr(auto_ptr_ref<X>) throw(); 234 template<class Y> operator auto_ptr_ref<Y>() throw(); 235 template<class Y> operator auto_ptr<Y>() throw(); 236}; 237 238template <class T> 239struct default_delete 240{ 241 constexpr default_delete() noexcept = default; 242 template <class U> default_delete(const default_delete<U>&) noexcept; 243 244 void operator()(T*) const noexcept; 245}; 246 247template <class T> 248struct default_delete<T[]> 249{ 250 constexpr default_delete() noexcept = default; 251 void operator()(T*) const noexcept; 252 template <class U> void operator()(U*) const = delete; 253}; 254 255template <class T, class D = default_delete<T>> 256class unique_ptr 257{ 258public: 259 typedef see below pointer; 260 typedef T element_type; 261 typedef D deleter_type; 262 263 // constructors 264 constexpr unique_ptr() noexcept; 265 explicit unique_ptr(pointer p) noexcept; 266 unique_ptr(pointer p, see below d1) noexcept; 267 unique_ptr(pointer p, see below d2) noexcept; 268 unique_ptr(unique_ptr&& u) noexcept; 269 unique_ptr(nullptr_t) noexcept : unique_ptr() { } 270 template <class U, class E> 271 unique_ptr(unique_ptr<U, E>&& u) noexcept; 272 template <class U> 273 unique_ptr(auto_ptr<U>&& u) noexcept; 274 275 // destructor 276 ~unique_ptr(); 277 278 // assignment 279 unique_ptr& operator=(unique_ptr&& u) noexcept; 280 template <class U, class E> unique_ptr& operator=(unique_ptr<U, E>&& u) noexcept; 281 unique_ptr& operator=(nullptr_t) noexcept; 282 283 // observers 284 typename add_lvalue_reference<T>::type operator*() const; 285 pointer operator->() const noexcept; 286 pointer get() const noexcept; 287 deleter_type& get_deleter() noexcept; 288 const deleter_type& get_deleter() const noexcept; 289 explicit operator bool() const noexcept; 290 291 // modifiers 292 pointer release() noexcept; 293 void reset(pointer p = pointer()) noexcept; 294 void swap(unique_ptr& u) noexcept; 295}; 296 297template <class T, class D> 298class unique_ptr<T[], D> 299{ 300public: 301 typedef implementation-defined pointer; 302 typedef T element_type; 303 typedef D deleter_type; 304 305 // constructors 306 constexpr unique_ptr() noexcept; 307 explicit unique_ptr(pointer p) noexcept; 308 unique_ptr(pointer p, see below d) noexcept; 309 unique_ptr(pointer p, see below d) noexcept; 310 unique_ptr(unique_ptr&& u) noexcept; 311 unique_ptr(nullptr_t) noexcept : unique_ptr() { } 312 313 // destructor 314 ~unique_ptr(); 315 316 // assignment 317 unique_ptr& operator=(unique_ptr&& u) noexcept; 318 unique_ptr& operator=(nullptr_t) noexcept; 319 320 // observers 321 T& operator[](size_t i) const; 322 pointer get() const noexcept; 323 deleter_type& get_deleter() noexcept; 324 const deleter_type& get_deleter() const noexcept; 325 explicit operator bool() const noexcept; 326 327 // modifiers 328 pointer release() noexcept; 329 void reset(pointer p = pointer()) noexcept; 330 void reset(nullptr_t) noexcept; 331 template <class U> void reset(U) = delete; 332 void swap(unique_ptr& u) noexcept; 333}; 334 335template <class T, class D> 336 void swap(unique_ptr<T, D>& x, unique_ptr<T, D>& y) noexcept; 337 338template <class T1, class D1, class T2, class D2> 339 bool operator==(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 340template <class T1, class D1, class T2, class D2> 341 bool operator!=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 342template <class T1, class D1, class T2, class D2> 343 bool operator<(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 344template <class T1, class D1, class T2, class D2> 345 bool operator<=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 346template <class T1, class D1, class T2, class D2> 347 bool operator>(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 348template <class T1, class D1, class T2, class D2> 349 bool operator>=(const unique_ptr<T1, D1>& x, const unique_ptr<T2, D2>& y); 350 351template <class T, class D> 352 bool operator==(const unique_ptr<T, D>& x, nullptr_t) noexcept; 353template <class T, class D> 354 bool operator==(nullptr_t, const unique_ptr<T, D>& y) noexcept; 355template <class T, class D> 356 bool operator!=(const unique_ptr<T, D>& x, nullptr_t) noexcept; 357template <class T, class D> 358 bool operator!=(nullptr_t, const unique_ptr<T, D>& y) noexcept; 359 360template <class T, class D> 361 bool operator<(const unique_ptr<T, D>& x, nullptr_t); 362template <class T, class D> 363 bool operator<(nullptr_t, const unique_ptr<T, D>& y); 364template <class T, class D> 365 bool operator<=(const unique_ptr<T, D>& x, nullptr_t); 366template <class T, class D> 367 bool operator<=(nullptr_t, const unique_ptr<T, D>& y); 368template <class T, class D> 369 bool operator>(const unique_ptr<T, D>& x, nullptr_t); 370template <class T, class D> 371 bool operator>(nullptr_t, const unique_ptr<T, D>& y); 372template <class T, class D> 373 bool operator>=(const unique_ptr<T, D>& x, nullptr_t); 374template <class T, class D> 375 bool operator>=(nullptr_t, const unique_ptr<T, D>& y); 376 377class bad_weak_ptr 378 : public std::exception 379{ 380 bad_weak_ptr() noexcept; 381}; 382 383template<class T, class... Args> unique_ptr<T> make_unique(Args&&... args); // C++14 384template<class T> unique_ptr<T> make_unique(size_t n); // C++14 385template<class T, class... Args> unspecified make_unique(Args&&...) = delete; // C++14, T == U[N] 386 387template<class T> 388class shared_ptr 389{ 390public: 391 typedef T element_type; 392 typedef weak_ptr<T> weak_type; // C++17 393 394 // constructors: 395 constexpr shared_ptr() noexcept; 396 template<class Y> explicit shared_ptr(Y* p); 397 template<class Y, class D> shared_ptr(Y* p, D d); 398 template<class Y, class D, class A> shared_ptr(Y* p, D d, A a); 399 template <class D> shared_ptr(nullptr_t p, D d); 400 template <class D, class A> shared_ptr(nullptr_t p, D d, A a); 401 template<class Y> shared_ptr(const shared_ptr<Y>& r, T *p) noexcept; 402 shared_ptr(const shared_ptr& r) noexcept; 403 template<class Y> shared_ptr(const shared_ptr<Y>& r) noexcept; 404 shared_ptr(shared_ptr&& r) noexcept; 405 template<class Y> shared_ptr(shared_ptr<Y>&& r) noexcept; 406 template<class Y> explicit shared_ptr(const weak_ptr<Y>& r); 407 template<class Y> shared_ptr(auto_ptr<Y>&& r); 408 template <class Y, class D> shared_ptr(unique_ptr<Y, D>&& r); 409 shared_ptr(nullptr_t) : shared_ptr() { } 410 411 // destructor: 412 ~shared_ptr(); 413 414 // assignment: 415 shared_ptr& operator=(const shared_ptr& r) noexcept; 416 template<class Y> shared_ptr& operator=(const shared_ptr<Y>& r) noexcept; 417 shared_ptr& operator=(shared_ptr&& r) noexcept; 418 template<class Y> shared_ptr& operator=(shared_ptr<Y>&& r); 419 template<class Y> shared_ptr& operator=(auto_ptr<Y>&& r); 420 template <class Y, class D> shared_ptr& operator=(unique_ptr<Y, D>&& r); 421 422 // modifiers: 423 void swap(shared_ptr& r) noexcept; 424 void reset() noexcept; 425 template<class Y> void reset(Y* p); 426 template<class Y, class D> void reset(Y* p, D d); 427 template<class Y, class D, class A> void reset(Y* p, D d, A a); 428 429 // observers: 430 T* get() const noexcept; 431 T& operator*() const noexcept; 432 T* operator->() const noexcept; 433 long use_count() const noexcept; 434 bool unique() const noexcept; 435 explicit operator bool() const noexcept; 436 template<class U> bool owner_before(shared_ptr<U> const& b) const; 437 template<class U> bool owner_before(weak_ptr<U> const& b) const; 438}; 439 440// shared_ptr comparisons: 441template<class T, class U> 442 bool operator==(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 443template<class T, class U> 444 bool operator!=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 445template<class T, class U> 446 bool operator<(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 447template<class T, class U> 448 bool operator>(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 449template<class T, class U> 450 bool operator<=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 451template<class T, class U> 452 bool operator>=(shared_ptr<T> const& a, shared_ptr<U> const& b) noexcept; 453 454template <class T> 455 bool operator==(const shared_ptr<T>& x, nullptr_t) noexcept; 456template <class T> 457 bool operator==(nullptr_t, const shared_ptr<T>& y) noexcept; 458template <class T> 459 bool operator!=(const shared_ptr<T>& x, nullptr_t) noexcept; 460template <class T> 461 bool operator!=(nullptr_t, const shared_ptr<T>& y) noexcept; 462template <class T> 463 bool operator<(const shared_ptr<T>& x, nullptr_t) noexcept; 464template <class T> 465bool operator<(nullptr_t, const shared_ptr<T>& y) noexcept; 466template <class T> 467 bool operator<=(const shared_ptr<T>& x, nullptr_t) noexcept; 468template <class T> 469 bool operator<=(nullptr_t, const shared_ptr<T>& y) noexcept; 470template <class T> 471 bool operator>(const shared_ptr<T>& x, nullptr_t) noexcept; 472template <class T> 473 bool operator>(nullptr_t, const shared_ptr<T>& y) noexcept; 474template <class T> 475 bool operator>=(const shared_ptr<T>& x, nullptr_t) noexcept; 476template <class T> 477 bool operator>=(nullptr_t, const shared_ptr<T>& y) noexcept; 478 479// shared_ptr specialized algorithms: 480template<class T> void swap(shared_ptr<T>& a, shared_ptr<T>& b) noexcept; 481 482// shared_ptr casts: 483template<class T, class U> 484 shared_ptr<T> static_pointer_cast(shared_ptr<U> const& r) noexcept; 485template<class T, class U> 486 shared_ptr<T> dynamic_pointer_cast(shared_ptr<U> const& r) noexcept; 487template<class T, class U> 488 shared_ptr<T> const_pointer_cast(shared_ptr<U> const& r) noexcept; 489 490// shared_ptr I/O: 491template<class E, class T, class Y> 492 basic_ostream<E, T>& operator<< (basic_ostream<E, T>& os, shared_ptr<Y> const& p); 493 494// shared_ptr get_deleter: 495template<class D, class T> D* get_deleter(shared_ptr<T> const& p) noexcept; 496 497template<class T, class... Args> 498 shared_ptr<T> make_shared(Args&&... args); 499template<class T, class A, class... Args> 500 shared_ptr<T> allocate_shared(const A& a, Args&&... args); 501 502template<class T> 503class weak_ptr 504{ 505public: 506 typedef T element_type; 507 508 // constructors 509 constexpr weak_ptr() noexcept; 510 template<class Y> weak_ptr(shared_ptr<Y> const& r) noexcept; 511 weak_ptr(weak_ptr const& r) noexcept; 512 template<class Y> weak_ptr(weak_ptr<Y> const& r) noexcept; 513 weak_ptr(weak_ptr&& r) noexcept; // C++14 514 template<class Y> weak_ptr(weak_ptr<Y>&& r) noexcept; // C++14 515 516 // destructor 517 ~weak_ptr(); 518 519 // assignment 520 weak_ptr& operator=(weak_ptr const& r) noexcept; 521 template<class Y> weak_ptr& operator=(weak_ptr<Y> const& r) noexcept; 522 template<class Y> weak_ptr& operator=(shared_ptr<Y> const& r) noexcept; 523 weak_ptr& operator=(weak_ptr&& r) noexcept; // C++14 524 template<class Y> weak_ptr& operator=(weak_ptr<Y>&& r) noexcept; // C++14 525 526 // modifiers 527 void swap(weak_ptr& r) noexcept; 528 void reset() noexcept; 529 530 // observers 531 long use_count() const noexcept; 532 bool expired() const noexcept; 533 shared_ptr<T> lock() const noexcept; 534 template<class U> bool owner_before(shared_ptr<U> const& b) const; 535 template<class U> bool owner_before(weak_ptr<U> const& b) const; 536}; 537 538// weak_ptr specialized algorithms: 539template<class T> void swap(weak_ptr<T>& a, weak_ptr<T>& b) noexcept; 540 541// class owner_less: 542template<class T> struct owner_less; 543 544template<class T> 545struct owner_less<shared_ptr<T>> 546 : binary_function<shared_ptr<T>, shared_ptr<T>, bool> 547{ 548 typedef bool result_type; 549 bool operator()(shared_ptr<T> const&, shared_ptr<T> const&) const; 550 bool operator()(shared_ptr<T> const&, weak_ptr<T> const&) const; 551 bool operator()(weak_ptr<T> const&, shared_ptr<T> const&) const; 552}; 553 554template<class T> 555struct owner_less<weak_ptr<T>> 556 : binary_function<weak_ptr<T>, weak_ptr<T>, bool> 557{ 558 typedef bool result_type; 559 bool operator()(weak_ptr<T> const&, weak_ptr<T> const&) const; 560 bool operator()(shared_ptr<T> const&, weak_ptr<T> const&) const; 561 bool operator()(weak_ptr<T> const&, shared_ptr<T> const&) const; 562}; 563 564template<class T> 565class enable_shared_from_this 566{ 567protected: 568 constexpr enable_shared_from_this() noexcept; 569 enable_shared_from_this(enable_shared_from_this const&) noexcept; 570 enable_shared_from_this& operator=(enable_shared_from_this const&) noexcept; 571 ~enable_shared_from_this(); 572public: 573 shared_ptr<T> shared_from_this(); 574 shared_ptr<T const> shared_from_this() const; 575}; 576 577template<class T> 578 bool atomic_is_lock_free(const shared_ptr<T>* p); 579template<class T> 580 shared_ptr<T> atomic_load(const shared_ptr<T>* p); 581template<class T> 582 shared_ptr<T> atomic_load_explicit(const shared_ptr<T>* p, memory_order mo); 583template<class T> 584 void atomic_store(shared_ptr<T>* p, shared_ptr<T> r); 585template<class T> 586 void atomic_store_explicit(shared_ptr<T>* p, shared_ptr<T> r, memory_order mo); 587template<class T> 588 shared_ptr<T> atomic_exchange(shared_ptr<T>* p, shared_ptr<T> r); 589template<class T> 590 shared_ptr<T> 591 atomic_exchange_explicit(shared_ptr<T>* p, shared_ptr<T> r, memory_order mo); 592template<class T> 593 bool 594 atomic_compare_exchange_weak(shared_ptr<T>* p, shared_ptr<T>* v, shared_ptr<T> w); 595template<class T> 596 bool 597 atomic_compare_exchange_strong( shared_ptr<T>* p, shared_ptr<T>* v, shared_ptr<T> w); 598template<class T> 599 bool 600 atomic_compare_exchange_weak_explicit(shared_ptr<T>* p, shared_ptr<T>* v, 601 shared_ptr<T> w, memory_order success, 602 memory_order failure); 603template<class T> 604 bool 605 atomic_compare_exchange_strong_explicit(shared_ptr<T>* p, shared_ptr<T>* v, 606 shared_ptr<T> w, memory_order success, 607 memory_order failure); 608// Hash support 609template <class T> struct hash; 610template <class T, class D> struct hash<unique_ptr<T, D> >; 611template <class T> struct hash<shared_ptr<T> >; 612 613// Pointer safety 614enum class pointer_safety { relaxed, preferred, strict }; 615void declare_reachable(void *p); 616template <class T> T *undeclare_reachable(T *p); 617void declare_no_pointers(char *p, size_t n); 618void undeclare_no_pointers(char *p, size_t n); 619pointer_safety get_pointer_safety() noexcept; 620 621void* align(size_t alignment, size_t size, void*& ptr, size_t& space); 622 623} // std 624 625*/ 626 627#include <__config> 628#include <type_traits> 629#include <typeinfo> 630#include <cstddef> 631#include <cstdint> 632#include <new> 633#include <utility> 634#include <limits> 635#include <iterator> 636#include <__functional_base> 637#include <iosfwd> 638#include <tuple> 639#include <stdexcept> 640#include <cstring> 641 642#if !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 643# include <atomic> 644#endif 645 646#include <__undef_min_max> 647 648#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 649#pragma GCC system_header 650#endif 651 652_LIBCPP_BEGIN_NAMESPACE_STD 653 654template <class _ValueType> 655inline _LIBCPP_ALWAYS_INLINE 656_ValueType __libcpp_relaxed_load(_ValueType const* __value) { 657#if !defined(_LIBCPP_HAS_NO_THREADS) && \ 658 defined(__ATOMIC_RELAXED) && \ 659 (__has_builtin(__atomic_load_n) || _GNUC_VER >= 407) 660 return __atomic_load_n(__value, __ATOMIC_RELAXED); 661#else 662 return *__value; 663#endif 664} 665 666template <class _ValueType> 667inline _LIBCPP_ALWAYS_INLINE 668_ValueType __libcpp_acquire_load(_ValueType const* __value) { 669#if !defined(_LIBCPP_HAS_NO_THREADS) && \ 670 defined(__ATOMIC_ACQUIRE) && \ 671 (__has_builtin(__atomic_load_n) || _GNUC_VER >= 407) 672 return __atomic_load_n(__value, __ATOMIC_ACQUIRE); 673#else 674 return *__value; 675#endif 676} 677 678// addressof moved to <type_traits> 679 680template <class _Tp> class allocator; 681 682template <> 683class _LIBCPP_TEMPLATE_VIS allocator<void> 684{ 685public: 686 typedef void* pointer; 687 typedef const void* const_pointer; 688 typedef void value_type; 689 690 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 691}; 692 693template <> 694class _LIBCPP_TEMPLATE_VIS allocator<const void> 695{ 696public: 697 typedef const void* pointer; 698 typedef const void* const_pointer; 699 typedef const void value_type; 700 701 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 702}; 703 704// pointer_traits 705 706template <class _Tp> 707struct __has_element_type 708{ 709private: 710 struct __two {char __lx; char __lxx;}; 711 template <class _Up> static __two __test(...); 712 template <class _Up> static char __test(typename _Up::element_type* = 0); 713public: 714 static const bool value = sizeof(__test<_Tp>(0)) == 1; 715}; 716 717template <class _Ptr, bool = __has_element_type<_Ptr>::value> 718struct __pointer_traits_element_type; 719 720template <class _Ptr> 721struct __pointer_traits_element_type<_Ptr, true> 722{ 723 typedef typename _Ptr::element_type type; 724}; 725 726#ifndef _LIBCPP_HAS_NO_VARIADICS 727 728template <template <class, class...> class _Sp, class _Tp, class ..._Args> 729struct __pointer_traits_element_type<_Sp<_Tp, _Args...>, true> 730{ 731 typedef typename _Sp<_Tp, _Args...>::element_type type; 732}; 733 734template <template <class, class...> class _Sp, class _Tp, class ..._Args> 735struct __pointer_traits_element_type<_Sp<_Tp, _Args...>, false> 736{ 737 typedef _Tp type; 738}; 739 740#else // _LIBCPP_HAS_NO_VARIADICS 741 742template <template <class> class _Sp, class _Tp> 743struct __pointer_traits_element_type<_Sp<_Tp>, true> 744{ 745 typedef typename _Sp<_Tp>::element_type type; 746}; 747 748template <template <class> class _Sp, class _Tp> 749struct __pointer_traits_element_type<_Sp<_Tp>, false> 750{ 751 typedef _Tp type; 752}; 753 754template <template <class, class> class _Sp, class _Tp, class _A0> 755struct __pointer_traits_element_type<_Sp<_Tp, _A0>, true> 756{ 757 typedef typename _Sp<_Tp, _A0>::element_type type; 758}; 759 760template <template <class, class> class _Sp, class _Tp, class _A0> 761struct __pointer_traits_element_type<_Sp<_Tp, _A0>, false> 762{ 763 typedef _Tp type; 764}; 765 766template <template <class, class, class> class _Sp, class _Tp, class _A0, class _A1> 767struct __pointer_traits_element_type<_Sp<_Tp, _A0, _A1>, true> 768{ 769 typedef typename _Sp<_Tp, _A0, _A1>::element_type type; 770}; 771 772template <template <class, class, class> class _Sp, class _Tp, class _A0, class _A1> 773struct __pointer_traits_element_type<_Sp<_Tp, _A0, _A1>, false> 774{ 775 typedef _Tp type; 776}; 777 778template <template <class, class, class, class> class _Sp, class _Tp, class _A0, 779 class _A1, class _A2> 780struct __pointer_traits_element_type<_Sp<_Tp, _A0, _A1, _A2>, true> 781{ 782 typedef typename _Sp<_Tp, _A0, _A1, _A2>::element_type type; 783}; 784 785template <template <class, class, class, class> class _Sp, class _Tp, class _A0, 786 class _A1, class _A2> 787struct __pointer_traits_element_type<_Sp<_Tp, _A0, _A1, _A2>, false> 788{ 789 typedef _Tp type; 790}; 791 792#endif // _LIBCPP_HAS_NO_VARIADICS 793 794template <class _Tp> 795struct __has_difference_type 796{ 797private: 798 struct __two {char __lx; char __lxx;}; 799 template <class _Up> static __two __test(...); 800 template <class _Up> static char __test(typename _Up::difference_type* = 0); 801public: 802 static const bool value = sizeof(__test<_Tp>(0)) == 1; 803}; 804 805template <class _Ptr, bool = __has_difference_type<_Ptr>::value> 806struct __pointer_traits_difference_type 807{ 808 typedef ptrdiff_t type; 809}; 810 811template <class _Ptr> 812struct __pointer_traits_difference_type<_Ptr, true> 813{ 814 typedef typename _Ptr::difference_type type; 815}; 816 817template <class _Tp, class _Up> 818struct __has_rebind 819{ 820private: 821 struct __two {char __lx; char __lxx;}; 822 template <class _Xp> static __two __test(...); 823 template <class _Xp> static char __test(typename _Xp::template rebind<_Up>* = 0); 824public: 825 static const bool value = sizeof(__test<_Tp>(0)) == 1; 826}; 827 828template <class _Tp, class _Up, bool = __has_rebind<_Tp, _Up>::value> 829struct __pointer_traits_rebind 830{ 831#ifndef _LIBCPP_CXX03_LANG 832 typedef typename _Tp::template rebind<_Up> type; 833#else 834 typedef typename _Tp::template rebind<_Up>::other type; 835#endif 836}; 837 838#ifndef _LIBCPP_HAS_NO_VARIADICS 839 840template <template <class, class...> class _Sp, class _Tp, class ..._Args, class _Up> 841struct __pointer_traits_rebind<_Sp<_Tp, _Args...>, _Up, true> 842{ 843#ifndef _LIBCPP_CXX03_LANG 844 typedef typename _Sp<_Tp, _Args...>::template rebind<_Up> type; 845#else 846 typedef typename _Sp<_Tp, _Args...>::template rebind<_Up>::other type; 847#endif 848}; 849 850template <template <class, class...> class _Sp, class _Tp, class ..._Args, class _Up> 851struct __pointer_traits_rebind<_Sp<_Tp, _Args...>, _Up, false> 852{ 853 typedef _Sp<_Up, _Args...> type; 854}; 855 856#else // _LIBCPP_HAS_NO_VARIADICS 857 858template <template <class> class _Sp, class _Tp, class _Up> 859struct __pointer_traits_rebind<_Sp<_Tp>, _Up, true> 860{ 861#ifndef _LIBCPP_CXX03_LANG 862 typedef typename _Sp<_Tp>::template rebind<_Up> type; 863#else 864 typedef typename _Sp<_Tp>::template rebind<_Up>::other type; 865#endif 866}; 867 868template <template <class> class _Sp, class _Tp, class _Up> 869struct __pointer_traits_rebind<_Sp<_Tp>, _Up, false> 870{ 871 typedef _Sp<_Up> type; 872}; 873 874template <template <class, class> class _Sp, class _Tp, class _A0, class _Up> 875struct __pointer_traits_rebind<_Sp<_Tp, _A0>, _Up, true> 876{ 877#ifndef _LIBCPP_CXX03_LANG 878 typedef typename _Sp<_Tp, _A0>::template rebind<_Up> type; 879#else 880 typedef typename _Sp<_Tp, _A0>::template rebind<_Up>::other type; 881#endif 882}; 883 884template <template <class, class> class _Sp, class _Tp, class _A0, class _Up> 885struct __pointer_traits_rebind<_Sp<_Tp, _A0>, _Up, false> 886{ 887 typedef _Sp<_Up, _A0> type; 888}; 889 890template <template <class, class, class> class _Sp, class _Tp, class _A0, 891 class _A1, class _Up> 892struct __pointer_traits_rebind<_Sp<_Tp, _A0, _A1>, _Up, true> 893{ 894#ifndef _LIBCPP_CXX03_LANG 895 typedef typename _Sp<_Tp, _A0, _A1>::template rebind<_Up> type; 896#else 897 typedef typename _Sp<_Tp, _A0, _A1>::template rebind<_Up>::other type; 898#endif 899}; 900 901template <template <class, class, class> class _Sp, class _Tp, class _A0, 902 class _A1, class _Up> 903struct __pointer_traits_rebind<_Sp<_Tp, _A0, _A1>, _Up, false> 904{ 905 typedef _Sp<_Up, _A0, _A1> type; 906}; 907 908template <template <class, class, class, class> class _Sp, class _Tp, class _A0, 909 class _A1, class _A2, class _Up> 910struct __pointer_traits_rebind<_Sp<_Tp, _A0, _A1, _A2>, _Up, true> 911{ 912#ifndef _LIBCPP_CXX03_LANG 913 typedef typename _Sp<_Tp, _A0, _A1, _A2>::template rebind<_Up> type; 914#else 915 typedef typename _Sp<_Tp, _A0, _A1, _A2>::template rebind<_Up>::other type; 916#endif 917}; 918 919template <template <class, class, class, class> class _Sp, class _Tp, class _A0, 920 class _A1, class _A2, class _Up> 921struct __pointer_traits_rebind<_Sp<_Tp, _A0, _A1, _A2>, _Up, false> 922{ 923 typedef _Sp<_Up, _A0, _A1, _A2> type; 924}; 925 926#endif // _LIBCPP_HAS_NO_VARIADICS 927 928template <class _Ptr> 929struct _LIBCPP_TEMPLATE_VIS pointer_traits 930{ 931 typedef _Ptr pointer; 932 typedef typename __pointer_traits_element_type<pointer>::type element_type; 933 typedef typename __pointer_traits_difference_type<pointer>::type difference_type; 934 935#ifndef _LIBCPP_CXX03_LANG 936 template <class _Up> using rebind = typename __pointer_traits_rebind<pointer, _Up>::type; 937#else 938 template <class _Up> struct rebind 939 {typedef typename __pointer_traits_rebind<pointer, _Up>::type other;}; 940#endif // _LIBCPP_CXX03_LANG 941 942private: 943 struct __nat {}; 944public: 945 _LIBCPP_INLINE_VISIBILITY 946 static pointer pointer_to(typename conditional<is_void<element_type>::value, 947 __nat, element_type>::type& __r) 948 {return pointer::pointer_to(__r);} 949}; 950 951template <class _Tp> 952struct _LIBCPP_TEMPLATE_VIS pointer_traits<_Tp*> 953{ 954 typedef _Tp* pointer; 955 typedef _Tp element_type; 956 typedef ptrdiff_t difference_type; 957 958#ifndef _LIBCPP_CXX03_LANG 959 template <class _Up> using rebind = _Up*; 960#else 961 template <class _Up> struct rebind {typedef _Up* other;}; 962#endif 963 964private: 965 struct __nat {}; 966public: 967 _LIBCPP_INLINE_VISIBILITY 968 static pointer pointer_to(typename conditional<is_void<element_type>::value, 969 __nat, element_type>::type& __r) _NOEXCEPT 970 {return _VSTD::addressof(__r);} 971}; 972 973template <class _From, class _To> 974struct __rebind_pointer { 975#ifndef _LIBCPP_CXX03_LANG 976 typedef typename pointer_traits<_From>::template rebind<_To> type; 977#else 978 typedef typename pointer_traits<_From>::template rebind<_To>::other type; 979#endif 980}; 981 982// allocator_traits 983 984namespace __has_pointer_type_imp 985{ 986 template <class _Up> static __two __test(...); 987 template <class _Up> static char __test(typename _Up::pointer* = 0); 988} 989 990template <class _Tp> 991struct __has_pointer_type 992 : public integral_constant<bool, sizeof(__has_pointer_type_imp::__test<_Tp>(0)) == 1> 993{ 994}; 995 996namespace __pointer_type_imp 997{ 998 999template <class _Tp, class _Dp, bool = __has_pointer_type<_Dp>::value> 1000struct __pointer_type 1001{ 1002 typedef typename _Dp::pointer type; 1003}; 1004 1005template <class _Tp, class _Dp> 1006struct __pointer_type<_Tp, _Dp, false> 1007{ 1008 typedef _Tp* type; 1009}; 1010 1011} // __pointer_type_imp 1012 1013template <class _Tp, class _Dp> 1014struct __pointer_type 1015{ 1016 typedef typename __pointer_type_imp::__pointer_type<_Tp, typename remove_reference<_Dp>::type>::type type; 1017}; 1018 1019template <class _Tp> 1020struct __has_const_pointer 1021{ 1022private: 1023 struct __two {char __lx; char __lxx;}; 1024 template <class _Up> static __two __test(...); 1025 template <class _Up> static char __test(typename _Up::const_pointer* = 0); 1026public: 1027 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1028}; 1029 1030template <class _Tp, class _Ptr, class _Alloc, bool = __has_const_pointer<_Alloc>::value> 1031struct __const_pointer 1032{ 1033 typedef typename _Alloc::const_pointer type; 1034}; 1035 1036template <class _Tp, class _Ptr, class _Alloc> 1037struct __const_pointer<_Tp, _Ptr, _Alloc, false> 1038{ 1039#ifndef _LIBCPP_CXX03_LANG 1040 typedef typename pointer_traits<_Ptr>::template rebind<const _Tp> type; 1041#else 1042 typedef typename pointer_traits<_Ptr>::template rebind<const _Tp>::other type; 1043#endif 1044}; 1045 1046template <class _Tp> 1047struct __has_void_pointer 1048{ 1049private: 1050 struct __two {char __lx; char __lxx;}; 1051 template <class _Up> static __two __test(...); 1052 template <class _Up> static char __test(typename _Up::void_pointer* = 0); 1053public: 1054 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1055}; 1056 1057template <class _Ptr, class _Alloc, bool = __has_void_pointer<_Alloc>::value> 1058struct __void_pointer 1059{ 1060 typedef typename _Alloc::void_pointer type; 1061}; 1062 1063template <class _Ptr, class _Alloc> 1064struct __void_pointer<_Ptr, _Alloc, false> 1065{ 1066#ifndef _LIBCPP_CXX03_LANG 1067 typedef typename pointer_traits<_Ptr>::template rebind<void> type; 1068#else 1069 typedef typename pointer_traits<_Ptr>::template rebind<void>::other type; 1070#endif 1071}; 1072 1073template <class _Tp> 1074struct __has_const_void_pointer 1075{ 1076private: 1077 struct __two {char __lx; char __lxx;}; 1078 template <class _Up> static __two __test(...); 1079 template <class _Up> static char __test(typename _Up::const_void_pointer* = 0); 1080public: 1081 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1082}; 1083 1084template <class _Ptr, class _Alloc, bool = __has_const_void_pointer<_Alloc>::value> 1085struct __const_void_pointer 1086{ 1087 typedef typename _Alloc::const_void_pointer type; 1088}; 1089 1090template <class _Ptr, class _Alloc> 1091struct __const_void_pointer<_Ptr, _Alloc, false> 1092{ 1093#ifndef _LIBCPP_CXX03_LANG 1094 typedef typename pointer_traits<_Ptr>::template rebind<const void> type; 1095#else 1096 typedef typename pointer_traits<_Ptr>::template rebind<const void>::other type; 1097#endif 1098}; 1099 1100template <class _Tp> 1101inline _LIBCPP_INLINE_VISIBILITY 1102_Tp* 1103__to_raw_pointer(_Tp* __p) _NOEXCEPT 1104{ 1105 return __p; 1106} 1107 1108template <class _Pointer> 1109inline _LIBCPP_INLINE_VISIBILITY 1110typename pointer_traits<_Pointer>::element_type* 1111__to_raw_pointer(_Pointer __p) _NOEXCEPT 1112{ 1113 return _VSTD::__to_raw_pointer(__p.operator->()); 1114} 1115 1116template <class _Tp> 1117struct __has_size_type 1118{ 1119private: 1120 struct __two {char __lx; char __lxx;}; 1121 template <class _Up> static __two __test(...); 1122 template <class _Up> static char __test(typename _Up::size_type* = 0); 1123public: 1124 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1125}; 1126 1127template <class _Alloc, class _DiffType, bool = __has_size_type<_Alloc>::value> 1128struct __size_type 1129{ 1130 typedef typename make_unsigned<_DiffType>::type type; 1131}; 1132 1133template <class _Alloc, class _DiffType> 1134struct __size_type<_Alloc, _DiffType, true> 1135{ 1136 typedef typename _Alloc::size_type type; 1137}; 1138 1139template <class _Tp> 1140struct __has_propagate_on_container_copy_assignment 1141{ 1142private: 1143 struct __two {char __lx; char __lxx;}; 1144 template <class _Up> static __two __test(...); 1145 template <class _Up> static char __test(typename _Up::propagate_on_container_copy_assignment* = 0); 1146public: 1147 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1148}; 1149 1150template <class _Alloc, bool = __has_propagate_on_container_copy_assignment<_Alloc>::value> 1151struct __propagate_on_container_copy_assignment 1152{ 1153 typedef false_type type; 1154}; 1155 1156template <class _Alloc> 1157struct __propagate_on_container_copy_assignment<_Alloc, true> 1158{ 1159 typedef typename _Alloc::propagate_on_container_copy_assignment type; 1160}; 1161 1162template <class _Tp> 1163struct __has_propagate_on_container_move_assignment 1164{ 1165private: 1166 struct __two {char __lx; char __lxx;}; 1167 template <class _Up> static __two __test(...); 1168 template <class _Up> static char __test(typename _Up::propagate_on_container_move_assignment* = 0); 1169public: 1170 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1171}; 1172 1173template <class _Alloc, bool = __has_propagate_on_container_move_assignment<_Alloc>::value> 1174struct __propagate_on_container_move_assignment 1175{ 1176 typedef false_type type; 1177}; 1178 1179template <class _Alloc> 1180struct __propagate_on_container_move_assignment<_Alloc, true> 1181{ 1182 typedef typename _Alloc::propagate_on_container_move_assignment type; 1183}; 1184 1185template <class _Tp> 1186struct __has_propagate_on_container_swap 1187{ 1188private: 1189 struct __two {char __lx; char __lxx;}; 1190 template <class _Up> static __two __test(...); 1191 template <class _Up> static char __test(typename _Up::propagate_on_container_swap* = 0); 1192public: 1193 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1194}; 1195 1196template <class _Alloc, bool = __has_propagate_on_container_swap<_Alloc>::value> 1197struct __propagate_on_container_swap 1198{ 1199 typedef false_type type; 1200}; 1201 1202template <class _Alloc> 1203struct __propagate_on_container_swap<_Alloc, true> 1204{ 1205 typedef typename _Alloc::propagate_on_container_swap type; 1206}; 1207 1208template <class _Tp> 1209struct __has_is_always_equal 1210{ 1211private: 1212 struct __two {char __lx; char __lxx;}; 1213 template <class _Up> static __two __test(...); 1214 template <class _Up> static char __test(typename _Up::is_always_equal* = 0); 1215public: 1216 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1217}; 1218 1219template <class _Alloc, bool = __has_is_always_equal<_Alloc>::value> 1220struct __is_always_equal 1221{ 1222 typedef typename _VSTD::is_empty<_Alloc>::type type; 1223}; 1224 1225template <class _Alloc> 1226struct __is_always_equal<_Alloc, true> 1227{ 1228 typedef typename _Alloc::is_always_equal type; 1229}; 1230 1231template <class _Tp, class _Up, bool = __has_rebind<_Tp, _Up>::value> 1232struct __has_rebind_other 1233{ 1234private: 1235 struct __two {char __lx; char __lxx;}; 1236 template <class _Xp> static __two __test(...); 1237 template <class _Xp> static char __test(typename _Xp::template rebind<_Up>::other* = 0); 1238public: 1239 static const bool value = sizeof(__test<_Tp>(0)) == 1; 1240}; 1241 1242template <class _Tp, class _Up> 1243struct __has_rebind_other<_Tp, _Up, false> 1244{ 1245 static const bool value = false; 1246}; 1247 1248template <class _Tp, class _Up, bool = __has_rebind_other<_Tp, _Up>::value> 1249struct __allocator_traits_rebind 1250{ 1251 typedef typename _Tp::template rebind<_Up>::other type; 1252}; 1253 1254#ifndef _LIBCPP_HAS_NO_VARIADICS 1255 1256template <template <class, class...> class _Alloc, class _Tp, class ..._Args, class _Up> 1257struct __allocator_traits_rebind<_Alloc<_Tp, _Args...>, _Up, true> 1258{ 1259 typedef typename _Alloc<_Tp, _Args...>::template rebind<_Up>::other type; 1260}; 1261 1262template <template <class, class...> class _Alloc, class _Tp, class ..._Args, class _Up> 1263struct __allocator_traits_rebind<_Alloc<_Tp, _Args...>, _Up, false> 1264{ 1265 typedef _Alloc<_Up, _Args...> type; 1266}; 1267 1268#else // _LIBCPP_HAS_NO_VARIADICS 1269 1270template <template <class> class _Alloc, class _Tp, class _Up> 1271struct __allocator_traits_rebind<_Alloc<_Tp>, _Up, true> 1272{ 1273 typedef typename _Alloc<_Tp>::template rebind<_Up>::other type; 1274}; 1275 1276template <template <class> class _Alloc, class _Tp, class _Up> 1277struct __allocator_traits_rebind<_Alloc<_Tp>, _Up, false> 1278{ 1279 typedef _Alloc<_Up> type; 1280}; 1281 1282template <template <class, class> class _Alloc, class _Tp, class _A0, class _Up> 1283struct __allocator_traits_rebind<_Alloc<_Tp, _A0>, _Up, true> 1284{ 1285 typedef typename _Alloc<_Tp, _A0>::template rebind<_Up>::other type; 1286}; 1287 1288template <template <class, class> class _Alloc, class _Tp, class _A0, class _Up> 1289struct __allocator_traits_rebind<_Alloc<_Tp, _A0>, _Up, false> 1290{ 1291 typedef _Alloc<_Up, _A0> type; 1292}; 1293 1294template <template <class, class, class> class _Alloc, class _Tp, class _A0, 1295 class _A1, class _Up> 1296struct __allocator_traits_rebind<_Alloc<_Tp, _A0, _A1>, _Up, true> 1297{ 1298 typedef typename _Alloc<_Tp, _A0, _A1>::template rebind<_Up>::other type; 1299}; 1300 1301template <template <class, class, class> class _Alloc, class _Tp, class _A0, 1302 class _A1, class _Up> 1303struct __allocator_traits_rebind<_Alloc<_Tp, _A0, _A1>, _Up, false> 1304{ 1305 typedef _Alloc<_Up, _A0, _A1> type; 1306}; 1307 1308template <template <class, class, class, class> class _Alloc, class _Tp, class _A0, 1309 class _A1, class _A2, class _Up> 1310struct __allocator_traits_rebind<_Alloc<_Tp, _A0, _A1, _A2>, _Up, true> 1311{ 1312 typedef typename _Alloc<_Tp, _A0, _A1, _A2>::template rebind<_Up>::other type; 1313}; 1314 1315template <template <class, class, class, class> class _Alloc, class _Tp, class _A0, 1316 class _A1, class _A2, class _Up> 1317struct __allocator_traits_rebind<_Alloc<_Tp, _A0, _A1, _A2>, _Up, false> 1318{ 1319 typedef _Alloc<_Up, _A0, _A1, _A2> type; 1320}; 1321 1322#endif // _LIBCPP_HAS_NO_VARIADICS 1323 1324#ifndef _LIBCPP_CXX03_LANG 1325 1326template <class _Alloc, class _SizeType, class _ConstVoidPtr> 1327auto 1328__has_allocate_hint_test(_Alloc&& __a, _SizeType&& __sz, _ConstVoidPtr&& __p) 1329 -> decltype(__a.allocate(__sz, __p), true_type()); 1330 1331template <class _Alloc, class _SizeType, class _ConstVoidPtr> 1332auto 1333__has_allocate_hint_test(const _Alloc& __a, _SizeType&& __sz, _ConstVoidPtr&& __p) 1334 -> false_type; 1335 1336template <class _Alloc, class _SizeType, class _ConstVoidPtr> 1337struct __has_allocate_hint 1338 : integral_constant<bool, 1339 is_same< 1340 decltype(__has_allocate_hint_test(declval<_Alloc>(), 1341 declval<_SizeType>(), 1342 declval<_ConstVoidPtr>())), 1343 true_type>::value> 1344{ 1345}; 1346 1347#else // _LIBCPP_CXX03_LANG 1348 1349template <class _Alloc, class _SizeType, class _ConstVoidPtr> 1350struct __has_allocate_hint 1351 : true_type 1352{ 1353}; 1354 1355#endif // _LIBCPP_CXX03_LANG 1356 1357#if !defined(_LIBCPP_CXX03_LANG) 1358 1359template <class _Alloc, class _Tp, class ..._Args> 1360decltype(_VSTD::declval<_Alloc>().construct(_VSTD::declval<_Tp*>(), 1361 _VSTD::declval<_Args>()...), 1362 true_type()) 1363__has_construct_test(_Alloc&& __a, _Tp* __p, _Args&& ...__args); 1364 1365template <class _Alloc, class _Pointer, class ..._Args> 1366false_type 1367__has_construct_test(const _Alloc& __a, _Pointer&& __p, _Args&& ...__args); 1368 1369template <class _Alloc, class _Pointer, class ..._Args> 1370struct __has_construct 1371 : integral_constant<bool, 1372 is_same< 1373 decltype(__has_construct_test(declval<_Alloc>(), 1374 declval<_Pointer>(), 1375 declval<_Args>()...)), 1376 true_type>::value> 1377{ 1378}; 1379 1380template <class _Alloc, class _Pointer> 1381auto 1382__has_destroy_test(_Alloc&& __a, _Pointer&& __p) 1383 -> decltype(__a.destroy(__p), true_type()); 1384 1385template <class _Alloc, class _Pointer> 1386auto 1387__has_destroy_test(const _Alloc& __a, _Pointer&& __p) 1388 -> false_type; 1389 1390template <class _Alloc, class _Pointer> 1391struct __has_destroy 1392 : integral_constant<bool, 1393 is_same< 1394 decltype(__has_destroy_test(declval<_Alloc>(), 1395 declval<_Pointer>())), 1396 true_type>::value> 1397{ 1398}; 1399 1400template <class _Alloc> 1401auto 1402__has_max_size_test(_Alloc&& __a) 1403 -> decltype(__a.max_size(), true_type()); 1404 1405template <class _Alloc> 1406auto 1407__has_max_size_test(const volatile _Alloc& __a) 1408 -> false_type; 1409 1410template <class _Alloc> 1411struct __has_max_size 1412 : integral_constant<bool, 1413 is_same< 1414 decltype(__has_max_size_test(declval<_Alloc&>())), 1415 true_type>::value> 1416{ 1417}; 1418 1419template <class _Alloc> 1420auto 1421__has_select_on_container_copy_construction_test(_Alloc&& __a) 1422 -> decltype(__a.select_on_container_copy_construction(), true_type()); 1423 1424template <class _Alloc> 1425auto 1426__has_select_on_container_copy_construction_test(const volatile _Alloc& __a) 1427 -> false_type; 1428 1429template <class _Alloc> 1430struct __has_select_on_container_copy_construction 1431 : integral_constant<bool, 1432 is_same< 1433 decltype(__has_select_on_container_copy_construction_test(declval<_Alloc&>())), 1434 true_type>::value> 1435{ 1436}; 1437 1438#else // _LIBCPP_CXX03_LANG 1439 1440#ifndef _LIBCPP_HAS_NO_VARIADICS 1441 1442template <class _Alloc, class _Pointer, class ..._Args> 1443struct __has_construct 1444 : false_type 1445{ 1446}; 1447 1448#else // _LIBCPP_HAS_NO_VARIADICS 1449 1450template <class _Alloc, class _Pointer, class _Args> 1451struct __has_construct 1452 : false_type 1453{ 1454}; 1455 1456#endif // _LIBCPP_HAS_NO_VARIADICS 1457 1458template <class _Alloc, class _Pointer> 1459struct __has_destroy 1460 : false_type 1461{ 1462}; 1463 1464template <class _Alloc> 1465struct __has_max_size 1466 : true_type 1467{ 1468}; 1469 1470template <class _Alloc> 1471struct __has_select_on_container_copy_construction 1472 : false_type 1473{ 1474}; 1475 1476#endif // _LIBCPP_CXX03_LANG 1477 1478template <class _Alloc, class _Ptr, bool = __has_difference_type<_Alloc>::value> 1479struct __alloc_traits_difference_type 1480{ 1481 typedef typename pointer_traits<_Ptr>::difference_type type; 1482}; 1483 1484template <class _Alloc, class _Ptr> 1485struct __alloc_traits_difference_type<_Alloc, _Ptr, true> 1486{ 1487 typedef typename _Alloc::difference_type type; 1488}; 1489 1490template <class _Alloc> 1491struct _LIBCPP_TEMPLATE_VIS allocator_traits 1492{ 1493 typedef _Alloc allocator_type; 1494 typedef typename allocator_type::value_type value_type; 1495 1496 typedef typename __pointer_type<value_type, allocator_type>::type pointer; 1497 typedef typename __const_pointer<value_type, pointer, allocator_type>::type const_pointer; 1498 typedef typename __void_pointer<pointer, allocator_type>::type void_pointer; 1499 typedef typename __const_void_pointer<pointer, allocator_type>::type const_void_pointer; 1500 1501 typedef typename __alloc_traits_difference_type<allocator_type, pointer>::type difference_type; 1502 typedef typename __size_type<allocator_type, difference_type>::type size_type; 1503 1504 typedef typename __propagate_on_container_copy_assignment<allocator_type>::type 1505 propagate_on_container_copy_assignment; 1506 typedef typename __propagate_on_container_move_assignment<allocator_type>::type 1507 propagate_on_container_move_assignment; 1508 typedef typename __propagate_on_container_swap<allocator_type>::type 1509 propagate_on_container_swap; 1510 typedef typename __is_always_equal<allocator_type>::type 1511 is_always_equal; 1512 1513#ifndef _LIBCPP_CXX03_LANG 1514 template <class _Tp> using rebind_alloc = 1515 typename __allocator_traits_rebind<allocator_type, _Tp>::type; 1516 template <class _Tp> using rebind_traits = allocator_traits<rebind_alloc<_Tp>>; 1517#else // _LIBCPP_CXX03_LANG 1518 template <class _Tp> struct rebind_alloc 1519 {typedef typename __allocator_traits_rebind<allocator_type, _Tp>::type other;}; 1520 template <class _Tp> struct rebind_traits 1521 {typedef allocator_traits<typename rebind_alloc<_Tp>::other> other;}; 1522#endif // _LIBCPP_CXX03_LANG 1523 1524 _LIBCPP_INLINE_VISIBILITY 1525 static pointer allocate(allocator_type& __a, size_type __n) 1526 {return __a.allocate(__n);} 1527 _LIBCPP_INLINE_VISIBILITY 1528 static pointer allocate(allocator_type& __a, size_type __n, const_void_pointer __hint) 1529 {return allocate(__a, __n, __hint, 1530 __has_allocate_hint<allocator_type, size_type, const_void_pointer>());} 1531 1532 _LIBCPP_INLINE_VISIBILITY 1533 static void deallocate(allocator_type& __a, pointer __p, size_type __n) _NOEXCEPT 1534 {__a.deallocate(__p, __n);} 1535 1536#ifndef _LIBCPP_HAS_NO_VARIADICS 1537 template <class _Tp, class... _Args> 1538 _LIBCPP_INLINE_VISIBILITY 1539 static void construct(allocator_type& __a, _Tp* __p, _Args&&... __args) 1540 {__construct(__has_construct<allocator_type, _Tp*, _Args...>(), 1541 __a, __p, _VSTD::forward<_Args>(__args)...);} 1542#else // _LIBCPP_HAS_NO_VARIADICS 1543 template <class _Tp> 1544 _LIBCPP_INLINE_VISIBILITY 1545 static void construct(allocator_type& __a, _Tp* __p) 1546 { 1547 ::new ((void*)__p) _Tp(); 1548 } 1549 template <class _Tp, class _A0> 1550 _LIBCPP_INLINE_VISIBILITY 1551 static void construct(allocator_type& __a, _Tp* __p, const _A0& __a0) 1552 { 1553 ::new ((void*)__p) _Tp(__a0); 1554 } 1555 template <class _Tp, class _A0, class _A1> 1556 _LIBCPP_INLINE_VISIBILITY 1557 static void construct(allocator_type& __a, _Tp* __p, const _A0& __a0, 1558 const _A1& __a1) 1559 { 1560 ::new ((void*)__p) _Tp(__a0, __a1); 1561 } 1562 template <class _Tp, class _A0, class _A1, class _A2> 1563 _LIBCPP_INLINE_VISIBILITY 1564 static void construct(allocator_type& __a, _Tp* __p, const _A0& __a0, 1565 const _A1& __a1, const _A2& __a2) 1566 { 1567 ::new ((void*)__p) _Tp(__a0, __a1, __a2); 1568 } 1569#endif // _LIBCPP_HAS_NO_VARIADICS 1570 1571 template <class _Tp> 1572 _LIBCPP_INLINE_VISIBILITY 1573 static void destroy(allocator_type& __a, _Tp* __p) 1574 {__destroy(__has_destroy<allocator_type, _Tp*>(), __a, __p);} 1575 1576 _LIBCPP_INLINE_VISIBILITY 1577 static size_type max_size(const allocator_type& __a) _NOEXCEPT 1578 {return __max_size(__has_max_size<const allocator_type>(), __a);} 1579 1580 _LIBCPP_INLINE_VISIBILITY 1581 static allocator_type 1582 select_on_container_copy_construction(const allocator_type& __a) 1583 {return select_on_container_copy_construction( 1584 __has_select_on_container_copy_construction<const allocator_type>(), 1585 __a);} 1586 1587 template <class _Ptr> 1588 _LIBCPP_INLINE_VISIBILITY 1589 static 1590 void 1591 __construct_forward(allocator_type& __a, _Ptr __begin1, _Ptr __end1, _Ptr& __begin2) 1592 { 1593 for (; __begin1 != __end1; ++__begin1, ++__begin2) 1594 construct(__a, _VSTD::__to_raw_pointer(__begin2), _VSTD::move_if_noexcept(*__begin1)); 1595 } 1596 1597 template <class _Tp> 1598 _LIBCPP_INLINE_VISIBILITY 1599 static 1600 typename enable_if 1601 < 1602 (is_same<allocator_type, allocator<_Tp> >::value 1603 || !__has_construct<allocator_type, _Tp*, _Tp>::value) && 1604 is_trivially_move_constructible<_Tp>::value, 1605 void 1606 >::type 1607 __construct_forward(allocator_type&, _Tp* __begin1, _Tp* __end1, _Tp*& __begin2) 1608 { 1609 ptrdiff_t _Np = __end1 - __begin1; 1610 if (_Np > 0) 1611 { 1612 _VSTD::memcpy(__begin2, __begin1, _Np * sizeof(_Tp)); 1613 __begin2 += _Np; 1614 } 1615 } 1616 1617 template <class _Iter, class _Ptr> 1618 _LIBCPP_INLINE_VISIBILITY 1619 static 1620 void 1621 __construct_range_forward(allocator_type& __a, _Iter __begin1, _Iter __end1, _Ptr& __begin2) 1622 { 1623 for (; __begin1 != __end1; ++__begin1, (void) ++__begin2) 1624 construct(__a, _VSTD::__to_raw_pointer(__begin2), *__begin1); 1625 } 1626 1627 template <class _Tp> 1628 _LIBCPP_INLINE_VISIBILITY 1629 static 1630 typename enable_if 1631 < 1632 (is_same<allocator_type, allocator<_Tp> >::value 1633 || !__has_construct<allocator_type, _Tp*, _Tp>::value) && 1634 is_trivially_move_constructible<_Tp>::value, 1635 void 1636 >::type 1637 __construct_range_forward(allocator_type&, _Tp* __begin1, _Tp* __end1, _Tp*& __begin2) 1638 { 1639 typedef typename remove_const<_Tp>::type _Vp; 1640 ptrdiff_t _Np = __end1 - __begin1; 1641 if (_Np > 0) 1642 { 1643 _VSTD::memcpy(const_cast<_Vp*>(__begin2), __begin1, _Np * sizeof(_Tp)); 1644 __begin2 += _Np; 1645 } 1646 } 1647 1648 template <class _Ptr> 1649 _LIBCPP_INLINE_VISIBILITY 1650 static 1651 void 1652 __construct_backward(allocator_type& __a, _Ptr __begin1, _Ptr __end1, _Ptr& __end2) 1653 { 1654 while (__end1 != __begin1) 1655 { 1656 construct(__a, _VSTD::__to_raw_pointer(__end2-1), _VSTD::move_if_noexcept(*--__end1)); 1657 --__end2; 1658 } 1659 } 1660 1661 template <class _Tp> 1662 _LIBCPP_INLINE_VISIBILITY 1663 static 1664 typename enable_if 1665 < 1666 (is_same<allocator_type, allocator<_Tp> >::value 1667 || !__has_construct<allocator_type, _Tp*, _Tp>::value) && 1668 is_trivially_move_constructible<_Tp>::value, 1669 void 1670 >::type 1671 __construct_backward(allocator_type&, _Tp* __begin1, _Tp* __end1, _Tp*& __end2) 1672 { 1673 ptrdiff_t _Np = __end1 - __begin1; 1674 __end2 -= _Np; 1675 if (_Np > 0) 1676 _VSTD::memcpy(__end2, __begin1, _Np * sizeof(_Tp)); 1677 } 1678 1679private: 1680 1681 _LIBCPP_INLINE_VISIBILITY 1682 static pointer allocate(allocator_type& __a, size_type __n, 1683 const_void_pointer __hint, true_type) 1684 {return __a.allocate(__n, __hint);} 1685 _LIBCPP_INLINE_VISIBILITY 1686 static pointer allocate(allocator_type& __a, size_type __n, 1687 const_void_pointer, false_type) 1688 {return __a.allocate(__n);} 1689 1690#ifndef _LIBCPP_HAS_NO_VARIADICS 1691 template <class _Tp, class... _Args> 1692 _LIBCPP_INLINE_VISIBILITY 1693 static void __construct(true_type, allocator_type& __a, _Tp* __p, _Args&&... __args) 1694 {__a.construct(__p, _VSTD::forward<_Args>(__args)...);} 1695 template <class _Tp, class... _Args> 1696 _LIBCPP_INLINE_VISIBILITY 1697 static void __construct(false_type, allocator_type&, _Tp* __p, _Args&&... __args) 1698 { 1699 ::new ((void*)__p) _Tp(_VSTD::forward<_Args>(__args)...); 1700 } 1701#endif // _LIBCPP_HAS_NO_VARIADICS 1702 1703 template <class _Tp> 1704 _LIBCPP_INLINE_VISIBILITY 1705 static void __destroy(true_type, allocator_type& __a, _Tp* __p) 1706 {__a.destroy(__p);} 1707 template <class _Tp> 1708 _LIBCPP_INLINE_VISIBILITY 1709 static void __destroy(false_type, allocator_type&, _Tp* __p) 1710 { 1711 __p->~_Tp(); 1712 } 1713 1714 _LIBCPP_INLINE_VISIBILITY 1715 static size_type __max_size(true_type, const allocator_type& __a) 1716 {return __a.max_size();} 1717 _LIBCPP_INLINE_VISIBILITY 1718 static size_type __max_size(false_type, const allocator_type&) 1719 {return numeric_limits<size_type>::max() / sizeof(value_type);} 1720 1721 _LIBCPP_INLINE_VISIBILITY 1722 static allocator_type 1723 select_on_container_copy_construction(true_type, const allocator_type& __a) 1724 {return __a.select_on_container_copy_construction();} 1725 _LIBCPP_INLINE_VISIBILITY 1726 static allocator_type 1727 select_on_container_copy_construction(false_type, const allocator_type& __a) 1728 {return __a;} 1729}; 1730 1731template <class _Traits, class _Tp> 1732struct __rebind_alloc_helper 1733{ 1734#ifndef _LIBCPP_CXX03_LANG 1735 typedef typename _Traits::template rebind_alloc<_Tp> type; 1736#else 1737 typedef typename _Traits::template rebind_alloc<_Tp>::other type; 1738#endif 1739}; 1740 1741// allocator 1742 1743template <class _Tp> 1744class _LIBCPP_TEMPLATE_VIS allocator 1745{ 1746public: 1747 typedef size_t size_type; 1748 typedef ptrdiff_t difference_type; 1749 typedef _Tp* pointer; 1750 typedef const _Tp* const_pointer; 1751 typedef _Tp& reference; 1752 typedef const _Tp& const_reference; 1753 typedef _Tp value_type; 1754 1755 typedef true_type propagate_on_container_move_assignment; 1756 typedef true_type is_always_equal; 1757 1758 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 1759 1760 _LIBCPP_INLINE_VISIBILITY allocator() _NOEXCEPT {} 1761 template <class _Up> _LIBCPP_INLINE_VISIBILITY allocator(const allocator<_Up>&) _NOEXCEPT {} 1762 _LIBCPP_INLINE_VISIBILITY pointer address(reference __x) const _NOEXCEPT 1763 {return _VSTD::addressof(__x);} 1764 _LIBCPP_INLINE_VISIBILITY const_pointer address(const_reference __x) const _NOEXCEPT 1765 {return _VSTD::addressof(__x);} 1766 _LIBCPP_INLINE_VISIBILITY pointer allocate(size_type __n, allocator<void>::const_pointer = 0) 1767 { 1768 if (__n > max_size()) 1769 __throw_length_error("allocator<T>::allocate(size_t n)" 1770 " 'n' exceeds maximum supported size"); 1771 return static_cast<pointer>(_VSTD::__allocate(__n * sizeof(_Tp))); 1772 } 1773 _LIBCPP_INLINE_VISIBILITY void deallocate(pointer __p, size_type) _NOEXCEPT 1774 {_VSTD::__libcpp_deallocate((void*)__p);} 1775 _LIBCPP_INLINE_VISIBILITY size_type max_size() const _NOEXCEPT 1776 {return size_type(~0) / sizeof(_Tp);} 1777#if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1778 template <class _Up, class... _Args> 1779 _LIBCPP_INLINE_VISIBILITY 1780 void 1781 construct(_Up* __p, _Args&&... __args) 1782 { 1783 ::new((void*)__p) _Up(_VSTD::forward<_Args>(__args)...); 1784 } 1785#else // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1786 _LIBCPP_INLINE_VISIBILITY 1787 void 1788 construct(pointer __p) 1789 { 1790 ::new((void*)__p) _Tp(); 1791 } 1792# if defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) 1793 1794 template <class _A0> 1795 _LIBCPP_INLINE_VISIBILITY 1796 void 1797 construct(pointer __p, _A0& __a0) 1798 { 1799 ::new((void*)__p) _Tp(__a0); 1800 } 1801 template <class _A0> 1802 _LIBCPP_INLINE_VISIBILITY 1803 void 1804 construct(pointer __p, const _A0& __a0) 1805 { 1806 ::new((void*)__p) _Tp(__a0); 1807 } 1808# endif // defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) 1809 template <class _A0, class _A1> 1810 _LIBCPP_INLINE_VISIBILITY 1811 void 1812 construct(pointer __p, _A0& __a0, _A1& __a1) 1813 { 1814 ::new((void*)__p) _Tp(__a0, __a1); 1815 } 1816 template <class _A0, class _A1> 1817 _LIBCPP_INLINE_VISIBILITY 1818 void 1819 construct(pointer __p, const _A0& __a0, _A1& __a1) 1820 { 1821 ::new((void*)__p) _Tp(__a0, __a1); 1822 } 1823 template <class _A0, class _A1> 1824 _LIBCPP_INLINE_VISIBILITY 1825 void 1826 construct(pointer __p, _A0& __a0, const _A1& __a1) 1827 { 1828 ::new((void*)__p) _Tp(__a0, __a1); 1829 } 1830 template <class _A0, class _A1> 1831 _LIBCPP_INLINE_VISIBILITY 1832 void 1833 construct(pointer __p, const _A0& __a0, const _A1& __a1) 1834 { 1835 ::new((void*)__p) _Tp(__a0, __a1); 1836 } 1837#endif // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1838 _LIBCPP_INLINE_VISIBILITY void destroy(pointer __p) {__p->~_Tp();} 1839}; 1840 1841template <class _Tp> 1842class _LIBCPP_TEMPLATE_VIS allocator<const _Tp> 1843{ 1844public: 1845 typedef size_t size_type; 1846 typedef ptrdiff_t difference_type; 1847 typedef const _Tp* pointer; 1848 typedef const _Tp* const_pointer; 1849 typedef const _Tp& reference; 1850 typedef const _Tp& const_reference; 1851 typedef const _Tp value_type; 1852 1853 typedef true_type propagate_on_container_move_assignment; 1854 typedef true_type is_always_equal; 1855 1856 template <class _Up> struct rebind {typedef allocator<_Up> other;}; 1857 1858 _LIBCPP_INLINE_VISIBILITY allocator() _NOEXCEPT {} 1859 template <class _Up> _LIBCPP_INLINE_VISIBILITY allocator(const allocator<_Up>&) _NOEXCEPT {} 1860 _LIBCPP_INLINE_VISIBILITY const_pointer address(const_reference __x) const _NOEXCEPT 1861 {return _VSTD::addressof(__x);} 1862 _LIBCPP_INLINE_VISIBILITY pointer allocate(size_type __n, allocator<void>::const_pointer = 0) 1863 { 1864 if (__n > max_size()) 1865 __throw_length_error("allocator<const T>::allocate(size_t n)" 1866 " 'n' exceeds maximum supported size"); 1867 return static_cast<pointer>(_VSTD::__allocate(__n * sizeof(_Tp))); 1868 } 1869 _LIBCPP_INLINE_VISIBILITY void deallocate(pointer __p, size_type) _NOEXCEPT 1870 {_VSTD::__libcpp_deallocate((void*)__p);} 1871 _LIBCPP_INLINE_VISIBILITY size_type max_size() const _NOEXCEPT 1872 {return size_type(~0) / sizeof(_Tp);} 1873#if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1874 template <class _Up, class... _Args> 1875 _LIBCPP_INLINE_VISIBILITY 1876 void 1877 construct(_Up* __p, _Args&&... __args) 1878 { 1879 ::new((void*)__p) _Up(_VSTD::forward<_Args>(__args)...); 1880 } 1881#else // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1882 _LIBCPP_INLINE_VISIBILITY 1883 void 1884 construct(pointer __p) 1885 { 1886 ::new((void*)__p) _Tp(); 1887 } 1888# if defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) 1889 1890 template <class _A0> 1891 _LIBCPP_INLINE_VISIBILITY 1892 void 1893 construct(pointer __p, _A0& __a0) 1894 { 1895 ::new((void*)__p) _Tp(__a0); 1896 } 1897 template <class _A0> 1898 _LIBCPP_INLINE_VISIBILITY 1899 void 1900 construct(pointer __p, const _A0& __a0) 1901 { 1902 ::new((void*)__p) _Tp(__a0); 1903 } 1904# endif // defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) 1905 template <class _A0, class _A1> 1906 _LIBCPP_INLINE_VISIBILITY 1907 void 1908 construct(pointer __p, _A0& __a0, _A1& __a1) 1909 { 1910 ::new((void*)__p) _Tp(__a0, __a1); 1911 } 1912 template <class _A0, class _A1> 1913 _LIBCPP_INLINE_VISIBILITY 1914 void 1915 construct(pointer __p, const _A0& __a0, _A1& __a1) 1916 { 1917 ::new((void*)__p) _Tp(__a0, __a1); 1918 } 1919 template <class _A0, class _A1> 1920 _LIBCPP_INLINE_VISIBILITY 1921 void 1922 construct(pointer __p, _A0& __a0, const _A1& __a1) 1923 { 1924 ::new((void*)__p) _Tp(__a0, __a1); 1925 } 1926 template <class _A0, class _A1> 1927 _LIBCPP_INLINE_VISIBILITY 1928 void 1929 construct(pointer __p, const _A0& __a0, const _A1& __a1) 1930 { 1931 ::new((void*)__p) _Tp(__a0, __a1); 1932 } 1933#endif // !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_VARIADICS) 1934 _LIBCPP_INLINE_VISIBILITY void destroy(pointer __p) {__p->~_Tp();} 1935}; 1936 1937template <class _Tp, class _Up> 1938inline _LIBCPP_INLINE_VISIBILITY 1939bool operator==(const allocator<_Tp>&, const allocator<_Up>&) _NOEXCEPT {return true;} 1940 1941template <class _Tp, class _Up> 1942inline _LIBCPP_INLINE_VISIBILITY 1943bool operator!=(const allocator<_Tp>&, const allocator<_Up>&) _NOEXCEPT {return false;} 1944 1945template <class _OutputIterator, class _Tp> 1946class _LIBCPP_TEMPLATE_VIS raw_storage_iterator 1947 : public iterator<output_iterator_tag, 1948 _Tp, // purposefully not C++03 1949 ptrdiff_t, // purposefully not C++03 1950 _Tp*, // purposefully not C++03 1951 raw_storage_iterator<_OutputIterator, _Tp>&> // purposefully not C++03 1952{ 1953private: 1954 _OutputIterator __x_; 1955public: 1956 _LIBCPP_INLINE_VISIBILITY explicit raw_storage_iterator(_OutputIterator __x) : __x_(__x) {} 1957 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator*() {return *this;} 1958 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator=(const _Tp& __element) 1959 {::new(&*__x_) _Tp(__element); return *this;} 1960#if _LIBCPP_STD_VER >= 14 1961 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator=(_Tp&& __element) 1962 {::new(&*__x_) _Tp(_VSTD::move(__element)); return *this;} 1963#endif 1964 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator& operator++() {++__x_; return *this;} 1965 _LIBCPP_INLINE_VISIBILITY raw_storage_iterator operator++(int) 1966 {raw_storage_iterator __t(*this); ++__x_; return __t;} 1967#if _LIBCPP_STD_VER >= 14 1968 _LIBCPP_INLINE_VISIBILITY _OutputIterator base() const { return __x_; } 1969#endif 1970}; 1971 1972template <class _Tp> 1973pair<_Tp*, ptrdiff_t> 1974get_temporary_buffer(ptrdiff_t __n) _NOEXCEPT 1975{ 1976 pair<_Tp*, ptrdiff_t> __r(0, 0); 1977 const ptrdiff_t __m = (~ptrdiff_t(0) ^ 1978 ptrdiff_t(ptrdiff_t(1) << (sizeof(ptrdiff_t) * __CHAR_BIT__ - 1))) 1979 / sizeof(_Tp); 1980 if (__n > __m) 1981 __n = __m; 1982 while (__n > 0) 1983 { 1984 __r.first = static_cast<_Tp*>(::operator new(__n * sizeof(_Tp), nothrow)); 1985 if (__r.first) 1986 { 1987 __r.second = __n; 1988 break; 1989 } 1990 __n /= 2; 1991 } 1992 return __r; 1993} 1994 1995template <class _Tp> 1996inline _LIBCPP_INLINE_VISIBILITY 1997void return_temporary_buffer(_Tp* __p) _NOEXCEPT {::operator delete(__p);} 1998 1999template <class _Tp> 2000struct auto_ptr_ref 2001{ 2002 _Tp* __ptr_; 2003}; 2004 2005template<class _Tp> 2006class _LIBCPP_TEMPLATE_VIS auto_ptr 2007{ 2008private: 2009 _Tp* __ptr_; 2010public: 2011 typedef _Tp element_type; 2012 2013 _LIBCPP_INLINE_VISIBILITY explicit auto_ptr(_Tp* __p = 0) throw() : __ptr_(__p) {} 2014 _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr& __p) throw() : __ptr_(__p.release()) {} 2015 template<class _Up> _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr<_Up>& __p) throw() 2016 : __ptr_(__p.release()) {} 2017 _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr& __p) throw() 2018 {reset(__p.release()); return *this;} 2019 template<class _Up> _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr<_Up>& __p) throw() 2020 {reset(__p.release()); return *this;} 2021 _LIBCPP_INLINE_VISIBILITY auto_ptr& operator=(auto_ptr_ref<_Tp> __p) throw() 2022 {reset(__p.__ptr_); return *this;} 2023 _LIBCPP_INLINE_VISIBILITY ~auto_ptr() throw() {delete __ptr_;} 2024 2025 _LIBCPP_INLINE_VISIBILITY _Tp& operator*() const throw() 2026 {return *__ptr_;} 2027 _LIBCPP_INLINE_VISIBILITY _Tp* operator->() const throw() {return __ptr_;} 2028 _LIBCPP_INLINE_VISIBILITY _Tp* get() const throw() {return __ptr_;} 2029 _LIBCPP_INLINE_VISIBILITY _Tp* release() throw() 2030 { 2031 _Tp* __t = __ptr_; 2032 __ptr_ = 0; 2033 return __t; 2034 } 2035 _LIBCPP_INLINE_VISIBILITY void reset(_Tp* __p = 0) throw() 2036 { 2037 if (__ptr_ != __p) 2038 delete __ptr_; 2039 __ptr_ = __p; 2040 } 2041 2042 _LIBCPP_INLINE_VISIBILITY auto_ptr(auto_ptr_ref<_Tp> __p) throw() : __ptr_(__p.__ptr_) {} 2043 template<class _Up> _LIBCPP_INLINE_VISIBILITY operator auto_ptr_ref<_Up>() throw() 2044 {auto_ptr_ref<_Up> __t; __t.__ptr_ = release(); return __t;} 2045 template<class _Up> _LIBCPP_INLINE_VISIBILITY operator auto_ptr<_Up>() throw() 2046 {return auto_ptr<_Up>(release());} 2047}; 2048 2049template <> 2050class _LIBCPP_TEMPLATE_VIS auto_ptr<void> 2051{ 2052public: 2053 typedef void element_type; 2054}; 2055 2056template <class _T1, class _T2, bool = is_same<typename remove_cv<_T1>::type, 2057 typename remove_cv<_T2>::type>::value, 2058 bool = is_empty<_T1>::value 2059 && !__libcpp_is_final<_T1>::value, 2060 bool = is_empty<_T2>::value 2061 && !__libcpp_is_final<_T2>::value 2062 > 2063struct __libcpp_compressed_pair_switch; 2064 2065template <class _T1, class _T2, bool IsSame> 2066struct __libcpp_compressed_pair_switch<_T1, _T2, IsSame, false, false> {enum {value = 0};}; 2067 2068template <class _T1, class _T2, bool IsSame> 2069struct __libcpp_compressed_pair_switch<_T1, _T2, IsSame, true, false> {enum {value = 1};}; 2070 2071template <class _T1, class _T2, bool IsSame> 2072struct __libcpp_compressed_pair_switch<_T1, _T2, IsSame, false, true> {enum {value = 2};}; 2073 2074template <class _T1, class _T2> 2075struct __libcpp_compressed_pair_switch<_T1, _T2, false, true, true> {enum {value = 3};}; 2076 2077template <class _T1, class _T2> 2078struct __libcpp_compressed_pair_switch<_T1, _T2, true, true, true> {enum {value = 1};}; 2079 2080template <class _T1, class _T2, unsigned = __libcpp_compressed_pair_switch<_T1, _T2>::value> 2081class __libcpp_compressed_pair_imp; 2082 2083template <class _T1, class _T2> 2084class __libcpp_compressed_pair_imp<_T1, _T2, 0> 2085{ 2086private: 2087 _T1 __first_; 2088 _T2 __second_; 2089public: 2090 typedef _T1 _T1_param; 2091 typedef _T2 _T2_param; 2092 2093 typedef typename remove_reference<_T1>::type& _T1_reference; 2094 typedef typename remove_reference<_T2>::type& _T2_reference; 2095 2096 typedef const typename remove_reference<_T1>::type& _T1_const_reference; 2097 typedef const typename remove_reference<_T2>::type& _T2_const_reference; 2098 2099 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp() : __first_(), __second_() {} 2100 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T1_param __t1) 2101 : __first_(_VSTD::forward<_T1_param>(__t1)), __second_() {} 2102 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T2_param __t2) 2103 : __first_(), __second_(_VSTD::forward<_T2_param>(__t2)) {} 2104 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp(_T1_param __t1, _T2_param __t2) 2105 : __first_(_VSTD::forward<_T1_param>(__t1)), __second_(_VSTD::forward<_T2_param>(__t2)) {} 2106 2107#ifndef _LIBCPP_HAS_NO_VARIADICS 2108 2109 template <class... _Args1, class... _Args2, size_t... _I1, size_t... _I2> 2110 _LIBCPP_INLINE_VISIBILITY 2111 __libcpp_compressed_pair_imp(piecewise_construct_t, 2112 tuple<_Args1...> __first_args, 2113 tuple<_Args2...> __second_args, 2114 __tuple_indices<_I1...>, 2115 __tuple_indices<_I2...>) 2116 : __first_(_VSTD::forward<_Args1>(_VSTD::get<_I1>(__first_args))...), 2117 __second_(_VSTD::forward<_Args2>(_VSTD::get<_I2>(__second_args))...) 2118 {} 2119 2120#endif // _LIBCPP_HAS_NO_VARIADICS 2121 2122 _LIBCPP_INLINE_VISIBILITY _T1_reference first() _NOEXCEPT {return __first_;} 2123 _LIBCPP_INLINE_VISIBILITY _T1_const_reference first() const _NOEXCEPT {return __first_;} 2124 2125 _LIBCPP_INLINE_VISIBILITY _T2_reference second() _NOEXCEPT {return __second_;} 2126 _LIBCPP_INLINE_VISIBILITY _T2_const_reference second() const _NOEXCEPT {return __second_;} 2127 2128 _LIBCPP_INLINE_VISIBILITY void swap(__libcpp_compressed_pair_imp& __x) 2129 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2130 __is_nothrow_swappable<_T2>::value) 2131 { 2132 using _VSTD::swap; 2133 swap(__first_, __x.__first_); 2134 swap(__second_, __x.__second_); 2135 } 2136}; 2137 2138template <class _T1, class _T2> 2139class __libcpp_compressed_pair_imp<_T1, _T2, 1> 2140 : private _T1 2141{ 2142private: 2143 _T2 __second_; 2144public: 2145 typedef _T1 _T1_param; 2146 typedef _T2 _T2_param; 2147 2148 typedef _T1& _T1_reference; 2149 typedef typename remove_reference<_T2>::type& _T2_reference; 2150 2151 typedef const _T1& _T1_const_reference; 2152 typedef const typename remove_reference<_T2>::type& _T2_const_reference; 2153 2154 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp() : __second_() {} 2155 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T1_param __t1) 2156 : _T1(_VSTD::forward<_T1_param>(__t1)), __second_() {} 2157 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T2_param __t2) 2158 : __second_(_VSTD::forward<_T2_param>(__t2)) {} 2159 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp(_T1_param __t1, _T2_param __t2) 2160 : _T1(_VSTD::forward<_T1_param>(__t1)), __second_(_VSTD::forward<_T2_param>(__t2)) {} 2161 2162#ifndef _LIBCPP_HAS_NO_VARIADICS 2163 2164 template <class... _Args1, class... _Args2, size_t... _I1, size_t... _I2> 2165 _LIBCPP_INLINE_VISIBILITY 2166 __libcpp_compressed_pair_imp(piecewise_construct_t, 2167 tuple<_Args1...> __first_args, 2168 tuple<_Args2...> __second_args, 2169 __tuple_indices<_I1...>, 2170 __tuple_indices<_I2...>) 2171 : _T1(_VSTD::forward<_Args1>(_VSTD::get<_I1>(__first_args))...), 2172 __second_(_VSTD::forward<_Args2>(_VSTD::get<_I2>(__second_args))...) 2173 {} 2174 2175#endif // _LIBCPP_HAS_NO_VARIADICS 2176 2177 _LIBCPP_INLINE_VISIBILITY _T1_reference first() _NOEXCEPT {return *this;} 2178 _LIBCPP_INLINE_VISIBILITY _T1_const_reference first() const _NOEXCEPT {return *this;} 2179 2180 _LIBCPP_INLINE_VISIBILITY _T2_reference second() _NOEXCEPT {return __second_;} 2181 _LIBCPP_INLINE_VISIBILITY _T2_const_reference second() const _NOEXCEPT {return __second_;} 2182 2183 _LIBCPP_INLINE_VISIBILITY void swap(__libcpp_compressed_pair_imp& __x) 2184 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2185 __is_nothrow_swappable<_T2>::value) 2186 { 2187 using _VSTD::swap; 2188 swap(__second_, __x.__second_); 2189 } 2190}; 2191 2192template <class _T1, class _T2> 2193class __libcpp_compressed_pair_imp<_T1, _T2, 2> 2194 : private _T2 2195{ 2196private: 2197 _T1 __first_; 2198public: 2199 typedef _T1 _T1_param; 2200 typedef _T2 _T2_param; 2201 2202 typedef typename remove_reference<_T1>::type& _T1_reference; 2203 typedef _T2& _T2_reference; 2204 2205 typedef const typename remove_reference<_T1>::type& _T1_const_reference; 2206 typedef const _T2& _T2_const_reference; 2207 2208 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp() : __first_() {} 2209 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T1_param __t1) 2210 : __first_(_VSTD::forward<_T1_param>(__t1)) {} 2211 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T2_param __t2) 2212 : _T2(_VSTD::forward<_T2_param>(__t2)), __first_() {} 2213 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp(_T1_param __t1, _T2_param __t2) 2214 _NOEXCEPT_(is_nothrow_move_constructible<_T1>::value && 2215 is_nothrow_move_constructible<_T2>::value) 2216 : _T2(_VSTD::forward<_T2_param>(__t2)), __first_(_VSTD::forward<_T1_param>(__t1)) {} 2217 2218#ifndef _LIBCPP_HAS_NO_VARIADICS 2219 2220 template <class... _Args1, class... _Args2, size_t... _I1, size_t... _I2> 2221 _LIBCPP_INLINE_VISIBILITY 2222 __libcpp_compressed_pair_imp(piecewise_construct_t, 2223 tuple<_Args1...> __first_args, 2224 tuple<_Args2...> __second_args, 2225 __tuple_indices<_I1...>, 2226 __tuple_indices<_I2...>) 2227 : _T2(_VSTD::forward<_Args2>(_VSTD::get<_I2>(__second_args))...), 2228 __first_(_VSTD::forward<_Args1>(_VSTD::get<_I1>(__first_args))...) 2229 2230 {} 2231 2232#endif // _LIBCPP_HAS_NO_VARIADICS 2233 2234 _LIBCPP_INLINE_VISIBILITY _T1_reference first() _NOEXCEPT {return __first_;} 2235 _LIBCPP_INLINE_VISIBILITY _T1_const_reference first() const _NOEXCEPT {return __first_;} 2236 2237 _LIBCPP_INLINE_VISIBILITY _T2_reference second() _NOEXCEPT {return *this;} 2238 _LIBCPP_INLINE_VISIBILITY _T2_const_reference second() const _NOEXCEPT {return *this;} 2239 2240 _LIBCPP_INLINE_VISIBILITY void swap(__libcpp_compressed_pair_imp& __x) 2241 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2242 __is_nothrow_swappable<_T2>::value) 2243 { 2244 using _VSTD::swap; 2245 swap(__first_, __x.__first_); 2246 } 2247}; 2248 2249template <class _T1, class _T2> 2250class __libcpp_compressed_pair_imp<_T1, _T2, 3> 2251 : private _T1, 2252 private _T2 2253{ 2254public: 2255 typedef _T1 _T1_param; 2256 typedef _T2 _T2_param; 2257 2258 typedef _T1& _T1_reference; 2259 typedef _T2& _T2_reference; 2260 2261 typedef const _T1& _T1_const_reference; 2262 typedef const _T2& _T2_const_reference; 2263 2264 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp() {} 2265 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T1_param __t1) 2266 : _T1(_VSTD::forward<_T1_param>(__t1)) {} 2267 _LIBCPP_INLINE_VISIBILITY explicit __libcpp_compressed_pair_imp(_T2_param __t2) 2268 : _T2(_VSTD::forward<_T2_param>(__t2)) {} 2269 _LIBCPP_INLINE_VISIBILITY __libcpp_compressed_pair_imp(_T1_param __t1, _T2_param __t2) 2270 : _T1(_VSTD::forward<_T1_param>(__t1)), _T2(_VSTD::forward<_T2_param>(__t2)) {} 2271 2272#ifndef _LIBCPP_HAS_NO_VARIADICS 2273 2274 template <class... _Args1, class... _Args2, size_t... _I1, size_t... _I2> 2275 _LIBCPP_INLINE_VISIBILITY 2276 __libcpp_compressed_pair_imp(piecewise_construct_t, 2277 tuple<_Args1...> __first_args, 2278 tuple<_Args2...> __second_args, 2279 __tuple_indices<_I1...>, 2280 __tuple_indices<_I2...>) 2281 : _T1(_VSTD::forward<_Args1>(_VSTD::get<_I1>(__first_args))...), 2282 _T2(_VSTD::forward<_Args2>(_VSTD::get<_I2>(__second_args))...) 2283 {} 2284 2285#endif // _LIBCPP_HAS_NO_VARIADICS 2286 2287 _LIBCPP_INLINE_VISIBILITY _T1_reference first() _NOEXCEPT {return *this;} 2288 _LIBCPP_INLINE_VISIBILITY _T1_const_reference first() const _NOEXCEPT {return *this;} 2289 2290 _LIBCPP_INLINE_VISIBILITY _T2_reference second() _NOEXCEPT {return *this;} 2291 _LIBCPP_INLINE_VISIBILITY _T2_const_reference second() const _NOEXCEPT {return *this;} 2292 2293 _LIBCPP_INLINE_VISIBILITY void swap(__libcpp_compressed_pair_imp&) 2294 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2295 __is_nothrow_swappable<_T2>::value) 2296 { 2297 } 2298}; 2299 2300template <class _T1, class _T2> 2301class __compressed_pair 2302 : private __libcpp_compressed_pair_imp<_T1, _T2> 2303{ 2304 typedef __libcpp_compressed_pair_imp<_T1, _T2> base; 2305public: 2306 typedef typename base::_T1_param _T1_param; 2307 typedef typename base::_T2_param _T2_param; 2308 2309 typedef typename base::_T1_reference _T1_reference; 2310 typedef typename base::_T2_reference _T2_reference; 2311 2312 typedef typename base::_T1_const_reference _T1_const_reference; 2313 typedef typename base::_T2_const_reference _T2_const_reference; 2314 2315 _LIBCPP_INLINE_VISIBILITY __compressed_pair() {} 2316 _LIBCPP_INLINE_VISIBILITY explicit __compressed_pair(_T1_param __t1) 2317 : base(_VSTD::forward<_T1_param>(__t1)) {} 2318 _LIBCPP_INLINE_VISIBILITY explicit __compressed_pair(_T2_param __t2) 2319 : base(_VSTD::forward<_T2_param>(__t2)) {} 2320 _LIBCPP_INLINE_VISIBILITY __compressed_pair(_T1_param __t1, _T2_param __t2) 2321 : base(_VSTD::forward<_T1_param>(__t1), _VSTD::forward<_T2_param>(__t2)) {} 2322 2323#ifndef _LIBCPP_HAS_NO_VARIADICS 2324 2325 template <class... _Args1, class... _Args2> 2326 _LIBCPP_INLINE_VISIBILITY 2327 __compressed_pair(piecewise_construct_t __pc, tuple<_Args1...> __first_args, 2328 tuple<_Args2...> __second_args) 2329 : base(__pc, _VSTD::move(__first_args), _VSTD::move(__second_args), 2330 typename __make_tuple_indices<sizeof...(_Args1)>::type(), 2331 typename __make_tuple_indices<sizeof...(_Args2) >::type()) 2332 {} 2333 2334#endif // _LIBCPP_HAS_NO_VARIADICS 2335 2336 _LIBCPP_INLINE_VISIBILITY _T1_reference first() _NOEXCEPT {return base::first();} 2337 _LIBCPP_INLINE_VISIBILITY _T1_const_reference first() const _NOEXCEPT {return base::first();} 2338 2339 _LIBCPP_INLINE_VISIBILITY _T2_reference second() _NOEXCEPT {return base::second();} 2340 _LIBCPP_INLINE_VISIBILITY _T2_const_reference second() const _NOEXCEPT {return base::second();} 2341 2342 _LIBCPP_INLINE_VISIBILITY void swap(__compressed_pair& __x) 2343 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2344 __is_nothrow_swappable<_T2>::value) 2345 {base::swap(__x);} 2346}; 2347 2348template <class _T1, class _T2> 2349inline _LIBCPP_INLINE_VISIBILITY 2350void 2351swap(__compressed_pair<_T1, _T2>& __x, __compressed_pair<_T1, _T2>& __y) 2352 _NOEXCEPT_(__is_nothrow_swappable<_T1>::value && 2353 __is_nothrow_swappable<_T2>::value) 2354 {__x.swap(__y);} 2355 2356// __same_or_less_cv_qualified 2357 2358template <class _Ptr1, class _Ptr2, 2359 bool = is_same<typename remove_cv<typename pointer_traits<_Ptr1>::element_type>::type, 2360 typename remove_cv<typename pointer_traits<_Ptr2>::element_type>::type 2361 >::value 2362 > 2363struct __same_or_less_cv_qualified_imp 2364 : is_convertible<_Ptr1, _Ptr2> {}; 2365 2366template <class _Ptr1, class _Ptr2> 2367struct __same_or_less_cv_qualified_imp<_Ptr1, _Ptr2, false> 2368 : false_type {}; 2369 2370template <class _Ptr1, class _Ptr2, bool = is_pointer<_Ptr1>::value || 2371 is_same<_Ptr1, _Ptr2>::value || 2372 __has_element_type<_Ptr1>::value> 2373struct __same_or_less_cv_qualified 2374 : __same_or_less_cv_qualified_imp<_Ptr1, _Ptr2> {}; 2375 2376template <class _Ptr1, class _Ptr2> 2377struct __same_or_less_cv_qualified<_Ptr1, _Ptr2, false> 2378 : false_type {}; 2379 2380// default_delete 2381 2382template <class _Tp> 2383struct _LIBCPP_TEMPLATE_VIS default_delete 2384{ 2385#ifndef _LIBCPP_CXX03_LANG 2386 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR default_delete() _NOEXCEPT = default; 2387#else 2388 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR default_delete() _NOEXCEPT {} 2389#endif 2390 template <class _Up> 2391 _LIBCPP_INLINE_VISIBILITY default_delete(const default_delete<_Up>&, 2392 typename enable_if<is_convertible<_Up*, _Tp*>::value>::type* = 0) _NOEXCEPT {} 2393 _LIBCPP_INLINE_VISIBILITY void operator() (_Tp* __ptr) const _NOEXCEPT 2394 { 2395 static_assert(sizeof(_Tp) > 0, "default_delete can not delete incomplete type"); 2396 static_assert(!is_void<_Tp>::value, "default_delete can not delete incomplete type"); 2397 delete __ptr; 2398 } 2399}; 2400 2401template <class _Tp> 2402struct _LIBCPP_TEMPLATE_VIS default_delete<_Tp[]> 2403{ 2404public: 2405#ifndef _LIBCPP_CXX03_LANG 2406 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR default_delete() _NOEXCEPT = default; 2407#else 2408 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR default_delete() _NOEXCEPT {} 2409#endif 2410 template <class _Up> 2411 _LIBCPP_INLINE_VISIBILITY default_delete(const default_delete<_Up[]>&, 2412 typename enable_if<__same_or_less_cv_qualified<_Up*, _Tp*>::value>::type* = 0) _NOEXCEPT {} 2413 template <class _Up> 2414 _LIBCPP_INLINE_VISIBILITY 2415 void operator() (_Up* __ptr, 2416 typename enable_if<__same_or_less_cv_qualified<_Up*, _Tp*>::value>::type* = 0) const _NOEXCEPT 2417 { 2418 static_assert(sizeof(_Tp) > 0, "default_delete can not delete incomplete type"); 2419 static_assert(!is_void<_Tp>::value, "default_delete can not delete void type"); 2420 delete [] __ptr; 2421 } 2422}; 2423 2424template <class _Tp, class _Dp = default_delete<_Tp> > 2425class _LIBCPP_TEMPLATE_VIS unique_ptr 2426{ 2427public: 2428 typedef _Tp element_type; 2429 typedef _Dp deleter_type; 2430 typedef typename __pointer_type<_Tp, deleter_type>::type pointer; 2431private: 2432 __compressed_pair<pointer, deleter_type> __ptr_; 2433 2434#ifdef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2435 unique_ptr(unique_ptr&); 2436 template <class _Up, class _Ep> 2437 unique_ptr(unique_ptr<_Up, _Ep>&); 2438 unique_ptr& operator=(unique_ptr&); 2439 template <class _Up, class _Ep> 2440 unique_ptr& operator=(unique_ptr<_Up, _Ep>&); 2441#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2442 2443 struct __nat {int __for_bool_;}; 2444 2445 typedef typename remove_reference<deleter_type>::type& _Dp_reference; 2446 typedef const typename remove_reference<deleter_type>::type& _Dp_const_reference; 2447public: 2448 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR unique_ptr() _NOEXCEPT 2449 : __ptr_(pointer()) 2450 { 2451 static_assert(!is_pointer<deleter_type>::value, 2452 "unique_ptr constructed with null function pointer deleter"); 2453 } 2454 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR unique_ptr(nullptr_t) _NOEXCEPT 2455 : __ptr_(pointer()) 2456 { 2457 static_assert(!is_pointer<deleter_type>::value, 2458 "unique_ptr constructed with null function pointer deleter"); 2459 } 2460 _LIBCPP_INLINE_VISIBILITY explicit unique_ptr(pointer __p) _NOEXCEPT 2461 : __ptr_(_VSTD::move(__p)) 2462 { 2463 static_assert(!is_pointer<deleter_type>::value, 2464 "unique_ptr constructed with null function pointer deleter"); 2465 } 2466 2467#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2468 _LIBCPP_INLINE_VISIBILITY unique_ptr(pointer __p, typename conditional< 2469 is_reference<deleter_type>::value, 2470 deleter_type, 2471 typename add_lvalue_reference<const deleter_type>::type>::type __d) 2472 _NOEXCEPT 2473 : __ptr_(__p, __d) {} 2474 2475 _LIBCPP_INLINE_VISIBILITY unique_ptr(pointer __p, typename remove_reference<deleter_type>::type&& __d) 2476 _NOEXCEPT 2477 : __ptr_(__p, _VSTD::move(__d)) 2478 { 2479 static_assert(!is_reference<deleter_type>::value, "rvalue deleter bound to reference"); 2480 } 2481 _LIBCPP_INLINE_VISIBILITY unique_ptr(unique_ptr&& __u) _NOEXCEPT 2482 : __ptr_(__u.release(), _VSTD::forward<deleter_type>(__u.get_deleter())) {} 2483 template <class _Up, class _Ep> 2484 _LIBCPP_INLINE_VISIBILITY 2485 unique_ptr(unique_ptr<_Up, _Ep>&& __u, 2486 typename enable_if 2487 < 2488 !is_array<_Up>::value && 2489 is_convertible<typename unique_ptr<_Up, _Ep>::pointer, pointer>::value && 2490 is_convertible<_Ep, deleter_type>::value && 2491 ( 2492 !is_reference<deleter_type>::value || 2493 is_same<deleter_type, _Ep>::value 2494 ), 2495 __nat 2496 >::type = __nat()) _NOEXCEPT 2497 : __ptr_(__u.release(), _VSTD::forward<_Ep>(__u.get_deleter())) {} 2498 2499 template <class _Up> 2500 _LIBCPP_INLINE_VISIBILITY unique_ptr(auto_ptr<_Up>&& __p, 2501 typename enable_if< 2502 is_convertible<_Up*, _Tp*>::value && 2503 is_same<_Dp, default_delete<_Tp> >::value, 2504 __nat 2505 >::type = __nat()) _NOEXCEPT 2506 : __ptr_(__p.release()) 2507 { 2508 } 2509 2510 _LIBCPP_INLINE_VISIBILITY unique_ptr& operator=(unique_ptr&& __u) _NOEXCEPT 2511 { 2512 reset(__u.release()); 2513 __ptr_.second() = _VSTD::forward<deleter_type>(__u.get_deleter()); 2514 return *this; 2515 } 2516 2517 template <class _Up, class _Ep> 2518 _LIBCPP_INLINE_VISIBILITY 2519 typename enable_if 2520 < 2521 !is_array<_Up>::value && 2522 is_convertible<typename unique_ptr<_Up, _Ep>::pointer, pointer>::value && 2523 is_assignable<deleter_type&, _Ep&&>::value, 2524 unique_ptr& 2525 >::type 2526 operator=(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT 2527 { 2528 reset(__u.release()); 2529 __ptr_.second() = _VSTD::forward<_Ep>(__u.get_deleter()); 2530 return *this; 2531 } 2532#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2533 2534 _LIBCPP_INLINE_VISIBILITY operator __rv<unique_ptr>() 2535 { 2536 return __rv<unique_ptr>(*this); 2537 } 2538 2539 _LIBCPP_INLINE_VISIBILITY unique_ptr(__rv<unique_ptr> __u) 2540 : __ptr_(__u->release(), _VSTD::forward<deleter_type>(__u->get_deleter())) {} 2541 2542 template <class _Up, class _Ep> 2543 _LIBCPP_INLINE_VISIBILITY 2544 typename enable_if< 2545 !is_array<_Up>::value && 2546 is_convertible<typename unique_ptr<_Up, _Ep>::pointer, pointer>::value && 2547 is_assignable<deleter_type&, _Ep&>::value, 2548 unique_ptr& 2549 >::type 2550 operator=(unique_ptr<_Up, _Ep> __u) 2551 { 2552 reset(__u.release()); 2553 __ptr_.second() = _VSTD::forward<_Ep>(__u.get_deleter()); 2554 return *this; 2555 } 2556 2557 _LIBCPP_INLINE_VISIBILITY unique_ptr(pointer __p, deleter_type __d) 2558 : __ptr_(_VSTD::move(__p), _VSTD::move(__d)) {} 2559 2560 template <class _Up> 2561 _LIBCPP_INLINE_VISIBILITY 2562 typename enable_if< 2563 is_convertible<_Up*, _Tp*>::value && 2564 is_same<_Dp, default_delete<_Tp> >::value, 2565 unique_ptr& 2566 >::type 2567 operator=(auto_ptr<_Up> __p) 2568 {reset(__p.release()); return *this;} 2569 2570#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2571 _LIBCPP_INLINE_VISIBILITY ~unique_ptr() {reset();} 2572 2573 _LIBCPP_INLINE_VISIBILITY unique_ptr& operator=(nullptr_t) _NOEXCEPT 2574 { 2575 reset(); 2576 return *this; 2577 } 2578 2579 _LIBCPP_INLINE_VISIBILITY typename add_lvalue_reference<_Tp>::type operator*() const 2580 {return *__ptr_.first();} 2581 _LIBCPP_INLINE_VISIBILITY pointer operator->() const _NOEXCEPT {return __ptr_.first();} 2582 _LIBCPP_INLINE_VISIBILITY pointer get() const _NOEXCEPT {return __ptr_.first();} 2583 _LIBCPP_INLINE_VISIBILITY _Dp_reference get_deleter() _NOEXCEPT 2584 {return __ptr_.second();} 2585 _LIBCPP_INLINE_VISIBILITY _Dp_const_reference get_deleter() const _NOEXCEPT 2586 {return __ptr_.second();} 2587 _LIBCPP_INLINE_VISIBILITY 2588 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT 2589 {return __ptr_.first() != nullptr;} 2590 2591 _LIBCPP_INLINE_VISIBILITY pointer release() _NOEXCEPT 2592 { 2593 pointer __t = __ptr_.first(); 2594 __ptr_.first() = pointer(); 2595 return __t; 2596 } 2597 2598 _LIBCPP_INLINE_VISIBILITY void reset(pointer __p = pointer()) _NOEXCEPT 2599 { 2600 pointer __tmp = __ptr_.first(); 2601 __ptr_.first() = __p; 2602 if (__tmp) 2603 __ptr_.second()(__tmp); 2604 } 2605 2606 _LIBCPP_INLINE_VISIBILITY void swap(unique_ptr& __u) _NOEXCEPT 2607 {__ptr_.swap(__u.__ptr_);} 2608}; 2609 2610template <class _Tp, class _Dp> 2611class _LIBCPP_TEMPLATE_VIS unique_ptr<_Tp[], _Dp> 2612{ 2613public: 2614 typedef _Tp element_type; 2615 typedef _Dp deleter_type; 2616 typedef typename __pointer_type<_Tp, deleter_type>::type pointer; 2617private: 2618 __compressed_pair<pointer, deleter_type> __ptr_; 2619 2620#ifdef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2621 unique_ptr(unique_ptr&); 2622 template <class _Up> 2623 unique_ptr(unique_ptr<_Up>&); 2624 unique_ptr& operator=(unique_ptr&); 2625 template <class _Up> 2626 unique_ptr& operator=(unique_ptr<_Up>&); 2627#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2628 2629 struct __nat {int __for_bool_;}; 2630 2631 typedef typename remove_reference<deleter_type>::type& _Dp_reference; 2632 typedef const typename remove_reference<deleter_type>::type& _Dp_const_reference; 2633public: 2634 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR unique_ptr() _NOEXCEPT 2635 : __ptr_(pointer()) 2636 { 2637 static_assert(!is_pointer<deleter_type>::value, 2638 "unique_ptr constructed with null function pointer deleter"); 2639 } 2640 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR unique_ptr(nullptr_t) _NOEXCEPT 2641 : __ptr_(pointer()) 2642 { 2643 static_assert(!is_pointer<deleter_type>::value, 2644 "unique_ptr constructed with null function pointer deleter"); 2645 } 2646#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2647 template <class _Pp> 2648 _LIBCPP_INLINE_VISIBILITY explicit unique_ptr(_Pp __p, 2649 typename enable_if<__same_or_less_cv_qualified<_Pp, pointer>::value, __nat>::type = __nat()) _NOEXCEPT 2650 : __ptr_(__p) 2651 { 2652 static_assert(!is_pointer<deleter_type>::value, 2653 "unique_ptr constructed with null function pointer deleter"); 2654 } 2655 2656 template <class _Pp> 2657 _LIBCPP_INLINE_VISIBILITY unique_ptr(_Pp __p, typename conditional< 2658 is_reference<deleter_type>::value, 2659 deleter_type, 2660 typename add_lvalue_reference<const deleter_type>::type>::type __d, 2661 typename enable_if<__same_or_less_cv_qualified<_Pp, pointer>::value, __nat>::type = __nat()) 2662 _NOEXCEPT 2663 : __ptr_(__p, __d) {} 2664 2665 _LIBCPP_INLINE_VISIBILITY unique_ptr(nullptr_t, typename conditional< 2666 is_reference<deleter_type>::value, 2667 deleter_type, 2668 typename add_lvalue_reference<const deleter_type>::type>::type __d) 2669 _NOEXCEPT 2670 : __ptr_(pointer(), __d) {} 2671 2672 template <class _Pp> 2673 _LIBCPP_INLINE_VISIBILITY unique_ptr(_Pp __p, 2674 typename remove_reference<deleter_type>::type&& __d, 2675 typename enable_if<__same_or_less_cv_qualified<_Pp, pointer>::value, __nat>::type = __nat()) 2676 _NOEXCEPT 2677 : __ptr_(__p, _VSTD::move(__d)) 2678 { 2679 static_assert(!is_reference<deleter_type>::value, "rvalue deleter bound to reference"); 2680 } 2681 2682 _LIBCPP_INLINE_VISIBILITY unique_ptr(nullptr_t, typename remove_reference<deleter_type>::type&& __d) 2683 _NOEXCEPT 2684 : __ptr_(pointer(), _VSTD::move(__d)) 2685 { 2686 static_assert(!is_reference<deleter_type>::value, "rvalue deleter bound to reference"); 2687 } 2688 2689 _LIBCPP_INLINE_VISIBILITY unique_ptr(unique_ptr&& __u) _NOEXCEPT 2690 : __ptr_(__u.release(), _VSTD::forward<deleter_type>(__u.get_deleter())) {} 2691 2692 _LIBCPP_INLINE_VISIBILITY unique_ptr& operator=(unique_ptr&& __u) _NOEXCEPT 2693 { 2694 reset(__u.release()); 2695 __ptr_.second() = _VSTD::forward<deleter_type>(__u.get_deleter()); 2696 return *this; 2697 } 2698 2699 template <class _Up, class _Ep> 2700 _LIBCPP_INLINE_VISIBILITY 2701 unique_ptr(unique_ptr<_Up, _Ep>&& __u, 2702 typename enable_if 2703 < 2704 is_array<_Up>::value && 2705 __same_or_less_cv_qualified<typename unique_ptr<_Up, _Ep>::pointer, pointer>::value 2706 && is_convertible<_Ep, deleter_type>::value && 2707 ( 2708 !is_reference<deleter_type>::value || 2709 is_same<deleter_type, _Ep>::value 2710 ), 2711 __nat 2712 >::type = __nat() 2713 ) _NOEXCEPT 2714 : __ptr_(__u.release(), _VSTD::forward<deleter_type>(__u.get_deleter())) {} 2715 2716 2717 template <class _Up, class _Ep> 2718 _LIBCPP_INLINE_VISIBILITY 2719 typename enable_if 2720 < 2721 is_array<_Up>::value && 2722 __same_or_less_cv_qualified<typename unique_ptr<_Up, _Ep>::pointer, pointer>::value && 2723 is_assignable<deleter_type&, _Ep&&>::value, 2724 unique_ptr& 2725 >::type 2726 operator=(unique_ptr<_Up, _Ep>&& __u) _NOEXCEPT 2727 { 2728 reset(__u.release()); 2729 __ptr_.second() = _VSTD::forward<_Ep>(__u.get_deleter()); 2730 return *this; 2731 } 2732#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2733 2734 _LIBCPP_INLINE_VISIBILITY explicit unique_ptr(pointer __p) 2735 : __ptr_(__p) 2736 { 2737 static_assert(!is_pointer<deleter_type>::value, 2738 "unique_ptr constructed with null function pointer deleter"); 2739 } 2740 2741 _LIBCPP_INLINE_VISIBILITY unique_ptr(pointer __p, deleter_type __d) 2742 : __ptr_(__p, _VSTD::forward<deleter_type>(__d)) {} 2743 2744 _LIBCPP_INLINE_VISIBILITY unique_ptr(nullptr_t, deleter_type __d) 2745 : __ptr_(pointer(), _VSTD::forward<deleter_type>(__d)) {} 2746 2747 _LIBCPP_INLINE_VISIBILITY operator __rv<unique_ptr>() 2748 { 2749 return __rv<unique_ptr>(*this); 2750 } 2751 2752 _LIBCPP_INLINE_VISIBILITY unique_ptr(__rv<unique_ptr> __u) 2753 : __ptr_(__u->release(), _VSTD::forward<deleter_type>(__u->get_deleter())) {} 2754 2755 _LIBCPP_INLINE_VISIBILITY unique_ptr& operator=(__rv<unique_ptr> __u) 2756 { 2757 reset(__u->release()); 2758 __ptr_.second() = _VSTD::forward<deleter_type>(__u->get_deleter()); 2759 return *this; 2760 } 2761 2762#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2763 _LIBCPP_INLINE_VISIBILITY ~unique_ptr() {reset();} 2764 2765 _LIBCPP_INLINE_VISIBILITY unique_ptr& operator=(nullptr_t) _NOEXCEPT 2766 { 2767 reset(); 2768 return *this; 2769 } 2770 2771 _LIBCPP_INLINE_VISIBILITY typename add_lvalue_reference<_Tp>::type operator[](size_t __i) const 2772 {return __ptr_.first()[__i];} 2773 _LIBCPP_INLINE_VISIBILITY pointer get() const _NOEXCEPT {return __ptr_.first();} 2774 _LIBCPP_INLINE_VISIBILITY _Dp_reference get_deleter() _NOEXCEPT 2775 {return __ptr_.second();} 2776 _LIBCPP_INLINE_VISIBILITY _Dp_const_reference get_deleter() const _NOEXCEPT 2777 {return __ptr_.second();} 2778 _LIBCPP_INLINE_VISIBILITY 2779 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT 2780 {return __ptr_.first() != nullptr;} 2781 2782 _LIBCPP_INLINE_VISIBILITY pointer release() _NOEXCEPT 2783 { 2784 pointer __t = __ptr_.first(); 2785 __ptr_.first() = pointer(); 2786 return __t; 2787 } 2788 2789 template <class _Pp> 2790 _LIBCPP_INLINE_VISIBILITY 2791 typename enable_if<__same_or_less_cv_qualified<_Pp, pointer>::value, void>::type 2792 reset(_Pp __p) _NOEXCEPT 2793 { 2794 pointer __tmp = __ptr_.first(); 2795 __ptr_.first() = __p; 2796 if (__tmp) 2797 __ptr_.second()(__tmp); 2798 } 2799 _LIBCPP_INLINE_VISIBILITY void reset(nullptr_t = nullptr) _NOEXCEPT 2800 { 2801 pointer __tmp = __ptr_.first(); 2802 __ptr_.first() = nullptr; 2803 if (__tmp) 2804 __ptr_.second()(__tmp); 2805 } 2806 2807 _LIBCPP_INLINE_VISIBILITY void swap(unique_ptr& __u) {__ptr_.swap(__u.__ptr_);} 2808private: 2809 2810#ifdef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2811 template <class _Up> 2812 explicit unique_ptr(_Up); 2813 template <class _Up> 2814 unique_ptr(_Up __u, 2815 typename conditional< 2816 is_reference<deleter_type>::value, 2817 deleter_type, 2818 typename add_lvalue_reference<const deleter_type>::type>::type, 2819 typename enable_if 2820 < 2821 is_convertible<_Up, pointer>::value, 2822 __nat 2823 >::type = __nat()); 2824#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 2825}; 2826 2827template <class _Tp, class _Dp> 2828inline _LIBCPP_INLINE_VISIBILITY 2829typename enable_if< 2830 __is_swappable<_Dp>::value, 2831 void 2832>::type 2833swap(unique_ptr<_Tp, _Dp>& __x, unique_ptr<_Tp, _Dp>& __y) _NOEXCEPT {__x.swap(__y);} 2834 2835template <class _T1, class _D1, class _T2, class _D2> 2836inline _LIBCPP_INLINE_VISIBILITY 2837bool 2838operator==(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return __x.get() == __y.get();} 2839 2840template <class _T1, class _D1, class _T2, class _D2> 2841inline _LIBCPP_INLINE_VISIBILITY 2842bool 2843operator!=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__x == __y);} 2844 2845template <class _T1, class _D1, class _T2, class _D2> 2846inline _LIBCPP_INLINE_VISIBILITY 2847bool 2848operator< (const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) 2849{ 2850 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 2851 typedef typename unique_ptr<_T2, _D2>::pointer _P2; 2852 typedef typename common_type<_P1, _P2>::type _Vp; 2853 return less<_Vp>()(__x.get(), __y.get()); 2854} 2855 2856template <class _T1, class _D1, class _T2, class _D2> 2857inline _LIBCPP_INLINE_VISIBILITY 2858bool 2859operator> (const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return __y < __x;} 2860 2861template <class _T1, class _D1, class _T2, class _D2> 2862inline _LIBCPP_INLINE_VISIBILITY 2863bool 2864operator<=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__y < __x);} 2865 2866template <class _T1, class _D1, class _T2, class _D2> 2867inline _LIBCPP_INLINE_VISIBILITY 2868bool 2869operator>=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__x < __y);} 2870 2871template <class _T1, class _D1> 2872inline _LIBCPP_INLINE_VISIBILITY 2873bool 2874operator==(const unique_ptr<_T1, _D1>& __x, nullptr_t) _NOEXCEPT 2875{ 2876 return !__x; 2877} 2878 2879template <class _T1, class _D1> 2880inline _LIBCPP_INLINE_VISIBILITY 2881bool 2882operator==(nullptr_t, const unique_ptr<_T1, _D1>& __x) _NOEXCEPT 2883{ 2884 return !__x; 2885} 2886 2887template <class _T1, class _D1> 2888inline _LIBCPP_INLINE_VISIBILITY 2889bool 2890operator!=(const unique_ptr<_T1, _D1>& __x, nullptr_t) _NOEXCEPT 2891{ 2892 return static_cast<bool>(__x); 2893} 2894 2895template <class _T1, class _D1> 2896inline _LIBCPP_INLINE_VISIBILITY 2897bool 2898operator!=(nullptr_t, const unique_ptr<_T1, _D1>& __x) _NOEXCEPT 2899{ 2900 return static_cast<bool>(__x); 2901} 2902 2903template <class _T1, class _D1> 2904inline _LIBCPP_INLINE_VISIBILITY 2905bool 2906operator<(const unique_ptr<_T1, _D1>& __x, nullptr_t) 2907{ 2908 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 2909 return less<_P1>()(__x.get(), nullptr); 2910} 2911 2912template <class _T1, class _D1> 2913inline _LIBCPP_INLINE_VISIBILITY 2914bool 2915operator<(nullptr_t, const unique_ptr<_T1, _D1>& __x) 2916{ 2917 typedef typename unique_ptr<_T1, _D1>::pointer _P1; 2918 return less<_P1>()(nullptr, __x.get()); 2919} 2920 2921template <class _T1, class _D1> 2922inline _LIBCPP_INLINE_VISIBILITY 2923bool 2924operator>(const unique_ptr<_T1, _D1>& __x, nullptr_t) 2925{ 2926 return nullptr < __x; 2927} 2928 2929template <class _T1, class _D1> 2930inline _LIBCPP_INLINE_VISIBILITY 2931bool 2932operator>(nullptr_t, const unique_ptr<_T1, _D1>& __x) 2933{ 2934 return __x < nullptr; 2935} 2936 2937template <class _T1, class _D1> 2938inline _LIBCPP_INLINE_VISIBILITY 2939bool 2940operator<=(const unique_ptr<_T1, _D1>& __x, nullptr_t) 2941{ 2942 return !(nullptr < __x); 2943} 2944 2945template <class _T1, class _D1> 2946inline _LIBCPP_INLINE_VISIBILITY 2947bool 2948operator<=(nullptr_t, const unique_ptr<_T1, _D1>& __x) 2949{ 2950 return !(__x < nullptr); 2951} 2952 2953template <class _T1, class _D1> 2954inline _LIBCPP_INLINE_VISIBILITY 2955bool 2956operator>=(const unique_ptr<_T1, _D1>& __x, nullptr_t) 2957{ 2958 return !(__x < nullptr); 2959} 2960 2961template <class _T1, class _D1> 2962inline _LIBCPP_INLINE_VISIBILITY 2963bool 2964operator>=(nullptr_t, const unique_ptr<_T1, _D1>& __x) 2965{ 2966 return !(nullptr < __x); 2967} 2968 2969#ifdef _LIBCPP_HAS_NO_RVALUE_REFERENCES 2970 2971template <class _Tp, class _Dp> 2972inline _LIBCPP_INLINE_VISIBILITY 2973unique_ptr<_Tp, _Dp> 2974move(unique_ptr<_Tp, _Dp>& __t) 2975{ 2976 return unique_ptr<_Tp, _Dp>(__rv<unique_ptr<_Tp, _Dp> >(__t)); 2977} 2978 2979#endif 2980 2981#if _LIBCPP_STD_VER > 11 2982 2983template<class _Tp> 2984struct __unique_if 2985{ 2986 typedef unique_ptr<_Tp> __unique_single; 2987}; 2988 2989template<class _Tp> 2990struct __unique_if<_Tp[]> 2991{ 2992 typedef unique_ptr<_Tp[]> __unique_array_unknown_bound; 2993}; 2994 2995template<class _Tp, size_t _Np> 2996struct __unique_if<_Tp[_Np]> 2997{ 2998 typedef void __unique_array_known_bound; 2999}; 3000 3001template<class _Tp, class... _Args> 3002inline _LIBCPP_INLINE_VISIBILITY 3003typename __unique_if<_Tp>::__unique_single 3004make_unique(_Args&&... __args) 3005{ 3006 return unique_ptr<_Tp>(new _Tp(_VSTD::forward<_Args>(__args)...)); 3007} 3008 3009template<class _Tp> 3010inline _LIBCPP_INLINE_VISIBILITY 3011typename __unique_if<_Tp>::__unique_array_unknown_bound 3012make_unique(size_t __n) 3013{ 3014 typedef typename remove_extent<_Tp>::type _Up; 3015 return unique_ptr<_Tp>(new _Up[__n]()); 3016} 3017 3018template<class _Tp, class... _Args> 3019 typename __unique_if<_Tp>::__unique_array_known_bound 3020 make_unique(_Args&&...) = delete; 3021 3022#endif // _LIBCPP_STD_VER > 11 3023 3024template <class _Size> 3025inline _LIBCPP_INLINE_VISIBILITY 3026_Size 3027__loadword(const void* __p) 3028{ 3029 _Size __r; 3030 std::memcpy(&__r, __p, sizeof(__r)); 3031 return __r; 3032} 3033 3034// We use murmur2 when size_t is 32 bits, and cityhash64 when size_t 3035// is 64 bits. This is because cityhash64 uses 64bit x 64bit 3036// multiplication, which can be very slow on 32-bit systems. 3037template <class _Size, size_t = sizeof(_Size)*__CHAR_BIT__> 3038struct __murmur2_or_cityhash; 3039 3040template <class _Size> 3041struct __murmur2_or_cityhash<_Size, 32> 3042{ 3043 _Size operator()(const void* __key, _Size __len); 3044}; 3045 3046// murmur2 3047template <class _Size> 3048_Size 3049__murmur2_or_cityhash<_Size, 32>::operator()(const void* __key, _Size __len) _LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK 3050{ 3051 const _Size __m = 0x5bd1e995; 3052 const _Size __r = 24; 3053 _Size __h = __len; 3054 const unsigned char* __data = static_cast<const unsigned char*>(__key); 3055 for (; __len >= 4; __data += 4, __len -= 4) 3056 { 3057 _Size __k = __loadword<_Size>(__data); 3058 __k *= __m; 3059 __k ^= __k >> __r; 3060 __k *= __m; 3061 __h *= __m; 3062 __h ^= __k; 3063 } 3064 switch (__len) 3065 { 3066 case 3: 3067 __h ^= __data[2] << 16; 3068 case 2: 3069 __h ^= __data[1] << 8; 3070 case 1: 3071 __h ^= __data[0]; 3072 __h *= __m; 3073 } 3074 __h ^= __h >> 13; 3075 __h *= __m; 3076 __h ^= __h >> 15; 3077 return __h; 3078} 3079 3080template <class _Size> 3081struct __murmur2_or_cityhash<_Size, 64> 3082{ 3083 _Size operator()(const void* __key, _Size __len); 3084 3085 private: 3086 // Some primes between 2^63 and 2^64. 3087 static const _Size __k0 = 0xc3a5c85c97cb3127ULL; 3088 static const _Size __k1 = 0xb492b66fbe98f273ULL; 3089 static const _Size __k2 = 0x9ae16a3b2f90404fULL; 3090 static const _Size __k3 = 0xc949d7c7509e6557ULL; 3091 3092 static _Size __rotate(_Size __val, int __shift) { 3093 return __shift == 0 ? __val : ((__val >> __shift) | (__val << (64 - __shift))); 3094 } 3095 3096 static _Size __rotate_by_at_least_1(_Size __val, int __shift) { 3097 return (__val >> __shift) | (__val << (64 - __shift)); 3098 } 3099 3100 static _Size __shift_mix(_Size __val) { 3101 return __val ^ (__val >> 47); 3102 } 3103 3104 static _Size __hash_len_16(_Size __u, _Size __v) { 3105 const _Size __mul = 0x9ddfea08eb382d69ULL; 3106 _Size __a = (__u ^ __v) * __mul; 3107 __a ^= (__a >> 47); 3108 _Size __b = (__v ^ __a) * __mul; 3109 __b ^= (__b >> 47); 3110 __b *= __mul; 3111 return __b; 3112 } 3113 3114 static _Size __hash_len_0_to_16(const char* __s, _Size __len) { 3115 if (__len > 8) { 3116 const _Size __a = __loadword<_Size>(__s); 3117 const _Size __b = __loadword<_Size>(__s + __len - 8); 3118 return __hash_len_16(__a, __rotate_by_at_least_1(__b + __len, __len)) ^ __b; 3119 } 3120 if (__len >= 4) { 3121 const uint32_t __a = __loadword<uint32_t>(__s); 3122 const uint32_t __b = __loadword<uint32_t>(__s + __len - 4); 3123 return __hash_len_16(__len + (__a << 3), __b); 3124 } 3125 if (__len > 0) { 3126 const unsigned char __a = __s[0]; 3127 const unsigned char __b = __s[__len >> 1]; 3128 const unsigned char __c = __s[__len - 1]; 3129 const uint32_t __y = static_cast<uint32_t>(__a) + 3130 (static_cast<uint32_t>(__b) << 8); 3131 const uint32_t __z = __len + (static_cast<uint32_t>(__c) << 2); 3132 return __shift_mix(__y * __k2 ^ __z * __k3) * __k2; 3133 } 3134 return __k2; 3135 } 3136 3137 static _Size __hash_len_17_to_32(const char *__s, _Size __len) { 3138 const _Size __a = __loadword<_Size>(__s) * __k1; 3139 const _Size __b = __loadword<_Size>(__s + 8); 3140 const _Size __c = __loadword<_Size>(__s + __len - 8) * __k2; 3141 const _Size __d = __loadword<_Size>(__s + __len - 16) * __k0; 3142 return __hash_len_16(__rotate(__a - __b, 43) + __rotate(__c, 30) + __d, 3143 __a + __rotate(__b ^ __k3, 20) - __c + __len); 3144 } 3145 3146 // Return a 16-byte hash for 48 bytes. Quick and dirty. 3147 // Callers do best to use "random-looking" values for a and b. 3148 static pair<_Size, _Size> __weak_hash_len_32_with_seeds( 3149 _Size __w, _Size __x, _Size __y, _Size __z, _Size __a, _Size __b) { 3150 __a += __w; 3151 __b = __rotate(__b + __a + __z, 21); 3152 const _Size __c = __a; 3153 __a += __x; 3154 __a += __y; 3155 __b += __rotate(__a, 44); 3156 return pair<_Size, _Size>(__a + __z, __b + __c); 3157 } 3158 3159 // Return a 16-byte hash for s[0] ... s[31], a, and b. Quick and dirty. 3160 static pair<_Size, _Size> __weak_hash_len_32_with_seeds( 3161 const char* __s, _Size __a, _Size __b) { 3162 return __weak_hash_len_32_with_seeds(__loadword<_Size>(__s), 3163 __loadword<_Size>(__s + 8), 3164 __loadword<_Size>(__s + 16), 3165 __loadword<_Size>(__s + 24), 3166 __a, 3167 __b); 3168 } 3169 3170 // Return an 8-byte hash for 33 to 64 bytes. 3171 static _Size __hash_len_33_to_64(const char *__s, size_t __len) { 3172 _Size __z = __loadword<_Size>(__s + 24); 3173 _Size __a = __loadword<_Size>(__s) + 3174 (__len + __loadword<_Size>(__s + __len - 16)) * __k0; 3175 _Size __b = __rotate(__a + __z, 52); 3176 _Size __c = __rotate(__a, 37); 3177 __a += __loadword<_Size>(__s + 8); 3178 __c += __rotate(__a, 7); 3179 __a += __loadword<_Size>(__s + 16); 3180 _Size __vf = __a + __z; 3181 _Size __vs = __b + __rotate(__a, 31) + __c; 3182 __a = __loadword<_Size>(__s + 16) + __loadword<_Size>(__s + __len - 32); 3183 __z += __loadword<_Size>(__s + __len - 8); 3184 __b = __rotate(__a + __z, 52); 3185 __c = __rotate(__a, 37); 3186 __a += __loadword<_Size>(__s + __len - 24); 3187 __c += __rotate(__a, 7); 3188 __a += __loadword<_Size>(__s + __len - 16); 3189 _Size __wf = __a + __z; 3190 _Size __ws = __b + __rotate(__a, 31) + __c; 3191 _Size __r = __shift_mix((__vf + __ws) * __k2 + (__wf + __vs) * __k0); 3192 return __shift_mix(__r * __k0 + __vs) * __k2; 3193 } 3194}; 3195 3196// cityhash64 3197template <class _Size> 3198_Size 3199__murmur2_or_cityhash<_Size, 64>::operator()(const void* __key, _Size __len) _LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK 3200{ 3201 const char* __s = static_cast<const char*>(__key); 3202 if (__len <= 32) { 3203 if (__len <= 16) { 3204 return __hash_len_0_to_16(__s, __len); 3205 } else { 3206 return __hash_len_17_to_32(__s, __len); 3207 } 3208 } else if (__len <= 64) { 3209 return __hash_len_33_to_64(__s, __len); 3210 } 3211 3212 // For strings over 64 bytes we hash the end first, and then as we 3213 // loop we keep 56 bytes of state: v, w, x, y, and z. 3214 _Size __x = __loadword<_Size>(__s + __len - 40); 3215 _Size __y = __loadword<_Size>(__s + __len - 16) + 3216 __loadword<_Size>(__s + __len - 56); 3217 _Size __z = __hash_len_16(__loadword<_Size>(__s + __len - 48) + __len, 3218 __loadword<_Size>(__s + __len - 24)); 3219 pair<_Size, _Size> __v = __weak_hash_len_32_with_seeds(__s + __len - 64, __len, __z); 3220 pair<_Size, _Size> __w = __weak_hash_len_32_with_seeds(__s + __len - 32, __y + __k1, __x); 3221 __x = __x * __k1 + __loadword<_Size>(__s); 3222 3223 // Decrease len to the nearest multiple of 64, and operate on 64-byte chunks. 3224 __len = (__len - 1) & ~static_cast<_Size>(63); 3225 do { 3226 __x = __rotate(__x + __y + __v.first + __loadword<_Size>(__s + 8), 37) * __k1; 3227 __y = __rotate(__y + __v.second + __loadword<_Size>(__s + 48), 42) * __k1; 3228 __x ^= __w.second; 3229 __y += __v.first + __loadword<_Size>(__s + 40); 3230 __z = __rotate(__z + __w.first, 33) * __k1; 3231 __v = __weak_hash_len_32_with_seeds(__s, __v.second * __k1, __x + __w.first); 3232 __w = __weak_hash_len_32_with_seeds(__s + 32, __z + __w.second, 3233 __y + __loadword<_Size>(__s + 16)); 3234 std::swap(__z, __x); 3235 __s += 64; 3236 __len -= 64; 3237 } while (__len != 0); 3238 return __hash_len_16( 3239 __hash_len_16(__v.first, __w.first) + __shift_mix(__y) * __k1 + __z, 3240 __hash_len_16(__v.second, __w.second) + __x); 3241} 3242 3243template <class _Tp, size_t = sizeof(_Tp) / sizeof(size_t)> 3244struct __scalar_hash; 3245 3246template <class _Tp> 3247struct __scalar_hash<_Tp, 0> 3248 : public unary_function<_Tp, size_t> 3249{ 3250 _LIBCPP_INLINE_VISIBILITY 3251 size_t operator()(_Tp __v) const _NOEXCEPT 3252 { 3253 union 3254 { 3255 _Tp __t; 3256 size_t __a; 3257 } __u; 3258 __u.__a = 0; 3259 __u.__t = __v; 3260 return __u.__a; 3261 } 3262}; 3263 3264template <class _Tp> 3265struct __scalar_hash<_Tp, 1> 3266 : public unary_function<_Tp, size_t> 3267{ 3268 _LIBCPP_INLINE_VISIBILITY 3269 size_t operator()(_Tp __v) const _NOEXCEPT 3270 { 3271 union 3272 { 3273 _Tp __t; 3274 size_t __a; 3275 } __u; 3276 __u.__t = __v; 3277 return __u.__a; 3278 } 3279}; 3280 3281template <class _Tp> 3282struct __scalar_hash<_Tp, 2> 3283 : public unary_function<_Tp, size_t> 3284{ 3285 _LIBCPP_INLINE_VISIBILITY 3286 size_t operator()(_Tp __v) const _NOEXCEPT 3287 { 3288 union 3289 { 3290 _Tp __t; 3291 struct 3292 { 3293 size_t __a; 3294 size_t __b; 3295 } __s; 3296 } __u; 3297 __u.__t = __v; 3298 return __murmur2_or_cityhash<size_t>()(&__u, sizeof(__u)); 3299 } 3300}; 3301 3302template <class _Tp> 3303struct __scalar_hash<_Tp, 3> 3304 : public unary_function<_Tp, size_t> 3305{ 3306 _LIBCPP_INLINE_VISIBILITY 3307 size_t operator()(_Tp __v) const _NOEXCEPT 3308 { 3309 union 3310 { 3311 _Tp __t; 3312 struct 3313 { 3314 size_t __a; 3315 size_t __b; 3316 size_t __c; 3317 } __s; 3318 } __u; 3319 __u.__t = __v; 3320 return __murmur2_or_cityhash<size_t>()(&__u, sizeof(__u)); 3321 } 3322}; 3323 3324template <class _Tp> 3325struct __scalar_hash<_Tp, 4> 3326 : public unary_function<_Tp, size_t> 3327{ 3328 _LIBCPP_INLINE_VISIBILITY 3329 size_t operator()(_Tp __v) const _NOEXCEPT 3330 { 3331 union 3332 { 3333 _Tp __t; 3334 struct 3335 { 3336 size_t __a; 3337 size_t __b; 3338 size_t __c; 3339 size_t __d; 3340 } __s; 3341 } __u; 3342 __u.__t = __v; 3343 return __murmur2_or_cityhash<size_t>()(&__u, sizeof(__u)); 3344 } 3345}; 3346 3347struct _PairT { 3348 size_t first; 3349 size_t second; 3350}; 3351 3352_LIBCPP_INLINE_VISIBILITY 3353inline size_t __hash_combine(size_t __lhs, size_t __rhs) _NOEXCEPT { 3354 typedef __scalar_hash<_PairT> _HashT; 3355 const _PairT __p = {__lhs, __rhs}; 3356 return _HashT()(__p); 3357} 3358 3359template<class _Tp> 3360struct _LIBCPP_TEMPLATE_VIS hash<_Tp*> 3361 : public unary_function<_Tp*, size_t> 3362{ 3363 _LIBCPP_INLINE_VISIBILITY 3364 size_t operator()(_Tp* __v) const _NOEXCEPT 3365 { 3366 union 3367 { 3368 _Tp* __t; 3369 size_t __a; 3370 } __u; 3371 __u.__t = __v; 3372 return __murmur2_or_cityhash<size_t>()(&__u, sizeof(__u)); 3373 } 3374}; 3375 3376template <class _Tp, class _Dp> 3377struct _LIBCPP_TEMPLATE_VIS hash<unique_ptr<_Tp, _Dp> > 3378{ 3379 typedef unique_ptr<_Tp, _Dp> argument_type; 3380 typedef size_t result_type; 3381 _LIBCPP_INLINE_VISIBILITY 3382 result_type operator()(const argument_type& __ptr) const _NOEXCEPT 3383 { 3384 typedef typename argument_type::pointer pointer; 3385 return hash<pointer>()(__ptr.get()); 3386 } 3387}; 3388 3389struct __destruct_n 3390{ 3391private: 3392 size_t size; 3393 3394 template <class _Tp> 3395 _LIBCPP_INLINE_VISIBILITY void __process(_Tp* __p, false_type) _NOEXCEPT 3396 {for (size_t __i = 0; __i < size; ++__i, ++__p) __p->~_Tp();} 3397 3398 template <class _Tp> 3399 _LIBCPP_INLINE_VISIBILITY void __process(_Tp*, true_type) _NOEXCEPT 3400 {} 3401 3402 _LIBCPP_INLINE_VISIBILITY void __incr(false_type) _NOEXCEPT 3403 {++size;} 3404 _LIBCPP_INLINE_VISIBILITY void __incr(true_type) _NOEXCEPT 3405 {} 3406 3407 _LIBCPP_INLINE_VISIBILITY void __set(size_t __s, false_type) _NOEXCEPT 3408 {size = __s;} 3409 _LIBCPP_INLINE_VISIBILITY void __set(size_t, true_type) _NOEXCEPT 3410 {} 3411public: 3412 _LIBCPP_INLINE_VISIBILITY explicit __destruct_n(size_t __s) _NOEXCEPT 3413 : size(__s) {} 3414 3415 template <class _Tp> 3416 _LIBCPP_INLINE_VISIBILITY void __incr(_Tp*) _NOEXCEPT 3417 {__incr(integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 3418 3419 template <class _Tp> 3420 _LIBCPP_INLINE_VISIBILITY void __set(size_t __s, _Tp*) _NOEXCEPT 3421 {__set(__s, integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 3422 3423 template <class _Tp> 3424 _LIBCPP_INLINE_VISIBILITY void operator()(_Tp* __p) _NOEXCEPT 3425 {__process(__p, integral_constant<bool, is_trivially_destructible<_Tp>::value>());} 3426}; 3427 3428template <class _Alloc> 3429class __allocator_destructor 3430{ 3431 typedef allocator_traits<_Alloc> __alloc_traits; 3432public: 3433 typedef typename __alloc_traits::pointer pointer; 3434 typedef typename __alloc_traits::size_type size_type; 3435private: 3436 _Alloc& __alloc_; 3437 size_type __s_; 3438public: 3439 _LIBCPP_INLINE_VISIBILITY __allocator_destructor(_Alloc& __a, size_type __s) 3440 _NOEXCEPT 3441 : __alloc_(__a), __s_(__s) {} 3442 _LIBCPP_INLINE_VISIBILITY 3443 void operator()(pointer __p) _NOEXCEPT 3444 {__alloc_traits::deallocate(__alloc_, __p, __s_);} 3445}; 3446 3447template <class _InputIterator, class _ForwardIterator> 3448_ForwardIterator 3449uninitialized_copy(_InputIterator __f, _InputIterator __l, _ForwardIterator __r) 3450{ 3451 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 3452#ifndef _LIBCPP_NO_EXCEPTIONS 3453 _ForwardIterator __s = __r; 3454 try 3455 { 3456#endif 3457 for (; __f != __l; ++__f, (void) ++__r) 3458 ::new (static_cast<void*>(_VSTD::addressof(*__r))) value_type(*__f); 3459#ifndef _LIBCPP_NO_EXCEPTIONS 3460 } 3461 catch (...) 3462 { 3463 for (; __s != __r; ++__s) 3464 __s->~value_type(); 3465 throw; 3466 } 3467#endif 3468 return __r; 3469} 3470 3471template <class _InputIterator, class _Size, class _ForwardIterator> 3472_ForwardIterator 3473uninitialized_copy_n(_InputIterator __f, _Size __n, _ForwardIterator __r) 3474{ 3475 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 3476#ifndef _LIBCPP_NO_EXCEPTIONS 3477 _ForwardIterator __s = __r; 3478 try 3479 { 3480#endif 3481 for (; __n > 0; ++__f, (void) ++__r, (void) --__n) 3482 ::new (static_cast<void*>(_VSTD::addressof(*__r))) value_type(*__f); 3483#ifndef _LIBCPP_NO_EXCEPTIONS 3484 } 3485 catch (...) 3486 { 3487 for (; __s != __r; ++__s) 3488 __s->~value_type(); 3489 throw; 3490 } 3491#endif 3492 return __r; 3493} 3494 3495template <class _ForwardIterator, class _Tp> 3496void 3497uninitialized_fill(_ForwardIterator __f, _ForwardIterator __l, const _Tp& __x) 3498{ 3499 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 3500#ifndef _LIBCPP_NO_EXCEPTIONS 3501 _ForwardIterator __s = __f; 3502 try 3503 { 3504#endif 3505 for (; __f != __l; ++__f) 3506 ::new (static_cast<void*>(_VSTD::addressof(*__f))) value_type(__x); 3507#ifndef _LIBCPP_NO_EXCEPTIONS 3508 } 3509 catch (...) 3510 { 3511 for (; __s != __f; ++__s) 3512 __s->~value_type(); 3513 throw; 3514 } 3515#endif 3516} 3517 3518template <class _ForwardIterator, class _Size, class _Tp> 3519_ForwardIterator 3520uninitialized_fill_n(_ForwardIterator __f, _Size __n, const _Tp& __x) 3521{ 3522 typedef typename iterator_traits<_ForwardIterator>::value_type value_type; 3523#ifndef _LIBCPP_NO_EXCEPTIONS 3524 _ForwardIterator __s = __f; 3525 try 3526 { 3527#endif 3528 for (; __n > 0; ++__f, (void) --__n) 3529 ::new (static_cast<void*>(_VSTD::addressof(*__f))) value_type(__x); 3530#ifndef _LIBCPP_NO_EXCEPTIONS 3531 } 3532 catch (...) 3533 { 3534 for (; __s != __f; ++__s) 3535 __s->~value_type(); 3536 throw; 3537 } 3538#endif 3539 return __f; 3540} 3541 3542#if _LIBCPP_STD_VER > 14 3543 3544template <class _Tp> 3545inline _LIBCPP_INLINE_VISIBILITY 3546void destroy_at(_Tp* __loc) { 3547 _LIBCPP_ASSERT(__loc, "null pointer given to destroy_at"); 3548 __loc->~_Tp(); 3549} 3550 3551template <class _ForwardIterator> 3552inline _LIBCPP_INLINE_VISIBILITY 3553void destroy(_ForwardIterator __first, _ForwardIterator __last) { 3554 for (; __first != __last; ++__first) 3555 _VSTD::destroy_at(_VSTD::addressof(*__first)); 3556} 3557 3558template <class _ForwardIterator, class _Size> 3559inline _LIBCPP_INLINE_VISIBILITY 3560_ForwardIterator destroy_n(_ForwardIterator __first, _Size __n) { 3561 for (; __n > 0; (void)++__first, --__n) 3562 _VSTD::destroy_at(_VSTD::addressof(*__first)); 3563 return __first; 3564} 3565 3566template <class _ForwardIterator> 3567inline _LIBCPP_INLINE_VISIBILITY 3568void uninitialized_default_construct(_ForwardIterator __first, _ForwardIterator __last) { 3569 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 3570 auto __idx = __first; 3571#ifndef _LIBCPP_NO_EXCEPTIONS 3572 try { 3573#endif 3574 for (; __idx != __last; ++__idx) 3575 ::new((void*)_VSTD::addressof(*__idx)) _Vt; 3576#ifndef _LIBCPP_NO_EXCEPTIONS 3577 } catch (...) { 3578 _VSTD::destroy(__first, __idx); 3579 throw; 3580 } 3581#endif 3582} 3583 3584template <class _ForwardIterator, class _Size> 3585inline _LIBCPP_INLINE_VISIBILITY 3586_ForwardIterator uninitialized_default_construct_n(_ForwardIterator __first, _Size __n) { 3587 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 3588 auto __idx = __first; 3589#ifndef _LIBCPP_NO_EXCEPTIONS 3590 try { 3591#endif 3592 for (; __n > 0; (void)++__idx, --__n) 3593 ::new((void*)_VSTD::addressof(*__idx)) _Vt; 3594 return __idx; 3595#ifndef _LIBCPP_NO_EXCEPTIONS 3596 } catch (...) { 3597 _VSTD::destroy(__first, __idx); 3598 throw; 3599 } 3600#endif 3601} 3602 3603 3604template <class _ForwardIterator> 3605inline _LIBCPP_INLINE_VISIBILITY 3606void uninitialized_value_construct(_ForwardIterator __first, _ForwardIterator __last) { 3607 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 3608 auto __idx = __first; 3609#ifndef _LIBCPP_NO_EXCEPTIONS 3610 try { 3611#endif 3612 for (; __idx != __last; ++__idx) 3613 ::new((void*)_VSTD::addressof(*__idx)) _Vt(); 3614#ifndef _LIBCPP_NO_EXCEPTIONS 3615 } catch (...) { 3616 _VSTD::destroy(__first, __idx); 3617 throw; 3618 } 3619#endif 3620} 3621 3622template <class _ForwardIterator, class _Size> 3623inline _LIBCPP_INLINE_VISIBILITY 3624_ForwardIterator uninitialized_value_construct_n(_ForwardIterator __first, _Size __n) { 3625 using _Vt = typename iterator_traits<_ForwardIterator>::value_type; 3626 auto __idx = __first; 3627#ifndef _LIBCPP_NO_EXCEPTIONS 3628 try { 3629#endif 3630 for (; __n > 0; (void)++__idx, --__n) 3631 ::new((void*)_VSTD::addressof(*__idx)) _Vt(); 3632 return __idx; 3633#ifndef _LIBCPP_NO_EXCEPTIONS 3634 } catch (...) { 3635 _VSTD::destroy(__first, __idx); 3636 throw; 3637 } 3638#endif 3639} 3640 3641 3642template <class _InputIt, class _ForwardIt> 3643inline _LIBCPP_INLINE_VISIBILITY 3644_ForwardIt uninitialized_move(_InputIt __first, _InputIt __last, _ForwardIt __first_res) { 3645 using _Vt = typename iterator_traits<_ForwardIt>::value_type; 3646 auto __idx = __first_res; 3647#ifndef _LIBCPP_NO_EXCEPTIONS 3648 try { 3649#endif 3650 for (; __first != __last; (void)++__idx, ++__first) 3651 ::new((void*)_VSTD::addressof(*__idx)) _Vt(std::move(*__first)); 3652 return __idx; 3653#ifndef _LIBCPP_NO_EXCEPTIONS 3654 } catch (...) { 3655 _VSTD::destroy(__first_res, __idx); 3656 throw; 3657 } 3658#endif 3659} 3660 3661template <class _InputIt, class _Size, class _ForwardIt> 3662inline _LIBCPP_INLINE_VISIBILITY 3663pair<_InputIt, _ForwardIt> 3664uninitialized_move_n(_InputIt __first, _Size __n, _ForwardIt __first_res) { 3665 using _Vt = typename iterator_traits<_ForwardIt>::value_type; 3666 auto __idx = __first_res; 3667#ifndef _LIBCPP_NO_EXCEPTIONS 3668 try { 3669#endif 3670 for (; __n > 0; ++__idx, (void)++__first, --__n) 3671 ::new((void*)_VSTD::addressof(*__idx)) _Vt(std::move(*__first)); 3672 return {__first, __idx}; 3673#ifndef _LIBCPP_NO_EXCEPTIONS 3674 } catch (...) { 3675 _VSTD::destroy(__first_res, __idx); 3676 throw; 3677 } 3678#endif 3679} 3680 3681 3682#endif // _LIBCPP_STD_VER > 14 3683 3684class _LIBCPP_EXCEPTION_ABI bad_weak_ptr 3685 : public std::exception 3686{ 3687public: 3688 virtual ~bad_weak_ptr() _NOEXCEPT; 3689 virtual const char* what() const _NOEXCEPT; 3690}; 3691 3692_LIBCPP_NORETURN inline _LIBCPP_ALWAYS_INLINE 3693void __throw_bad_weak_ptr() 3694{ 3695#ifndef _LIBCPP_NO_EXCEPTIONS 3696 throw bad_weak_ptr(); 3697#else 3698 _VSTD::abort(); 3699#endif 3700} 3701 3702template<class _Tp> class _LIBCPP_TEMPLATE_VIS weak_ptr; 3703 3704class _LIBCPP_TYPE_VIS __shared_count 3705{ 3706 __shared_count(const __shared_count&); 3707 __shared_count& operator=(const __shared_count&); 3708 3709protected: 3710 long __shared_owners_; 3711 virtual ~__shared_count(); 3712private: 3713 virtual void __on_zero_shared() _NOEXCEPT = 0; 3714 3715public: 3716 _LIBCPP_INLINE_VISIBILITY 3717 explicit __shared_count(long __refs = 0) _NOEXCEPT 3718 : __shared_owners_(__refs) {} 3719 3720 void __add_shared() _NOEXCEPT; 3721 bool __release_shared() _NOEXCEPT; 3722 _LIBCPP_INLINE_VISIBILITY 3723 long use_count() const _NOEXCEPT { 3724 return __libcpp_relaxed_load(&__shared_owners_) + 1; 3725 } 3726}; 3727 3728class _LIBCPP_TYPE_VIS __shared_weak_count 3729 : private __shared_count 3730{ 3731 long __shared_weak_owners_; 3732 3733public: 3734 _LIBCPP_INLINE_VISIBILITY 3735 explicit __shared_weak_count(long __refs = 0) _NOEXCEPT 3736 : __shared_count(__refs), 3737 __shared_weak_owners_(__refs) {} 3738protected: 3739 virtual ~__shared_weak_count(); 3740 3741public: 3742 void __add_shared() _NOEXCEPT; 3743 void __add_weak() _NOEXCEPT; 3744 void __release_shared() _NOEXCEPT; 3745 void __release_weak() _NOEXCEPT; 3746 _LIBCPP_INLINE_VISIBILITY 3747 long use_count() const _NOEXCEPT {return __shared_count::use_count();} 3748 __shared_weak_count* lock() _NOEXCEPT; 3749 3750 // Define the function out only if we build static libc++ without RTTI. 3751 // Otherwise we may break clients who need to compile their projects with 3752 // -fno-rtti and yet link against a libc++.dylib compiled 3753 // without -fno-rtti. 3754#if !defined(_LIBCPP_NO_RTTI) || !defined(_LIBCPP_BUILD_STATIC) 3755 virtual const void* __get_deleter(const type_info&) const _NOEXCEPT; 3756#endif 3757private: 3758 virtual void __on_zero_shared_weak() _NOEXCEPT = 0; 3759}; 3760 3761template <class _Tp, class _Dp, class _Alloc> 3762class __shared_ptr_pointer 3763 : public __shared_weak_count 3764{ 3765 __compressed_pair<__compressed_pair<_Tp, _Dp>, _Alloc> __data_; 3766public: 3767 _LIBCPP_INLINE_VISIBILITY 3768 __shared_ptr_pointer(_Tp __p, _Dp __d, _Alloc __a) 3769 : __data_(__compressed_pair<_Tp, _Dp>(__p, _VSTD::move(__d)), _VSTD::move(__a)) {} 3770 3771#ifndef _LIBCPP_NO_RTTI 3772 virtual const void* __get_deleter(const type_info&) const _NOEXCEPT; 3773#endif 3774 3775private: 3776 virtual void __on_zero_shared() _NOEXCEPT; 3777 virtual void __on_zero_shared_weak() _NOEXCEPT; 3778}; 3779 3780#ifndef _LIBCPP_NO_RTTI 3781 3782template <class _Tp, class _Dp, class _Alloc> 3783const void* 3784__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__get_deleter(const type_info& __t) const _NOEXCEPT 3785{ 3786 return __t == typeid(_Dp) ? _VSTD::addressof(__data_.first().second()) : 0; 3787} 3788 3789#endif // _LIBCPP_NO_RTTI 3790 3791template <class _Tp, class _Dp, class _Alloc> 3792void 3793__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__on_zero_shared() _NOEXCEPT 3794{ 3795 __data_.first().second()(__data_.first().first()); 3796 __data_.first().second().~_Dp(); 3797} 3798 3799template <class _Tp, class _Dp, class _Alloc> 3800void 3801__shared_ptr_pointer<_Tp, _Dp, _Alloc>::__on_zero_shared_weak() _NOEXCEPT 3802{ 3803 typedef typename __allocator_traits_rebind<_Alloc, __shared_ptr_pointer>::type _Al; 3804 typedef allocator_traits<_Al> _ATraits; 3805 typedef pointer_traits<typename _ATraits::pointer> _PTraits; 3806 3807 _Al __a(__data_.second()); 3808 __data_.second().~_Alloc(); 3809 __a.deallocate(_PTraits::pointer_to(*this), 1); 3810} 3811 3812template <class _Tp, class _Alloc> 3813class __shared_ptr_emplace 3814 : public __shared_weak_count 3815{ 3816 __compressed_pair<_Alloc, _Tp> __data_; 3817public: 3818#ifndef _LIBCPP_HAS_NO_VARIADICS 3819 3820 _LIBCPP_INLINE_VISIBILITY 3821 __shared_ptr_emplace(_Alloc __a) 3822 : __data_(_VSTD::move(__a)) {} 3823 3824 template <class ..._Args> 3825 _LIBCPP_INLINE_VISIBILITY 3826 __shared_ptr_emplace(_Alloc __a, _Args&& ...__args) 3827 : __data_(piecewise_construct, _VSTD::forward_as_tuple(__a), 3828 _VSTD::forward_as_tuple(_VSTD::forward<_Args>(__args)...)) {} 3829 3830#else // _LIBCPP_HAS_NO_VARIADICS 3831 3832 _LIBCPP_INLINE_VISIBILITY 3833 __shared_ptr_emplace(_Alloc __a) 3834 : __data_(__a) {} 3835 3836 template <class _A0> 3837 _LIBCPP_INLINE_VISIBILITY 3838 __shared_ptr_emplace(_Alloc __a, _A0& __a0) 3839 : __data_(__a, _Tp(__a0)) {} 3840 3841 template <class _A0, class _A1> 3842 _LIBCPP_INLINE_VISIBILITY 3843 __shared_ptr_emplace(_Alloc __a, _A0& __a0, _A1& __a1) 3844 : __data_(__a, _Tp(__a0, __a1)) {} 3845 3846 template <class _A0, class _A1, class _A2> 3847 _LIBCPP_INLINE_VISIBILITY 3848 __shared_ptr_emplace(_Alloc __a, _A0& __a0, _A1& __a1, _A2& __a2) 3849 : __data_(__a, _Tp(__a0, __a1, __a2)) {} 3850 3851#endif // _LIBCPP_HAS_NO_VARIADICS 3852 3853private: 3854 virtual void __on_zero_shared() _NOEXCEPT; 3855 virtual void __on_zero_shared_weak() _NOEXCEPT; 3856public: 3857 _LIBCPP_INLINE_VISIBILITY 3858 _Tp* get() _NOEXCEPT {return &__data_.second();} 3859}; 3860 3861template <class _Tp, class _Alloc> 3862void 3863__shared_ptr_emplace<_Tp, _Alloc>::__on_zero_shared() _NOEXCEPT 3864{ 3865 __data_.second().~_Tp(); 3866} 3867 3868template <class _Tp, class _Alloc> 3869void 3870__shared_ptr_emplace<_Tp, _Alloc>::__on_zero_shared_weak() _NOEXCEPT 3871{ 3872 typedef typename __allocator_traits_rebind<_Alloc, __shared_ptr_emplace>::type _Al; 3873 typedef allocator_traits<_Al> _ATraits; 3874 typedef pointer_traits<typename _ATraits::pointer> _PTraits; 3875 _Al __a(__data_.first()); 3876 __data_.first().~_Alloc(); 3877 __a.deallocate(_PTraits::pointer_to(*this), 1); 3878} 3879 3880template<class _Tp> class _LIBCPP_TEMPLATE_VIS enable_shared_from_this; 3881 3882template<class _Tp> 3883class _LIBCPP_TEMPLATE_VIS shared_ptr 3884{ 3885public: 3886 typedef _Tp element_type; 3887 3888#if _LIBCPP_STD_VER > 14 3889 typedef weak_ptr<_Tp> weak_type; 3890#endif 3891private: 3892 element_type* __ptr_; 3893 __shared_weak_count* __cntrl_; 3894 3895 struct __nat {int __for_bool_;}; 3896public: 3897 _LIBCPP_INLINE_VISIBILITY 3898 _LIBCPP_CONSTEXPR shared_ptr() _NOEXCEPT; 3899 _LIBCPP_INLINE_VISIBILITY 3900 _LIBCPP_CONSTEXPR shared_ptr(nullptr_t) _NOEXCEPT; 3901 template<class _Yp> 3902 explicit shared_ptr(_Yp* __p, 3903 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 3904 template<class _Yp, class _Dp> 3905 shared_ptr(_Yp* __p, _Dp __d, 3906 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 3907 template<class _Yp, class _Dp, class _Alloc> 3908 shared_ptr(_Yp* __p, _Dp __d, _Alloc __a, 3909 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 3910 template <class _Dp> shared_ptr(nullptr_t __p, _Dp __d); 3911 template <class _Dp, class _Alloc> shared_ptr(nullptr_t __p, _Dp __d, _Alloc __a); 3912 template<class _Yp> _LIBCPP_INLINE_VISIBILITY shared_ptr(const shared_ptr<_Yp>& __r, element_type* __p) _NOEXCEPT; 3913 _LIBCPP_INLINE_VISIBILITY 3914 shared_ptr(const shared_ptr& __r) _NOEXCEPT; 3915 template<class _Yp> 3916 _LIBCPP_INLINE_VISIBILITY 3917 shared_ptr(const shared_ptr<_Yp>& __r, 3918 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()) 3919 _NOEXCEPT; 3920#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 3921 _LIBCPP_INLINE_VISIBILITY 3922 shared_ptr(shared_ptr&& __r) _NOEXCEPT; 3923 template<class _Yp> _LIBCPP_INLINE_VISIBILITY shared_ptr(shared_ptr<_Yp>&& __r, 3924 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()) 3925 _NOEXCEPT; 3926#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 3927 template<class _Yp> explicit shared_ptr(const weak_ptr<_Yp>& __r, 3928 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type= __nat()); 3929#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 3930 template<class _Yp> 3931 shared_ptr(auto_ptr<_Yp>&& __r, 3932 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 3933#else 3934 template<class _Yp> 3935 shared_ptr(auto_ptr<_Yp> __r, 3936 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type = __nat()); 3937#endif 3938#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 3939 template <class _Yp, class _Dp> 3940 shared_ptr(unique_ptr<_Yp, _Dp>&&, 3941 typename enable_if 3942 < 3943 !is_lvalue_reference<_Dp>::value && 3944 !is_array<_Yp>::value && 3945 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3946 __nat 3947 >::type = __nat()); 3948 template <class _Yp, class _Dp> 3949 shared_ptr(unique_ptr<_Yp, _Dp>&&, 3950 typename enable_if 3951 < 3952 is_lvalue_reference<_Dp>::value && 3953 !is_array<_Yp>::value && 3954 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3955 __nat 3956 >::type = __nat()); 3957#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 3958 template <class _Yp, class _Dp> 3959 shared_ptr(unique_ptr<_Yp, _Dp>, 3960 typename enable_if 3961 < 3962 !is_lvalue_reference<_Dp>::value && 3963 !is_array<_Yp>::value && 3964 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3965 __nat 3966 >::type = __nat()); 3967 template <class _Yp, class _Dp> 3968 shared_ptr(unique_ptr<_Yp, _Dp>, 3969 typename enable_if 3970 < 3971 is_lvalue_reference<_Dp>::value && 3972 !is_array<_Yp>::value && 3973 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 3974 __nat 3975 >::type = __nat()); 3976#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 3977 3978 ~shared_ptr(); 3979 3980 _LIBCPP_INLINE_VISIBILITY 3981 shared_ptr& operator=(const shared_ptr& __r) _NOEXCEPT; 3982 template<class _Yp> 3983 typename enable_if 3984 < 3985 is_convertible<_Yp*, element_type*>::value, 3986 shared_ptr& 3987 >::type 3988 _LIBCPP_INLINE_VISIBILITY 3989 operator=(const shared_ptr<_Yp>& __r) _NOEXCEPT; 3990#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 3991 _LIBCPP_INLINE_VISIBILITY 3992 shared_ptr& operator=(shared_ptr&& __r) _NOEXCEPT; 3993 template<class _Yp> 3994 typename enable_if 3995 < 3996 is_convertible<_Yp*, element_type*>::value, 3997 shared_ptr<_Tp>& 3998 >::type 3999 _LIBCPP_INLINE_VISIBILITY 4000 operator=(shared_ptr<_Yp>&& __r); 4001 template<class _Yp> 4002 _LIBCPP_INLINE_VISIBILITY 4003 typename enable_if 4004 < 4005 !is_array<_Yp>::value && 4006 is_convertible<_Yp*, element_type*>::value, 4007 shared_ptr 4008 >::type& 4009 operator=(auto_ptr<_Yp>&& __r); 4010#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 4011 template<class _Yp> 4012 _LIBCPP_INLINE_VISIBILITY 4013 typename enable_if 4014 < 4015 !is_array<_Yp>::value && 4016 is_convertible<_Yp*, element_type*>::value, 4017 shared_ptr& 4018 >::type 4019 operator=(auto_ptr<_Yp> __r); 4020#endif 4021 template <class _Yp, class _Dp> 4022 typename enable_if 4023 < 4024 !is_array<_Yp>::value && 4025 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 4026 shared_ptr& 4027 >::type 4028#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4029 _LIBCPP_INLINE_VISIBILITY 4030 operator=(unique_ptr<_Yp, _Dp>&& __r); 4031#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 4032 _LIBCPP_INLINE_VISIBILITY 4033 operator=(unique_ptr<_Yp, _Dp> __r); 4034#endif 4035 4036 _LIBCPP_INLINE_VISIBILITY 4037 void swap(shared_ptr& __r) _NOEXCEPT; 4038 _LIBCPP_INLINE_VISIBILITY 4039 void reset() _NOEXCEPT; 4040 template<class _Yp> 4041 typename enable_if 4042 < 4043 is_convertible<_Yp*, element_type*>::value, 4044 void 4045 >::type 4046 _LIBCPP_INLINE_VISIBILITY 4047 reset(_Yp* __p); 4048 template<class _Yp, class _Dp> 4049 typename enable_if 4050 < 4051 is_convertible<_Yp*, element_type*>::value, 4052 void 4053 >::type 4054 _LIBCPP_INLINE_VISIBILITY 4055 reset(_Yp* __p, _Dp __d); 4056 template<class _Yp, class _Dp, class _Alloc> 4057 typename enable_if 4058 < 4059 is_convertible<_Yp*, element_type*>::value, 4060 void 4061 >::type 4062 _LIBCPP_INLINE_VISIBILITY 4063 reset(_Yp* __p, _Dp __d, _Alloc __a); 4064 4065 _LIBCPP_INLINE_VISIBILITY 4066 element_type* get() const _NOEXCEPT {return __ptr_;} 4067 _LIBCPP_INLINE_VISIBILITY 4068 typename add_lvalue_reference<element_type>::type operator*() const _NOEXCEPT 4069 {return *__ptr_;} 4070 _LIBCPP_INLINE_VISIBILITY 4071 element_type* operator->() const _NOEXCEPT {return __ptr_;} 4072 _LIBCPP_INLINE_VISIBILITY 4073 long use_count() const _NOEXCEPT {return __cntrl_ ? __cntrl_->use_count() : 0;} 4074 _LIBCPP_INLINE_VISIBILITY 4075 bool unique() const _NOEXCEPT {return use_count() == 1;} 4076 _LIBCPP_INLINE_VISIBILITY 4077 _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT {return get() != 0;} 4078 template <class _Up> 4079 _LIBCPP_INLINE_VISIBILITY 4080 bool owner_before(shared_ptr<_Up> const& __p) const 4081 {return __cntrl_ < __p.__cntrl_;} 4082 template <class _Up> 4083 _LIBCPP_INLINE_VISIBILITY 4084 bool owner_before(weak_ptr<_Up> const& __p) const 4085 {return __cntrl_ < __p.__cntrl_;} 4086 _LIBCPP_INLINE_VISIBILITY 4087 bool 4088 __owner_equivalent(const shared_ptr& __p) const 4089 {return __cntrl_ == __p.__cntrl_;} 4090 4091#ifndef _LIBCPP_NO_RTTI 4092 template <class _Dp> 4093 _LIBCPP_INLINE_VISIBILITY 4094 _Dp* __get_deleter() const _NOEXCEPT 4095 {return (_Dp*)(__cntrl_ ? __cntrl_->__get_deleter(typeid(_Dp)) : 0);} 4096#endif // _LIBCPP_NO_RTTI 4097 4098#ifndef _LIBCPP_HAS_NO_VARIADICS 4099 4100 template<class ..._Args> 4101 static 4102 shared_ptr<_Tp> 4103 make_shared(_Args&& ...__args); 4104 4105 template<class _Alloc, class ..._Args> 4106 static 4107 shared_ptr<_Tp> 4108 allocate_shared(const _Alloc& __a, _Args&& ...__args); 4109 4110#else // _LIBCPP_HAS_NO_VARIADICS 4111 4112 static shared_ptr<_Tp> make_shared(); 4113 4114 template<class _A0> 4115 static shared_ptr<_Tp> make_shared(_A0&); 4116 4117 template<class _A0, class _A1> 4118 static shared_ptr<_Tp> make_shared(_A0&, _A1&); 4119 4120 template<class _A0, class _A1, class _A2> 4121 static shared_ptr<_Tp> make_shared(_A0&, _A1&, _A2&); 4122 4123 template<class _Alloc> 4124 static shared_ptr<_Tp> 4125 allocate_shared(const _Alloc& __a); 4126 4127 template<class _Alloc, class _A0> 4128 static shared_ptr<_Tp> 4129 allocate_shared(const _Alloc& __a, _A0& __a0); 4130 4131 template<class _Alloc, class _A0, class _A1> 4132 static shared_ptr<_Tp> 4133 allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1); 4134 4135 template<class _Alloc, class _A0, class _A1, class _A2> 4136 static shared_ptr<_Tp> 4137 allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1, _A2& __a2); 4138 4139#endif // _LIBCPP_HAS_NO_VARIADICS 4140 4141private: 4142 4143 template <class _Yp, class _OrigPtr> 4144 _LIBCPP_INLINE_VISIBILITY 4145 void 4146 __enable_weak_this(const enable_shared_from_this<_Yp>* __e, 4147 _OrigPtr* __ptr) _NOEXCEPT 4148 { 4149 typedef typename remove_cv<_Yp>::type _RawYp; 4150 if (__e && __e->__weak_this_.expired()) 4151 { 4152 __e->__weak_this_ = shared_ptr<_RawYp>(*this, 4153 const_cast<_RawYp*>(static_cast<const _Yp*>(__ptr))); 4154 } 4155 } 4156 4157 _LIBCPP_INLINE_VISIBILITY 4158 void __enable_weak_this(const volatile void*, const volatile void*) _NOEXCEPT {} 4159 4160 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS shared_ptr; 4161 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS weak_ptr; 4162}; 4163 4164template<class _Tp> 4165inline 4166_LIBCPP_CONSTEXPR 4167shared_ptr<_Tp>::shared_ptr() _NOEXCEPT 4168 : __ptr_(0), 4169 __cntrl_(0) 4170{ 4171} 4172 4173template<class _Tp> 4174inline 4175_LIBCPP_CONSTEXPR 4176shared_ptr<_Tp>::shared_ptr(nullptr_t) _NOEXCEPT 4177 : __ptr_(0), 4178 __cntrl_(0) 4179{ 4180} 4181 4182template<class _Tp> 4183template<class _Yp> 4184shared_ptr<_Tp>::shared_ptr(_Yp* __p, 4185 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4186 : __ptr_(__p) 4187{ 4188 unique_ptr<_Yp> __hold(__p); 4189 typedef __shared_ptr_pointer<_Yp*, default_delete<_Yp>, allocator<_Yp> > _CntrlBlk; 4190 __cntrl_ = new _CntrlBlk(__p, default_delete<_Yp>(), allocator<_Yp>()); 4191 __hold.release(); 4192 __enable_weak_this(__p, __p); 4193} 4194 4195template<class _Tp> 4196template<class _Yp, class _Dp> 4197shared_ptr<_Tp>::shared_ptr(_Yp* __p, _Dp __d, 4198 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4199 : __ptr_(__p) 4200{ 4201#ifndef _LIBCPP_NO_EXCEPTIONS 4202 try 4203 { 4204#endif // _LIBCPP_NO_EXCEPTIONS 4205 typedef __shared_ptr_pointer<_Yp*, _Dp, allocator<_Yp> > _CntrlBlk; 4206 __cntrl_ = new _CntrlBlk(__p, __d, allocator<_Yp>()); 4207 __enable_weak_this(__p, __p); 4208#ifndef _LIBCPP_NO_EXCEPTIONS 4209 } 4210 catch (...) 4211 { 4212 __d(__p); 4213 throw; 4214 } 4215#endif // _LIBCPP_NO_EXCEPTIONS 4216} 4217 4218template<class _Tp> 4219template<class _Dp> 4220shared_ptr<_Tp>::shared_ptr(nullptr_t __p, _Dp __d) 4221 : __ptr_(0) 4222{ 4223#ifndef _LIBCPP_NO_EXCEPTIONS 4224 try 4225 { 4226#endif // _LIBCPP_NO_EXCEPTIONS 4227 typedef __shared_ptr_pointer<nullptr_t, _Dp, allocator<_Tp> > _CntrlBlk; 4228 __cntrl_ = new _CntrlBlk(__p, __d, allocator<_Tp>()); 4229#ifndef _LIBCPP_NO_EXCEPTIONS 4230 } 4231 catch (...) 4232 { 4233 __d(__p); 4234 throw; 4235 } 4236#endif // _LIBCPP_NO_EXCEPTIONS 4237} 4238 4239template<class _Tp> 4240template<class _Yp, class _Dp, class _Alloc> 4241shared_ptr<_Tp>::shared_ptr(_Yp* __p, _Dp __d, _Alloc __a, 4242 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4243 : __ptr_(__p) 4244{ 4245#ifndef _LIBCPP_NO_EXCEPTIONS 4246 try 4247 { 4248#endif // _LIBCPP_NO_EXCEPTIONS 4249 typedef __shared_ptr_pointer<_Yp*, _Dp, _Alloc> _CntrlBlk; 4250 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _A2; 4251 typedef __allocator_destructor<_A2> _D2; 4252 _A2 __a2(__a); 4253 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 4254 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4255 _CntrlBlk(__p, __d, __a); 4256 __cntrl_ = _VSTD::addressof(*__hold2.release()); 4257 __enable_weak_this(__p, __p); 4258#ifndef _LIBCPP_NO_EXCEPTIONS 4259 } 4260 catch (...) 4261 { 4262 __d(__p); 4263 throw; 4264 } 4265#endif // _LIBCPP_NO_EXCEPTIONS 4266} 4267 4268template<class _Tp> 4269template<class _Dp, class _Alloc> 4270shared_ptr<_Tp>::shared_ptr(nullptr_t __p, _Dp __d, _Alloc __a) 4271 : __ptr_(0) 4272{ 4273#ifndef _LIBCPP_NO_EXCEPTIONS 4274 try 4275 { 4276#endif // _LIBCPP_NO_EXCEPTIONS 4277 typedef __shared_ptr_pointer<nullptr_t, _Dp, _Alloc> _CntrlBlk; 4278 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _A2; 4279 typedef __allocator_destructor<_A2> _D2; 4280 _A2 __a2(__a); 4281 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 4282 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4283 _CntrlBlk(__p, __d, __a); 4284 __cntrl_ = _VSTD::addressof(*__hold2.release()); 4285#ifndef _LIBCPP_NO_EXCEPTIONS 4286 } 4287 catch (...) 4288 { 4289 __d(__p); 4290 throw; 4291 } 4292#endif // _LIBCPP_NO_EXCEPTIONS 4293} 4294 4295template<class _Tp> 4296template<class _Yp> 4297inline 4298shared_ptr<_Tp>::shared_ptr(const shared_ptr<_Yp>& __r, element_type *__p) _NOEXCEPT 4299 : __ptr_(__p), 4300 __cntrl_(__r.__cntrl_) 4301{ 4302 if (__cntrl_) 4303 __cntrl_->__add_shared(); 4304} 4305 4306template<class _Tp> 4307inline 4308shared_ptr<_Tp>::shared_ptr(const shared_ptr& __r) _NOEXCEPT 4309 : __ptr_(__r.__ptr_), 4310 __cntrl_(__r.__cntrl_) 4311{ 4312 if (__cntrl_) 4313 __cntrl_->__add_shared(); 4314} 4315 4316template<class _Tp> 4317template<class _Yp> 4318inline 4319shared_ptr<_Tp>::shared_ptr(const shared_ptr<_Yp>& __r, 4320 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4321 _NOEXCEPT 4322 : __ptr_(__r.__ptr_), 4323 __cntrl_(__r.__cntrl_) 4324{ 4325 if (__cntrl_) 4326 __cntrl_->__add_shared(); 4327} 4328 4329#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4330 4331template<class _Tp> 4332inline 4333shared_ptr<_Tp>::shared_ptr(shared_ptr&& __r) _NOEXCEPT 4334 : __ptr_(__r.__ptr_), 4335 __cntrl_(__r.__cntrl_) 4336{ 4337 __r.__ptr_ = 0; 4338 __r.__cntrl_ = 0; 4339} 4340 4341template<class _Tp> 4342template<class _Yp> 4343inline 4344shared_ptr<_Tp>::shared_ptr(shared_ptr<_Yp>&& __r, 4345 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4346 _NOEXCEPT 4347 : __ptr_(__r.__ptr_), 4348 __cntrl_(__r.__cntrl_) 4349{ 4350 __r.__ptr_ = 0; 4351 __r.__cntrl_ = 0; 4352} 4353 4354#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 4355 4356template<class _Tp> 4357template<class _Yp> 4358#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4359shared_ptr<_Tp>::shared_ptr(auto_ptr<_Yp>&& __r, 4360#else 4361shared_ptr<_Tp>::shared_ptr(auto_ptr<_Yp> __r, 4362#endif 4363 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 4364 : __ptr_(__r.get()) 4365{ 4366 typedef __shared_ptr_pointer<_Yp*, default_delete<_Yp>, allocator<_Yp> > _CntrlBlk; 4367 __cntrl_ = new _CntrlBlk(__r.get(), default_delete<_Yp>(), allocator<_Yp>()); 4368 __enable_weak_this(__r.get(), __r.get()); 4369 __r.release(); 4370} 4371 4372template<class _Tp> 4373template <class _Yp, class _Dp> 4374#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4375shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp>&& __r, 4376#else 4377shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp> __r, 4378#endif 4379 typename enable_if 4380 < 4381 !is_lvalue_reference<_Dp>::value && 4382 !is_array<_Yp>::value && 4383 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 4384 __nat 4385 >::type) 4386 : __ptr_(__r.get()) 4387{ 4388#if _LIBCPP_STD_VER > 11 4389 if (__ptr_ == nullptr) 4390 __cntrl_ = nullptr; 4391 else 4392#endif 4393 { 4394 typedef __shared_ptr_pointer<_Yp*, _Dp, allocator<_Yp> > _CntrlBlk; 4395 __cntrl_ = new _CntrlBlk(__r.get(), __r.get_deleter(), allocator<_Yp>()); 4396 __enable_weak_this(__r.get(), __r.get()); 4397 } 4398 __r.release(); 4399} 4400 4401template<class _Tp> 4402template <class _Yp, class _Dp> 4403#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4404shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp>&& __r, 4405#else 4406shared_ptr<_Tp>::shared_ptr(unique_ptr<_Yp, _Dp> __r, 4407#endif 4408 typename enable_if 4409 < 4410 is_lvalue_reference<_Dp>::value && 4411 !is_array<_Yp>::value && 4412 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, element_type*>::value, 4413 __nat 4414 >::type) 4415 : __ptr_(__r.get()) 4416{ 4417#if _LIBCPP_STD_VER > 11 4418 if (__ptr_ == nullptr) 4419 __cntrl_ = nullptr; 4420 else 4421#endif 4422 { 4423 typedef __shared_ptr_pointer<_Yp*, 4424 reference_wrapper<typename remove_reference<_Dp>::type>, 4425 allocator<_Yp> > _CntrlBlk; 4426 __cntrl_ = new _CntrlBlk(__r.get(), ref(__r.get_deleter()), allocator<_Yp>()); 4427 __enable_weak_this(__r.get(), __r.get()); 4428 } 4429 __r.release(); 4430} 4431 4432#ifndef _LIBCPP_HAS_NO_VARIADICS 4433 4434template<class _Tp> 4435template<class ..._Args> 4436shared_ptr<_Tp> 4437shared_ptr<_Tp>::make_shared(_Args&& ...__args) 4438{ 4439 typedef __shared_ptr_emplace<_Tp, allocator<_Tp> > _CntrlBlk; 4440 typedef allocator<_CntrlBlk> _A2; 4441 typedef __allocator_destructor<_A2> _D2; 4442 _A2 __a2; 4443 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 4444 ::new(__hold2.get()) _CntrlBlk(__a2, _VSTD::forward<_Args>(__args)...); 4445 shared_ptr<_Tp> __r; 4446 __r.__ptr_ = __hold2.get()->get(); 4447 __r.__cntrl_ = __hold2.release(); 4448 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4449 return __r; 4450} 4451 4452template<class _Tp> 4453template<class _Alloc, class ..._Args> 4454shared_ptr<_Tp> 4455shared_ptr<_Tp>::allocate_shared(const _Alloc& __a, _Args&& ...__args) 4456{ 4457 typedef __shared_ptr_emplace<_Tp, _Alloc> _CntrlBlk; 4458 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _A2; 4459 typedef __allocator_destructor<_A2> _D2; 4460 _A2 __a2(__a); 4461 unique_ptr<_CntrlBlk, _D2> __hold2(__a2.allocate(1), _D2(__a2, 1)); 4462 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4463 _CntrlBlk(__a, _VSTD::forward<_Args>(__args)...); 4464 shared_ptr<_Tp> __r; 4465 __r.__ptr_ = __hold2.get()->get(); 4466 __r.__cntrl_ = _VSTD::addressof(*__hold2.release()); 4467 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4468 return __r; 4469} 4470 4471#else // _LIBCPP_HAS_NO_VARIADICS 4472 4473template<class _Tp> 4474shared_ptr<_Tp> 4475shared_ptr<_Tp>::make_shared() 4476{ 4477 typedef __shared_ptr_emplace<_Tp, allocator<_Tp> > _CntrlBlk; 4478 typedef allocator<_CntrlBlk> _Alloc2; 4479 typedef __allocator_destructor<_Alloc2> _D2; 4480 _Alloc2 __alloc2; 4481 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4482 ::new(__hold2.get()) _CntrlBlk(__alloc2); 4483 shared_ptr<_Tp> __r; 4484 __r.__ptr_ = __hold2.get()->get(); 4485 __r.__cntrl_ = __hold2.release(); 4486 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4487 return __r; 4488} 4489 4490template<class _Tp> 4491template<class _A0> 4492shared_ptr<_Tp> 4493shared_ptr<_Tp>::make_shared(_A0& __a0) 4494{ 4495 typedef __shared_ptr_emplace<_Tp, allocator<_Tp> > _CntrlBlk; 4496 typedef allocator<_CntrlBlk> _Alloc2; 4497 typedef __allocator_destructor<_Alloc2> _D2; 4498 _Alloc2 __alloc2; 4499 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4500 ::new(__hold2.get()) _CntrlBlk(__alloc2, __a0); 4501 shared_ptr<_Tp> __r; 4502 __r.__ptr_ = __hold2.get()->get(); 4503 __r.__cntrl_ = __hold2.release(); 4504 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4505 return __r; 4506} 4507 4508template<class _Tp> 4509template<class _A0, class _A1> 4510shared_ptr<_Tp> 4511shared_ptr<_Tp>::make_shared(_A0& __a0, _A1& __a1) 4512{ 4513 typedef __shared_ptr_emplace<_Tp, allocator<_Tp> > _CntrlBlk; 4514 typedef allocator<_CntrlBlk> _Alloc2; 4515 typedef __allocator_destructor<_Alloc2> _D2; 4516 _Alloc2 __alloc2; 4517 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4518 ::new(__hold2.get()) _CntrlBlk(__alloc2, __a0, __a1); 4519 shared_ptr<_Tp> __r; 4520 __r.__ptr_ = __hold2.get()->get(); 4521 __r.__cntrl_ = __hold2.release(); 4522 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4523 return __r; 4524} 4525 4526template<class _Tp> 4527template<class _A0, class _A1, class _A2> 4528shared_ptr<_Tp> 4529shared_ptr<_Tp>::make_shared(_A0& __a0, _A1& __a1, _A2& __a2) 4530{ 4531 typedef __shared_ptr_emplace<_Tp, allocator<_Tp> > _CntrlBlk; 4532 typedef allocator<_CntrlBlk> _Alloc2; 4533 typedef __allocator_destructor<_Alloc2> _D2; 4534 _Alloc2 __alloc2; 4535 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4536 ::new(__hold2.get()) _CntrlBlk(__alloc2, __a0, __a1, __a2); 4537 shared_ptr<_Tp> __r; 4538 __r.__ptr_ = __hold2.get()->get(); 4539 __r.__cntrl_ = __hold2.release(); 4540 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4541 return __r; 4542} 4543 4544template<class _Tp> 4545template<class _Alloc> 4546shared_ptr<_Tp> 4547shared_ptr<_Tp>::allocate_shared(const _Alloc& __a) 4548{ 4549 typedef __shared_ptr_emplace<_Tp, _Alloc> _CntrlBlk; 4550 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _Alloc2; 4551 typedef __allocator_destructor<_Alloc2> _D2; 4552 _Alloc2 __alloc2(__a); 4553 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4554 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4555 _CntrlBlk(__a); 4556 shared_ptr<_Tp> __r; 4557 __r.__ptr_ = __hold2.get()->get(); 4558 __r.__cntrl_ = _VSTD::addressof(*__hold2.release()); 4559 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4560 return __r; 4561} 4562 4563template<class _Tp> 4564template<class _Alloc, class _A0> 4565shared_ptr<_Tp> 4566shared_ptr<_Tp>::allocate_shared(const _Alloc& __a, _A0& __a0) 4567{ 4568 typedef __shared_ptr_emplace<_Tp, _Alloc> _CntrlBlk; 4569 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _Alloc2; 4570 typedef __allocator_destructor<_Alloc2> _D2; 4571 _Alloc2 __alloc2(__a); 4572 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4573 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4574 _CntrlBlk(__a, __a0); 4575 shared_ptr<_Tp> __r; 4576 __r.__ptr_ = __hold2.get()->get(); 4577 __r.__cntrl_ = _VSTD::addressof(*__hold2.release()); 4578 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4579 return __r; 4580} 4581 4582template<class _Tp> 4583template<class _Alloc, class _A0, class _A1> 4584shared_ptr<_Tp> 4585shared_ptr<_Tp>::allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1) 4586{ 4587 typedef __shared_ptr_emplace<_Tp, _Alloc> _CntrlBlk; 4588 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _Alloc2; 4589 typedef __allocator_destructor<_Alloc2> _D2; 4590 _Alloc2 __alloc2(__a); 4591 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4592 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4593 _CntrlBlk(__a, __a0, __a1); 4594 shared_ptr<_Tp> __r; 4595 __r.__ptr_ = __hold2.get()->get(); 4596 __r.__cntrl_ = _VSTD::addressof(*__hold2.release()); 4597 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4598 return __r; 4599} 4600 4601template<class _Tp> 4602template<class _Alloc, class _A0, class _A1, class _A2> 4603shared_ptr<_Tp> 4604shared_ptr<_Tp>::allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1, _A2& __a2) 4605{ 4606 typedef __shared_ptr_emplace<_Tp, _Alloc> _CntrlBlk; 4607 typedef typename __allocator_traits_rebind<_Alloc, _CntrlBlk>::type _Alloc2; 4608 typedef __allocator_destructor<_Alloc2> _D2; 4609 _Alloc2 __alloc2(__a); 4610 unique_ptr<_CntrlBlk, _D2> __hold2(__alloc2.allocate(1), _D2(__alloc2, 1)); 4611 ::new(static_cast<void*>(_VSTD::addressof(*__hold2.get()))) 4612 _CntrlBlk(__a, __a0, __a1, __a2); 4613 shared_ptr<_Tp> __r; 4614 __r.__ptr_ = __hold2.get()->get(); 4615 __r.__cntrl_ = _VSTD::addressof(*__hold2.release()); 4616 __r.__enable_weak_this(__r.__ptr_, __r.__ptr_); 4617 return __r; 4618} 4619 4620#endif // _LIBCPP_HAS_NO_VARIADICS 4621 4622template<class _Tp> 4623shared_ptr<_Tp>::~shared_ptr() 4624{ 4625 if (__cntrl_) 4626 __cntrl_->__release_shared(); 4627} 4628 4629template<class _Tp> 4630inline 4631shared_ptr<_Tp>& 4632shared_ptr<_Tp>::operator=(const shared_ptr& __r) _NOEXCEPT 4633{ 4634 shared_ptr(__r).swap(*this); 4635 return *this; 4636} 4637 4638template<class _Tp> 4639template<class _Yp> 4640inline 4641typename enable_if 4642< 4643 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4644 shared_ptr<_Tp>& 4645>::type 4646shared_ptr<_Tp>::operator=(const shared_ptr<_Yp>& __r) _NOEXCEPT 4647{ 4648 shared_ptr(__r).swap(*this); 4649 return *this; 4650} 4651 4652#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 4653 4654template<class _Tp> 4655inline 4656shared_ptr<_Tp>& 4657shared_ptr<_Tp>::operator=(shared_ptr&& __r) _NOEXCEPT 4658{ 4659 shared_ptr(_VSTD::move(__r)).swap(*this); 4660 return *this; 4661} 4662 4663template<class _Tp> 4664template<class _Yp> 4665inline 4666typename enable_if 4667< 4668 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4669 shared_ptr<_Tp>& 4670>::type 4671shared_ptr<_Tp>::operator=(shared_ptr<_Yp>&& __r) 4672{ 4673 shared_ptr(_VSTD::move(__r)).swap(*this); 4674 return *this; 4675} 4676 4677template<class _Tp> 4678template<class _Yp> 4679inline 4680typename enable_if 4681< 4682 !is_array<_Yp>::value && 4683 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4684 shared_ptr<_Tp> 4685>::type& 4686shared_ptr<_Tp>::operator=(auto_ptr<_Yp>&& __r) 4687{ 4688 shared_ptr(_VSTD::move(__r)).swap(*this); 4689 return *this; 4690} 4691 4692template<class _Tp> 4693template <class _Yp, class _Dp> 4694inline 4695typename enable_if 4696< 4697 !is_array<_Yp>::value && 4698 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, 4699 typename shared_ptr<_Tp>::element_type*>::value, 4700 shared_ptr<_Tp>& 4701>::type 4702shared_ptr<_Tp>::operator=(unique_ptr<_Yp, _Dp>&& __r) 4703{ 4704 shared_ptr(_VSTD::move(__r)).swap(*this); 4705 return *this; 4706} 4707 4708#else // _LIBCPP_HAS_NO_RVALUE_REFERENCES 4709 4710template<class _Tp> 4711template<class _Yp> 4712inline _LIBCPP_INLINE_VISIBILITY 4713typename enable_if 4714< 4715 !is_array<_Yp>::value && 4716 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4717 shared_ptr<_Tp>& 4718>::type 4719shared_ptr<_Tp>::operator=(auto_ptr<_Yp> __r) 4720{ 4721 shared_ptr(__r).swap(*this); 4722 return *this; 4723} 4724 4725template<class _Tp> 4726template <class _Yp, class _Dp> 4727inline _LIBCPP_INLINE_VISIBILITY 4728typename enable_if 4729< 4730 !is_array<_Yp>::value && 4731 is_convertible<typename unique_ptr<_Yp, _Dp>::pointer, 4732 typename shared_ptr<_Tp>::element_type*>::value, 4733 shared_ptr<_Tp>& 4734>::type 4735shared_ptr<_Tp>::operator=(unique_ptr<_Yp, _Dp> __r) 4736{ 4737 shared_ptr(_VSTD::move(__r)).swap(*this); 4738 return *this; 4739} 4740 4741#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 4742 4743template<class _Tp> 4744inline 4745void 4746shared_ptr<_Tp>::swap(shared_ptr& __r) _NOEXCEPT 4747{ 4748 _VSTD::swap(__ptr_, __r.__ptr_); 4749 _VSTD::swap(__cntrl_, __r.__cntrl_); 4750} 4751 4752template<class _Tp> 4753inline 4754void 4755shared_ptr<_Tp>::reset() _NOEXCEPT 4756{ 4757 shared_ptr().swap(*this); 4758} 4759 4760template<class _Tp> 4761template<class _Yp> 4762inline 4763typename enable_if 4764< 4765 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4766 void 4767>::type 4768shared_ptr<_Tp>::reset(_Yp* __p) 4769{ 4770 shared_ptr(__p).swap(*this); 4771} 4772 4773template<class _Tp> 4774template<class _Yp, class _Dp> 4775inline 4776typename enable_if 4777< 4778 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4779 void 4780>::type 4781shared_ptr<_Tp>::reset(_Yp* __p, _Dp __d) 4782{ 4783 shared_ptr(__p, __d).swap(*this); 4784} 4785 4786template<class _Tp> 4787template<class _Yp, class _Dp, class _Alloc> 4788inline 4789typename enable_if 4790< 4791 is_convertible<_Yp*, typename shared_ptr<_Tp>::element_type*>::value, 4792 void 4793>::type 4794shared_ptr<_Tp>::reset(_Yp* __p, _Dp __d, _Alloc __a) 4795{ 4796 shared_ptr(__p, __d, __a).swap(*this); 4797} 4798 4799#ifndef _LIBCPP_HAS_NO_VARIADICS 4800 4801template<class _Tp, class ..._Args> 4802inline _LIBCPP_INLINE_VISIBILITY 4803typename enable_if 4804< 4805 !is_array<_Tp>::value, 4806 shared_ptr<_Tp> 4807>::type 4808make_shared(_Args&& ...__args) 4809{ 4810 return shared_ptr<_Tp>::make_shared(_VSTD::forward<_Args>(__args)...); 4811} 4812 4813template<class _Tp, class _Alloc, class ..._Args> 4814inline _LIBCPP_INLINE_VISIBILITY 4815typename enable_if 4816< 4817 !is_array<_Tp>::value, 4818 shared_ptr<_Tp> 4819>::type 4820allocate_shared(const _Alloc& __a, _Args&& ...__args) 4821{ 4822 return shared_ptr<_Tp>::allocate_shared(__a, _VSTD::forward<_Args>(__args)...); 4823} 4824 4825#else // _LIBCPP_HAS_NO_VARIADICS 4826 4827template<class _Tp> 4828inline _LIBCPP_INLINE_VISIBILITY 4829shared_ptr<_Tp> 4830make_shared() 4831{ 4832 return shared_ptr<_Tp>::make_shared(); 4833} 4834 4835template<class _Tp, class _A0> 4836inline _LIBCPP_INLINE_VISIBILITY 4837shared_ptr<_Tp> 4838make_shared(_A0& __a0) 4839{ 4840 return shared_ptr<_Tp>::make_shared(__a0); 4841} 4842 4843template<class _Tp, class _A0, class _A1> 4844inline _LIBCPP_INLINE_VISIBILITY 4845shared_ptr<_Tp> 4846make_shared(_A0& __a0, _A1& __a1) 4847{ 4848 return shared_ptr<_Tp>::make_shared(__a0, __a1); 4849} 4850 4851template<class _Tp, class _A0, class _A1, class _A2> 4852inline _LIBCPP_INLINE_VISIBILITY 4853shared_ptr<_Tp> 4854make_shared(_A0& __a0, _A1& __a1, _A2& __a2) 4855{ 4856 return shared_ptr<_Tp>::make_shared(__a0, __a1, __a2); 4857} 4858 4859template<class _Tp, class _Alloc> 4860inline _LIBCPP_INLINE_VISIBILITY 4861shared_ptr<_Tp> 4862allocate_shared(const _Alloc& __a) 4863{ 4864 return shared_ptr<_Tp>::allocate_shared(__a); 4865} 4866 4867template<class _Tp, class _Alloc, class _A0> 4868inline _LIBCPP_INLINE_VISIBILITY 4869shared_ptr<_Tp> 4870allocate_shared(const _Alloc& __a, _A0& __a0) 4871{ 4872 return shared_ptr<_Tp>::allocate_shared(__a, __a0); 4873} 4874 4875template<class _Tp, class _Alloc, class _A0, class _A1> 4876inline _LIBCPP_INLINE_VISIBILITY 4877shared_ptr<_Tp> 4878allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1) 4879{ 4880 return shared_ptr<_Tp>::allocate_shared(__a, __a0, __a1); 4881} 4882 4883template<class _Tp, class _Alloc, class _A0, class _A1, class _A2> 4884inline _LIBCPP_INLINE_VISIBILITY 4885shared_ptr<_Tp> 4886allocate_shared(const _Alloc& __a, _A0& __a0, _A1& __a1, _A2& __a2) 4887{ 4888 return shared_ptr<_Tp>::allocate_shared(__a, __a0, __a1, __a2); 4889} 4890 4891#endif // _LIBCPP_HAS_NO_VARIADICS 4892 4893template<class _Tp, class _Up> 4894inline _LIBCPP_INLINE_VISIBILITY 4895bool 4896operator==(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4897{ 4898 return __x.get() == __y.get(); 4899} 4900 4901template<class _Tp, class _Up> 4902inline _LIBCPP_INLINE_VISIBILITY 4903bool 4904operator!=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4905{ 4906 return !(__x == __y); 4907} 4908 4909template<class _Tp, class _Up> 4910inline _LIBCPP_INLINE_VISIBILITY 4911bool 4912operator<(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4913{ 4914 typedef typename common_type<_Tp*, _Up*>::type _Vp; 4915 return less<_Vp>()(__x.get(), __y.get()); 4916} 4917 4918template<class _Tp, class _Up> 4919inline _LIBCPP_INLINE_VISIBILITY 4920bool 4921operator>(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4922{ 4923 return __y < __x; 4924} 4925 4926template<class _Tp, class _Up> 4927inline _LIBCPP_INLINE_VISIBILITY 4928bool 4929operator<=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4930{ 4931 return !(__y < __x); 4932} 4933 4934template<class _Tp, class _Up> 4935inline _LIBCPP_INLINE_VISIBILITY 4936bool 4937operator>=(const shared_ptr<_Tp>& __x, const shared_ptr<_Up>& __y) _NOEXCEPT 4938{ 4939 return !(__x < __y); 4940} 4941 4942template<class _Tp> 4943inline _LIBCPP_INLINE_VISIBILITY 4944bool 4945operator==(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 4946{ 4947 return !__x; 4948} 4949 4950template<class _Tp> 4951inline _LIBCPP_INLINE_VISIBILITY 4952bool 4953operator==(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 4954{ 4955 return !__x; 4956} 4957 4958template<class _Tp> 4959inline _LIBCPP_INLINE_VISIBILITY 4960bool 4961operator!=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 4962{ 4963 return static_cast<bool>(__x); 4964} 4965 4966template<class _Tp> 4967inline _LIBCPP_INLINE_VISIBILITY 4968bool 4969operator!=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 4970{ 4971 return static_cast<bool>(__x); 4972} 4973 4974template<class _Tp> 4975inline _LIBCPP_INLINE_VISIBILITY 4976bool 4977operator<(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 4978{ 4979 return less<_Tp*>()(__x.get(), nullptr); 4980} 4981 4982template<class _Tp> 4983inline _LIBCPP_INLINE_VISIBILITY 4984bool 4985operator<(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 4986{ 4987 return less<_Tp*>()(nullptr, __x.get()); 4988} 4989 4990template<class _Tp> 4991inline _LIBCPP_INLINE_VISIBILITY 4992bool 4993operator>(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 4994{ 4995 return nullptr < __x; 4996} 4997 4998template<class _Tp> 4999inline _LIBCPP_INLINE_VISIBILITY 5000bool 5001operator>(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 5002{ 5003 return __x < nullptr; 5004} 5005 5006template<class _Tp> 5007inline _LIBCPP_INLINE_VISIBILITY 5008bool 5009operator<=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 5010{ 5011 return !(nullptr < __x); 5012} 5013 5014template<class _Tp> 5015inline _LIBCPP_INLINE_VISIBILITY 5016bool 5017operator<=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 5018{ 5019 return !(__x < nullptr); 5020} 5021 5022template<class _Tp> 5023inline _LIBCPP_INLINE_VISIBILITY 5024bool 5025operator>=(const shared_ptr<_Tp>& __x, nullptr_t) _NOEXCEPT 5026{ 5027 return !(__x < nullptr); 5028} 5029 5030template<class _Tp> 5031inline _LIBCPP_INLINE_VISIBILITY 5032bool 5033operator>=(nullptr_t, const shared_ptr<_Tp>& __x) _NOEXCEPT 5034{ 5035 return !(nullptr < __x); 5036} 5037 5038template<class _Tp> 5039inline _LIBCPP_INLINE_VISIBILITY 5040void 5041swap(shared_ptr<_Tp>& __x, shared_ptr<_Tp>& __y) _NOEXCEPT 5042{ 5043 __x.swap(__y); 5044} 5045 5046template<class _Tp, class _Up> 5047inline _LIBCPP_INLINE_VISIBILITY 5048typename enable_if 5049< 5050 !is_array<_Tp>::value && !is_array<_Up>::value, 5051 shared_ptr<_Tp> 5052>::type 5053static_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 5054{ 5055 return shared_ptr<_Tp>(__r, static_cast<_Tp*>(__r.get())); 5056} 5057 5058template<class _Tp, class _Up> 5059inline _LIBCPP_INLINE_VISIBILITY 5060typename enable_if 5061< 5062 !is_array<_Tp>::value && !is_array<_Up>::value, 5063 shared_ptr<_Tp> 5064>::type 5065dynamic_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 5066{ 5067 _Tp* __p = dynamic_cast<_Tp*>(__r.get()); 5068 return __p ? shared_ptr<_Tp>(__r, __p) : shared_ptr<_Tp>(); 5069} 5070 5071template<class _Tp, class _Up> 5072typename enable_if 5073< 5074 is_array<_Tp>::value == is_array<_Up>::value, 5075 shared_ptr<_Tp> 5076>::type 5077const_pointer_cast(const shared_ptr<_Up>& __r) _NOEXCEPT 5078{ 5079 typedef typename remove_extent<_Tp>::type _RTp; 5080 return shared_ptr<_Tp>(__r, const_cast<_RTp*>(__r.get())); 5081} 5082 5083#ifndef _LIBCPP_NO_RTTI 5084 5085template<class _Dp, class _Tp> 5086inline _LIBCPP_INLINE_VISIBILITY 5087_Dp* 5088get_deleter(const shared_ptr<_Tp>& __p) _NOEXCEPT 5089{ 5090 return __p.template __get_deleter<_Dp>(); 5091} 5092 5093#endif // _LIBCPP_NO_RTTI 5094 5095template<class _Tp> 5096class _LIBCPP_TEMPLATE_VIS weak_ptr 5097{ 5098public: 5099 typedef _Tp element_type; 5100private: 5101 element_type* __ptr_; 5102 __shared_weak_count* __cntrl_; 5103 5104public: 5105 _LIBCPP_INLINE_VISIBILITY 5106 _LIBCPP_CONSTEXPR weak_ptr() _NOEXCEPT; 5107 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(shared_ptr<_Yp> const& __r, 5108 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 5109 _NOEXCEPT; 5110 _LIBCPP_INLINE_VISIBILITY 5111 weak_ptr(weak_ptr const& __r) _NOEXCEPT; 5112 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(weak_ptr<_Yp> const& __r, 5113 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 5114 _NOEXCEPT; 5115 5116#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 5117 _LIBCPP_INLINE_VISIBILITY 5118 weak_ptr(weak_ptr&& __r) _NOEXCEPT; 5119 template<class _Yp> _LIBCPP_INLINE_VISIBILITY weak_ptr(weak_ptr<_Yp>&& __r, 5120 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type = 0) 5121 _NOEXCEPT; 5122#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 5123 ~weak_ptr(); 5124 5125 _LIBCPP_INLINE_VISIBILITY 5126 weak_ptr& operator=(weak_ptr const& __r) _NOEXCEPT; 5127 template<class _Yp> 5128 typename enable_if 5129 < 5130 is_convertible<_Yp*, element_type*>::value, 5131 weak_ptr& 5132 >::type 5133 _LIBCPP_INLINE_VISIBILITY 5134 operator=(weak_ptr<_Yp> const& __r) _NOEXCEPT; 5135 5136#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 5137 5138 _LIBCPP_INLINE_VISIBILITY 5139 weak_ptr& operator=(weak_ptr&& __r) _NOEXCEPT; 5140 template<class _Yp> 5141 typename enable_if 5142 < 5143 is_convertible<_Yp*, element_type*>::value, 5144 weak_ptr& 5145 >::type 5146 _LIBCPP_INLINE_VISIBILITY 5147 operator=(weak_ptr<_Yp>&& __r) _NOEXCEPT; 5148 5149#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 5150 5151 template<class _Yp> 5152 typename enable_if 5153 < 5154 is_convertible<_Yp*, element_type*>::value, 5155 weak_ptr& 5156 >::type 5157 _LIBCPP_INLINE_VISIBILITY 5158 operator=(shared_ptr<_Yp> const& __r) _NOEXCEPT; 5159 5160 _LIBCPP_INLINE_VISIBILITY 5161 void swap(weak_ptr& __r) _NOEXCEPT; 5162 _LIBCPP_INLINE_VISIBILITY 5163 void reset() _NOEXCEPT; 5164 5165 _LIBCPP_INLINE_VISIBILITY 5166 long use_count() const _NOEXCEPT 5167 {return __cntrl_ ? __cntrl_->use_count() : 0;} 5168 _LIBCPP_INLINE_VISIBILITY 5169 bool expired() const _NOEXCEPT 5170 {return __cntrl_ == 0 || __cntrl_->use_count() == 0;} 5171 shared_ptr<_Tp> lock() const _NOEXCEPT; 5172 template<class _Up> 5173 _LIBCPP_INLINE_VISIBILITY 5174 bool owner_before(const shared_ptr<_Up>& __r) const 5175 {return __cntrl_ < __r.__cntrl_;} 5176 template<class _Up> 5177 _LIBCPP_INLINE_VISIBILITY 5178 bool owner_before(const weak_ptr<_Up>& __r) const 5179 {return __cntrl_ < __r.__cntrl_;} 5180 5181 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS weak_ptr; 5182 template <class _Up> friend class _LIBCPP_TEMPLATE_VIS shared_ptr; 5183}; 5184 5185template<class _Tp> 5186inline 5187_LIBCPP_CONSTEXPR 5188weak_ptr<_Tp>::weak_ptr() _NOEXCEPT 5189 : __ptr_(0), 5190 __cntrl_(0) 5191{ 5192} 5193 5194template<class _Tp> 5195inline 5196weak_ptr<_Tp>::weak_ptr(weak_ptr const& __r) _NOEXCEPT 5197 : __ptr_(__r.__ptr_), 5198 __cntrl_(__r.__cntrl_) 5199{ 5200 if (__cntrl_) 5201 __cntrl_->__add_weak(); 5202} 5203 5204template<class _Tp> 5205template<class _Yp> 5206inline 5207weak_ptr<_Tp>::weak_ptr(shared_ptr<_Yp> const& __r, 5208 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 5209 _NOEXCEPT 5210 : __ptr_(__r.__ptr_), 5211 __cntrl_(__r.__cntrl_) 5212{ 5213 if (__cntrl_) 5214 __cntrl_->__add_weak(); 5215} 5216 5217template<class _Tp> 5218template<class _Yp> 5219inline 5220weak_ptr<_Tp>::weak_ptr(weak_ptr<_Yp> const& __r, 5221 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 5222 _NOEXCEPT 5223 : __ptr_(__r.__ptr_), 5224 __cntrl_(__r.__cntrl_) 5225{ 5226 if (__cntrl_) 5227 __cntrl_->__add_weak(); 5228} 5229 5230#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 5231 5232template<class _Tp> 5233inline 5234weak_ptr<_Tp>::weak_ptr(weak_ptr&& __r) _NOEXCEPT 5235 : __ptr_(__r.__ptr_), 5236 __cntrl_(__r.__cntrl_) 5237{ 5238 __r.__ptr_ = 0; 5239 __r.__cntrl_ = 0; 5240} 5241 5242template<class _Tp> 5243template<class _Yp> 5244inline 5245weak_ptr<_Tp>::weak_ptr(weak_ptr<_Yp>&& __r, 5246 typename enable_if<is_convertible<_Yp*, _Tp*>::value, __nat*>::type) 5247 _NOEXCEPT 5248 : __ptr_(__r.__ptr_), 5249 __cntrl_(__r.__cntrl_) 5250{ 5251 __r.__ptr_ = 0; 5252 __r.__cntrl_ = 0; 5253} 5254 5255#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 5256 5257template<class _Tp> 5258weak_ptr<_Tp>::~weak_ptr() 5259{ 5260 if (__cntrl_) 5261 __cntrl_->__release_weak(); 5262} 5263 5264template<class _Tp> 5265inline 5266weak_ptr<_Tp>& 5267weak_ptr<_Tp>::operator=(weak_ptr const& __r) _NOEXCEPT 5268{ 5269 weak_ptr(__r).swap(*this); 5270 return *this; 5271} 5272 5273template<class _Tp> 5274template<class _Yp> 5275inline 5276typename enable_if 5277< 5278 is_convertible<_Yp*, _Tp*>::value, 5279 weak_ptr<_Tp>& 5280>::type 5281weak_ptr<_Tp>::operator=(weak_ptr<_Yp> const& __r) _NOEXCEPT 5282{ 5283 weak_ptr(__r).swap(*this); 5284 return *this; 5285} 5286 5287#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 5288 5289template<class _Tp> 5290inline 5291weak_ptr<_Tp>& 5292weak_ptr<_Tp>::operator=(weak_ptr&& __r) _NOEXCEPT 5293{ 5294 weak_ptr(_VSTD::move(__r)).swap(*this); 5295 return *this; 5296} 5297 5298template<class _Tp> 5299template<class _Yp> 5300inline 5301typename enable_if 5302< 5303 is_convertible<_Yp*, _Tp*>::value, 5304 weak_ptr<_Tp>& 5305>::type 5306weak_ptr<_Tp>::operator=(weak_ptr<_Yp>&& __r) _NOEXCEPT 5307{ 5308 weak_ptr(_VSTD::move(__r)).swap(*this); 5309 return *this; 5310} 5311 5312#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 5313 5314template<class _Tp> 5315template<class _Yp> 5316inline 5317typename enable_if 5318< 5319 is_convertible<_Yp*, _Tp*>::value, 5320 weak_ptr<_Tp>& 5321>::type 5322weak_ptr<_Tp>::operator=(shared_ptr<_Yp> const& __r) _NOEXCEPT 5323{ 5324 weak_ptr(__r).swap(*this); 5325 return *this; 5326} 5327 5328template<class _Tp> 5329inline 5330void 5331weak_ptr<_Tp>::swap(weak_ptr& __r) _NOEXCEPT 5332{ 5333 _VSTD::swap(__ptr_, __r.__ptr_); 5334 _VSTD::swap(__cntrl_, __r.__cntrl_); 5335} 5336 5337template<class _Tp> 5338inline _LIBCPP_INLINE_VISIBILITY 5339void 5340swap(weak_ptr<_Tp>& __x, weak_ptr<_Tp>& __y) _NOEXCEPT 5341{ 5342 __x.swap(__y); 5343} 5344 5345template<class _Tp> 5346inline 5347void 5348weak_ptr<_Tp>::reset() _NOEXCEPT 5349{ 5350 weak_ptr().swap(*this); 5351} 5352 5353template<class _Tp> 5354template<class _Yp> 5355shared_ptr<_Tp>::shared_ptr(const weak_ptr<_Yp>& __r, 5356 typename enable_if<is_convertible<_Yp*, element_type*>::value, __nat>::type) 5357 : __ptr_(__r.__ptr_), 5358 __cntrl_(__r.__cntrl_ ? __r.__cntrl_->lock() : __r.__cntrl_) 5359{ 5360 if (__cntrl_ == 0) 5361 __throw_bad_weak_ptr(); 5362} 5363 5364template<class _Tp> 5365shared_ptr<_Tp> 5366weak_ptr<_Tp>::lock() const _NOEXCEPT 5367{ 5368 shared_ptr<_Tp> __r; 5369 __r.__cntrl_ = __cntrl_ ? __cntrl_->lock() : __cntrl_; 5370 if (__r.__cntrl_) 5371 __r.__ptr_ = __ptr_; 5372 return __r; 5373} 5374 5375#if _LIBCPP_STD_VER > 14 5376template <class _Tp = void> struct owner_less; 5377#else 5378template <class _Tp> struct owner_less; 5379#endif 5380 5381template <class _Tp> 5382struct _LIBCPP_TEMPLATE_VIS owner_less<shared_ptr<_Tp> > 5383 : binary_function<shared_ptr<_Tp>, shared_ptr<_Tp>, bool> 5384{ 5385 typedef bool result_type; 5386 _LIBCPP_INLINE_VISIBILITY 5387 bool operator()(shared_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const 5388 {return __x.owner_before(__y);} 5389 _LIBCPP_INLINE_VISIBILITY 5390 bool operator()(shared_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const 5391 {return __x.owner_before(__y);} 5392 _LIBCPP_INLINE_VISIBILITY 5393 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const 5394 {return __x.owner_before(__y);} 5395}; 5396 5397template <class _Tp> 5398struct _LIBCPP_TEMPLATE_VIS owner_less<weak_ptr<_Tp> > 5399 : binary_function<weak_ptr<_Tp>, weak_ptr<_Tp>, bool> 5400{ 5401 typedef bool result_type; 5402 _LIBCPP_INLINE_VISIBILITY 5403 bool operator()( weak_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const 5404 {return __x.owner_before(__y);} 5405 _LIBCPP_INLINE_VISIBILITY 5406 bool operator()(shared_ptr<_Tp> const& __x, weak_ptr<_Tp> const& __y) const 5407 {return __x.owner_before(__y);} 5408 _LIBCPP_INLINE_VISIBILITY 5409 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Tp> const& __y) const 5410 {return __x.owner_before(__y);} 5411}; 5412 5413#if _LIBCPP_STD_VER > 14 5414template <> 5415struct _LIBCPP_TEMPLATE_VIS owner_less<void> 5416{ 5417 template <class _Tp, class _Up> 5418 _LIBCPP_INLINE_VISIBILITY 5419 bool operator()( shared_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const 5420 {return __x.owner_before(__y);} 5421 template <class _Tp, class _Up> 5422 _LIBCPP_INLINE_VISIBILITY 5423 bool operator()( shared_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const 5424 {return __x.owner_before(__y);} 5425 template <class _Tp, class _Up> 5426 _LIBCPP_INLINE_VISIBILITY 5427 bool operator()( weak_ptr<_Tp> const& __x, shared_ptr<_Up> const& __y) const 5428 {return __x.owner_before(__y);} 5429 template <class _Tp, class _Up> 5430 _LIBCPP_INLINE_VISIBILITY 5431 bool operator()( weak_ptr<_Tp> const& __x, weak_ptr<_Up> const& __y) const 5432 {return __x.owner_before(__y);} 5433 typedef void is_transparent; 5434}; 5435#endif 5436 5437template<class _Tp> 5438class _LIBCPP_TEMPLATE_VIS enable_shared_from_this 5439{ 5440 mutable weak_ptr<_Tp> __weak_this_; 5441protected: 5442 _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR 5443 enable_shared_from_this() _NOEXCEPT {} 5444 _LIBCPP_INLINE_VISIBILITY 5445 enable_shared_from_this(enable_shared_from_this const&) _NOEXCEPT {} 5446 _LIBCPP_INLINE_VISIBILITY 5447 enable_shared_from_this& operator=(enable_shared_from_this const&) _NOEXCEPT 5448 {return *this;} 5449 _LIBCPP_INLINE_VISIBILITY 5450 ~enable_shared_from_this() {} 5451public: 5452 _LIBCPP_INLINE_VISIBILITY 5453 shared_ptr<_Tp> shared_from_this() 5454 {return shared_ptr<_Tp>(__weak_this_);} 5455 _LIBCPP_INLINE_VISIBILITY 5456 shared_ptr<_Tp const> shared_from_this() const 5457 {return shared_ptr<const _Tp>(__weak_this_);} 5458 5459#if _LIBCPP_STD_VER > 14 5460 _LIBCPP_INLINE_VISIBILITY 5461 weak_ptr<_Tp> weak_from_this() _NOEXCEPT 5462 { return __weak_this_; } 5463 5464 _LIBCPP_INLINE_VISIBILITY 5465 weak_ptr<const _Tp> weak_from_this() const _NOEXCEPT 5466 { return __weak_this_; } 5467#endif // _LIBCPP_STD_VER > 14 5468 5469 template <class _Up> friend class shared_ptr; 5470}; 5471 5472template <class _Tp> 5473struct _LIBCPP_TEMPLATE_VIS hash<shared_ptr<_Tp> > 5474{ 5475 typedef shared_ptr<_Tp> argument_type; 5476 typedef size_t result_type; 5477 _LIBCPP_INLINE_VISIBILITY 5478 result_type operator()(const argument_type& __ptr) const _NOEXCEPT 5479 { 5480 return hash<_Tp*>()(__ptr.get()); 5481 } 5482}; 5483 5484template<class _CharT, class _Traits, class _Yp> 5485inline _LIBCPP_INLINE_VISIBILITY 5486basic_ostream<_CharT, _Traits>& 5487operator<<(basic_ostream<_CharT, _Traits>& __os, shared_ptr<_Yp> const& __p); 5488 5489 5490#if !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 5491 5492class _LIBCPP_TYPE_VIS __sp_mut 5493{ 5494 void* __lx; 5495public: 5496 void lock() _NOEXCEPT; 5497 void unlock() _NOEXCEPT; 5498 5499private: 5500 _LIBCPP_CONSTEXPR __sp_mut(void*) _NOEXCEPT; 5501 __sp_mut(const __sp_mut&); 5502 __sp_mut& operator=(const __sp_mut&); 5503 5504 friend _LIBCPP_FUNC_VIS __sp_mut& __get_sp_mut(const void*); 5505}; 5506 5507_LIBCPP_FUNC_VIS __sp_mut& __get_sp_mut(const void*); 5508 5509template <class _Tp> 5510inline _LIBCPP_INLINE_VISIBILITY 5511bool 5512atomic_is_lock_free(const shared_ptr<_Tp>*) 5513{ 5514 return false; 5515} 5516 5517template <class _Tp> 5518shared_ptr<_Tp> 5519atomic_load(const shared_ptr<_Tp>* __p) 5520{ 5521 __sp_mut& __m = __get_sp_mut(__p); 5522 __m.lock(); 5523 shared_ptr<_Tp> __q = *__p; 5524 __m.unlock(); 5525 return __q; 5526} 5527 5528template <class _Tp> 5529inline _LIBCPP_INLINE_VISIBILITY 5530shared_ptr<_Tp> 5531atomic_load_explicit(const shared_ptr<_Tp>* __p, memory_order) 5532{ 5533 return atomic_load(__p); 5534} 5535 5536template <class _Tp> 5537void 5538atomic_store(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r) 5539{ 5540 __sp_mut& __m = __get_sp_mut(__p); 5541 __m.lock(); 5542 __p->swap(__r); 5543 __m.unlock(); 5544} 5545 5546template <class _Tp> 5547inline _LIBCPP_INLINE_VISIBILITY 5548void 5549atomic_store_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r, memory_order) 5550{ 5551 atomic_store(__p, __r); 5552} 5553 5554template <class _Tp> 5555shared_ptr<_Tp> 5556atomic_exchange(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r) 5557{ 5558 __sp_mut& __m = __get_sp_mut(__p); 5559 __m.lock(); 5560 __p->swap(__r); 5561 __m.unlock(); 5562 return __r; 5563} 5564 5565template <class _Tp> 5566inline _LIBCPP_INLINE_VISIBILITY 5567shared_ptr<_Tp> 5568atomic_exchange_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp> __r, memory_order) 5569{ 5570 return atomic_exchange(__p, __r); 5571} 5572 5573template <class _Tp> 5574bool 5575atomic_compare_exchange_strong(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, shared_ptr<_Tp> __w) 5576{ 5577 shared_ptr<_Tp> __temp; 5578 __sp_mut& __m = __get_sp_mut(__p); 5579 __m.lock(); 5580 if (__p->__owner_equivalent(*__v)) 5581 { 5582 _VSTD::swap(__temp, *__p); 5583 *__p = __w; 5584 __m.unlock(); 5585 return true; 5586 } 5587 _VSTD::swap(__temp, *__v); 5588 *__v = *__p; 5589 __m.unlock(); 5590 return false; 5591} 5592 5593template <class _Tp> 5594inline _LIBCPP_INLINE_VISIBILITY 5595bool 5596atomic_compare_exchange_weak(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, shared_ptr<_Tp> __w) 5597{ 5598 return atomic_compare_exchange_strong(__p, __v, __w); 5599} 5600 5601template <class _Tp> 5602inline _LIBCPP_INLINE_VISIBILITY 5603bool 5604atomic_compare_exchange_strong_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, 5605 shared_ptr<_Tp> __w, memory_order, memory_order) 5606{ 5607 return atomic_compare_exchange_strong(__p, __v, __w); 5608} 5609 5610template <class _Tp> 5611inline _LIBCPP_INLINE_VISIBILITY 5612bool 5613atomic_compare_exchange_weak_explicit(shared_ptr<_Tp>* __p, shared_ptr<_Tp>* __v, 5614 shared_ptr<_Tp> __w, memory_order, memory_order) 5615{ 5616 return atomic_compare_exchange_weak(__p, __v, __w); 5617} 5618 5619#endif // !defined(_LIBCPP_HAS_NO_ATOMIC_HEADER) 5620 5621//enum class 5622#if defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) 5623# ifndef _LIBCPP_CXX03_LANG 5624enum class pointer_safety : unsigned char { 5625 relaxed, 5626 preferred, 5627 strict 5628}; 5629# endif 5630#else 5631struct _LIBCPP_TYPE_VIS pointer_safety 5632{ 5633 enum __lx 5634 { 5635 relaxed, 5636 preferred, 5637 strict 5638 }; 5639 5640 __lx __v_; 5641 5642 _LIBCPP_INLINE_VISIBILITY 5643 pointer_safety() : __v_() {} 5644 5645 _LIBCPP_INLINE_VISIBILITY 5646 pointer_safety(__lx __v) : __v_(__v) {} 5647 _LIBCPP_INLINE_VISIBILITY 5648 operator int() const {return __v_;} 5649}; 5650#endif 5651 5652#if !defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) && \ 5653 defined(_LIBCPP_BUILDING_MEMORY) 5654_LIBCPP_FUNC_VIS pointer_safety get_pointer_safety() _NOEXCEPT; 5655#else 5656// This function is only offered in C++03 under ABI v1. 5657# if !defined(_LIBCPP_ABI_POINTER_SAFETY_ENUM_TYPE) || !defined(_LIBCPP_CXX03_LANG) 5658inline _LIBCPP_INLINE_VISIBILITY 5659pointer_safety get_pointer_safety() _NOEXCEPT { 5660 return pointer_safety::relaxed; 5661} 5662# endif 5663#endif 5664 5665 5666_LIBCPP_FUNC_VIS void declare_reachable(void* __p); 5667_LIBCPP_FUNC_VIS void declare_no_pointers(char* __p, size_t __n); 5668_LIBCPP_FUNC_VIS void undeclare_no_pointers(char* __p, size_t __n); 5669_LIBCPP_FUNC_VIS void* __undeclare_reachable(void* __p); 5670 5671template <class _Tp> 5672inline _LIBCPP_INLINE_VISIBILITY 5673_Tp* 5674undeclare_reachable(_Tp* __p) 5675{ 5676 return static_cast<_Tp*>(__undeclare_reachable(__p)); 5677} 5678 5679_LIBCPP_FUNC_VIS void* align(size_t __align, size_t __sz, void*& __ptr, size_t& __space); 5680 5681// --- Helper for container swap -- 5682template <typename _Alloc> 5683inline _LIBCPP_INLINE_VISIBILITY 5684void __swap_allocator(_Alloc & __a1, _Alloc & __a2) 5685#if _LIBCPP_STD_VER >= 14 5686 _NOEXCEPT 5687#else 5688 _NOEXCEPT_(__is_nothrow_swappable<_Alloc>::value) 5689#endif 5690{ 5691 __swap_allocator(__a1, __a2, 5692 integral_constant<bool, _VSTD::allocator_traits<_Alloc>::propagate_on_container_swap::value>()); 5693} 5694 5695template <typename _Alloc> 5696_LIBCPP_INLINE_VISIBILITY 5697void __swap_allocator(_Alloc & __a1, _Alloc & __a2, true_type) 5698#if _LIBCPP_STD_VER >= 14 5699 _NOEXCEPT 5700#else 5701 _NOEXCEPT_(__is_nothrow_swappable<_Alloc>::value) 5702#endif 5703{ 5704 using _VSTD::swap; 5705 swap(__a1, __a2); 5706} 5707 5708template <typename _Alloc> 5709inline _LIBCPP_INLINE_VISIBILITY 5710void __swap_allocator(_Alloc &, _Alloc &, false_type) _NOEXCEPT {} 5711 5712template <typename _Alloc, typename _Traits=allocator_traits<_Alloc> > 5713struct __noexcept_move_assign_container : public integral_constant<bool, 5714 _Traits::propagate_on_container_move_assignment::value 5715#if _LIBCPP_STD_VER > 14 5716 || _Traits::is_always_equal::value 5717#else 5718 && is_nothrow_move_assignable<_Alloc>::value 5719#endif 5720 > {}; 5721 5722 5723#ifndef _LIBCPP_HAS_NO_VARIADICS 5724template <class _Tp, class _Alloc> 5725struct __temp_value { 5726 typedef allocator_traits<_Alloc> _Traits; 5727 5728 typename aligned_storage<sizeof(_Tp), alignof(_Tp)>::type __v; 5729 _Alloc &__a; 5730 5731 _Tp *__addr() { return reinterpret_cast<_Tp *>(addressof(__v)); } 5732 _Tp & get() { return *__addr(); } 5733 5734 template<class... _Args> 5735 __temp_value(_Alloc &__alloc, _Args&& ... __args) : __a(__alloc) 5736 { _Traits::construct(__a, __addr(), _VSTD::forward<_Args>(__args)...); } 5737 5738 ~__temp_value() { _Traits::destroy(__a, __addr()); } 5739 }; 5740#endif 5741 5742_LIBCPP_END_NAMESPACE_STD 5743 5744#endif // _LIBCPP_MEMORY 5745