35 #if __GNUC__ > 3 && __GNUC_MINOR__ > 6
36 #pragma GCC diagnostic push
37 #pragma GCC diagnostic ignored "-Wdelete-non-virtual-dtor"
41 #pragma clang diagnostic push
42 #pragma clang diagnostic ignored "-Wdelete-non-virtual-dtor"
66template<
typename T >
class shared_ptr;
67template<
typename T >
class weak_ptr;
77 :
public std::exception
80 inline virtual char const *
what()
const throw();
87 return "bad_weak_ptr";
131 assert( n_shared_ptrs == 0 || n_weak_ptrs >= 1 );
157 return n_shared_ptrs ? ++n_shared_ptrs :
false;
171 if( 0 == --n_shared_ptrs )
179 if( 0 == --n_weak_ptrs )
186 assert( n_weak_ptrs == 0 );
194 return n_shared_ptrs;
205template<
typename P >
216 inline void *
operator new ( std::size_t );
217 inline void operator delete (
void * );
220 inline virtual void *
get_deleter( std::type_info
const & );
221 inline virtual void dispose()
throw();
229template<
typename P >
235template<
typename P >
239template<
typename P >
246template<
typename P >
253template<
typename P >
257 return std::allocator<this_type>().allocate( 1 );
260template<
typename P >
264 std::allocator<this_type>().deallocate(
static_cast<this_type*
>(p), 1 );
280 inline void *
operator new ( std::size_t );
281 inline void operator delete (
void * );
284 inline virtual void *
get_deleter( std::type_info
const & );
285 inline virtual void dispose()
throw();
295template<
typename P,
typename D >
302template<
typename P,
typename D >
306template<
typename P,
typename D >
310 deleter( owned_ptr );
313template<
typename P,
typename D >
317 return ti ==
typeid(D) ? &
reinterpret_cast<char&
>( deleter ) : 0;
320template<
typename P,
typename D >
324 return std::allocator<this_type>().allocate( 1 );
327template<
typename P,
typename D >
331 std::allocator<this_type>().deallocate(
static_cast<this_type*
>(p), 1 );
348 inline virtual void *
get_deleter( std::type_info
const & );
349 inline virtual void dispose()
throw();
350 inline virtual void destroy()
throw();
361template<
typename P,
typename D,
typename A >
369template<
typename P,
typename D,
typename A >
373template<
typename P,
typename D,
typename A >
377 deleter( owned_ptr );
380template<
typename P,
typename D,
typename A >
384 typename A::template rebind< this_type >::other this_allocator( allocator );
386 this_allocator.destroy(
this );
387 this_allocator.deallocate(
this, 1 );
390template<
typename P,
typename D,
typename A >
394 return ti ==
typeid( D ) ? &
reinterpret_cast<char&
>( deleter ) : 0;
413 template< typename P >
416 template< typename P, typename D >
418 template< typename P, typename D, typename A >
420 template< typename P >
460template<
typename P >
475template<
typename P,
typename D >
490template<
typename P,
typename D,
typename A >
496 typedef typename A::template rebind<ctrl_block>::other
497 ctrl_block_allocator;
498 ctrl_block_allocator cba( a );
502 acb_ptr = cba.allocate( 1 );
503 new(
static_cast<void*
>(acb_ptr) ) ctrl_block(p, d, a);
509 cba.deallocate(
static_cast<ctrl_block*
>( acb_ptr ), 1 );
514template<
typename P >
531 other.acb_ptr = acb_ptr;
536 : acb_ptr( other.acb_ptr )
550 if( acb_ptr != 0 ) acb_ptr->release();
578 return acb_ptr == 0 ? 0L : acb_ptr->
use_count();
584 return lhs.acb_ptr == rhs.acb_ptr;
590 return std::less<abstract_ctrl_block*>()( lhs.acb_ptr, rhs.acb_ptr );
634 : acb_ptr( other.acb_ptr )
650 other.acb_ptr = acb_ptr;
655 : acb_ptr( other.acb_ptr )
700 return acb_ptr == 0 ? 0L : acb_ptr->
use_count();
706 return lhs.acb_ptr == rhs.acb_ptr;
712 return std::less<abstract_ctrl_block*>()( lhs.acb_ptr, rhs.acb_ptr );
716 : acb_ptr( other.acb_ptr )
724 : acb_ptr( other.acb_ptr )
745template<
typename T >
780template<
typename X,
typename Y,
typename T >
788 pe->_internal_accept_owner( ppx,
const_cast<Y*
>( py ) );
791template<
typename X,
typename Y,
typename T >
799 pe->_internal_accept_owner( ppx,
const_cast<Y*
>( py ) );
813template<
typename P >
827 template< typename P2 >
830 template< typename P2, typename D >
832 template< typename P2, typename D, typename A >
840 template< typename P2 >
843 template< typename P2 >
845 template< typename P2 >
847 template< typename P2 >
849 template< typename P2 >
851 template< typename P2 >
853 template< typename P2 >
855 template< typename P2 >
858 template< typename AP >
863 template< typename P2 >
868 template< typename P2 >
870 template< typename P2 >
872 template< typename AP >
878 template< typename P2 >
880 template< typename P2, typename D >
882 template< typename P2, typename D, typename A >
884 template< typename P2 >
898 template< typename P2 >
906 sp::shared_ctrl_handle pn;
910template< typename P, typename P2 >
912template< typename P, typename P2 >
914template< typename P, typename P2 >
917template< typename P >
920template< typename P, typename P2 >
922template< typename P, typename P2 >
924template< typename P, typename P2 >
927template< typename P >
929template< typename D, typename P >
932template< typename C, typename T, typename P >
933 inline std::basic_ostream<C,T> & operator << ( std::basic_ostream<C,T> &
937template< typename P >
943template<
typename P >
944template<
typename P2 >
952template<
typename P >
953template<
typename P2,
typename D >
961template<
typename P >
962template<
typename P2,
typename D,
typename A >
970template<
typename P >
974 std::swap( px, other.px );
978template<
typename P >
986template<
typename P >
987template<
typename P2 >
995template<
typename P >
996template<
typename P2 >
1007template<
typename P >
1008template<
typename P2 >
1016template<
typename P >
1017template<
typename P2 >
1025template<
typename P >
1026template<
typename P2 >
1034template<
typename P >
1035template<
typename P2 >
1046template<
typename P >
1047template<
typename P2 >
1055 throw std::bad_cast();
1058template<
typename P >
1059template<
typename P2 >
1064 P2 * tmp = other.get();
1069template<
typename P >
1070template<
typename AP >
1077 typename AP::element_type * tmp = other.get();
1082template<
typename P >
1083template<
typename P2 >
1091template<
typename P >
1092template<
typename P2 >
1100template<
typename P >
1101template<
typename P2 >
1109template<
typename P >
1110template<
typename AP >
1118template<
typename P >
1125template<
typename P >
1126template<
typename P2 >
1130 assert( p == 0 || p != px );
1134template<
typename P >
1135template<
typename P2,
typename D >
1142template<
typename P >
1143template<
typename P2,
typename D,
typename A >
1150template<
typename P >
1151template<
typename P2 >
1158template<
typename P >
1164template<
typename P >
1173template<
typename P >
1181template<
typename P >
1188template<
typename P >
1195template<
typename P >
1199 return pn.use_count();
1202template<
typename P >
1203template<
typename P2 >
1210template<
typename P >
1214 return pn.get_deleter( ti );
1217template<
typename P >
1221 return px == other.px && pn == other.pn;
1224template<
typename P,
typename P2 >
1228 return a.
get() == b.
get();
1231template<
typename P,
typename P2 >
1235 return a.
get() != b.
get();
1238template<
typename P,
typename P2 >
1245template<
typename P >
1252template<
typename P,
typename P2 >
1259template<
typename P,
typename P2 >
1266template<
typename P,
typename P2 >
1273template<
typename P >
1280template<
typename D,
typename P >
1287template<
typename C,
typename T,
typename P >
1288 std::basic_ostream<C,T> &
1289 operator << ( std::basic_ostream<C,T> & os, shared_ptr<P>
const & p )
1300template<
typename P >
1316 template< typename P2 >
1321 template< typename P2 >
1326 template< typename P2 >
1328 template< typename P2 >
1340 template< typename P2 >
1345 sp::weak_ctrl_handle pn;
1349template< typename P, typename P2 >
1352template< typename P >
1355template< typename P >
1361template<
typename P >
1362template<
typename P2 >
1366 : px( r.lock().get() )
1370template<
typename P >
1371template<
typename P2 >
1379template<
typename P >
1380template<
typename P2 >
1384 px = r.lock().get();
1389template<
typename P >
1390template<
typename P2 >
1399template<
typename P >
1406template<
typename P >
1413template<
typename P >
1420template<
typename P >
1427template<
typename P >
1434template<
typename P >
1438 std::swap(px, other.px);
1442template<
typename P >
1450template<
typename P >
1451template<
typename P2 >
1458template<
typename P,
typename P2 >
1465template<
typename P >
1478 inline void operator () (
void const * )
const;
1500template<
typename T >
1501 class enable_shared_from_this
1504 enable_shared_from_this()
1507 ~enable_shared_from_this()
1510 enable_shared_from_this( enable_shared_from_this
const & )
1513 enable_shared_from_this &
1514 operator = ( enable_shared_from_this
const & )
1523 shared_ptr<T> p( weak_this_ );
1524 assert( p.get() ==
this );
1529 shared_from_this()
const
1531 shared_ptr<T const> p( weak_this_ );
1532 assert( p.get() ==
this );
1539 template<
typename X,
typename Y >
1541 _internal_accept_owner( shared_ptr<X>
const * ppx, Y * py )
const
1543 if( weak_this_.expired() )
1544 weak_this_ = shared_ptr<T>( *ppx, py );
1548 mutable weak_ptr<T> weak_this_;
1557class esft2_deleter_wrapper
1560 shared_ptr<void> deleter_;
1563 esft2_deleter_wrapper()
1566 template<
typename T >
1568 set_deleter( shared_ptr<T>
const & deleter )
1573 template<
typename T >
1577 assert( deleter_.use_count() <= 1 );
1584template<
typename T >
1585 class enable_shared_from_this2
1589 enable_shared_from_this2()
1592 enable_shared_from_this2( enable_shared_from_this2
const & )
1595 enable_shared_from_this2 & operator = ( enable_shared_from_this2
const & )
1600 ~enable_shared_from_this2()
1602 assert( shared_this_.use_count() <= 1 );
1606 mutable weak_ptr<T> weak_this_;
1607 mutable shared_ptr<T> shared_this_;
1615 return shared_ptr<T>( weak_this_ );
1619 shared_from_this()
const
1622 return shared_ptr<T>( weak_this_ );
1627 void init_weak_once()
const
1629 if( weak_this_._empty() )
1631 shared_this_.reset(
static_cast< T*
>( 0 )
1632 , detail::esft2_deleter_wrapper()
1634 weak_this_ = shared_this_;
1641 template<
typename X,
typename Y >
1643 _internal_accept_owner( shared_ptr<X> * ppx, Y * py )
const
1647 if( weak_this_.use_count() == 0 )
1648 weak_this_ = shared_ptr<T>( *ppx, py );
1649 else if( shared_this_.use_count() != 0 )
1651 assert( ppx->unique() );
1653 detail::esft2_deleter_wrapper * pd
1654 = boost::get_deleter<detail::esft2_deleter_wrapper>( shared_this_ );
1657 pd->set_deleter( *ppx );
1659 ppx->reset( shared_this_, ppx->get() );
1660 shared_this_.reset();
virtual char const * what() const
bool _internal_less(shared_ptr< P2 > const &) const
reference operator*() const
bool _internal_equiv(shared_ptr const &) const
shared_ptr & operator=(shared_ptr const &)
void * _internal_get_deleter(std::type_info const &) const
void swap(shared_ptr< P > &)
void class_invariant() const
virtual void * get_deleter(std::type_info const &ti)=0
virtual ~abstract_ctrl_block()
virtual void * get_deleter(std::type_info const &)
virtual void * get_deleter(std::type_info const &)
virtual void * get_deleter(std::type_info const &)
ctrl_block_pda(P *, D, A)
void swap(shared_ctrl_handle &)
void * get_deleter(std::type_info const &) const
shared_ctrl_handle & operator=(shared_ctrl_handle const &)
friend bool operator<(weak_ctrl_handle const &, weak_ctrl_handle const &)
friend bool operator==(weak_ctrl_handle const &, weak_ctrl_handle const &)
void swap(weak_ctrl_handle &)
weak_ctrl_handle & operator=(shared_ctrl_handle const &)
void swap(this_type &other)
bool _internal_less(weak_ptr< P2 > const &rhs) const
weak_ptr & operator=(weak_ptr< P2 > const &r)
shared_ptr< P > lock() const
void _internal_assign(P *px2, sp::shared_ctrl_handle const &pn2)
bool operator==(shared_ctrl_handle const &lhs, shared_ctrl_handle const &rhs)
void sp_enable_shared_from_this(shared_ptr< X > const *ppx, Y const *py, enable_shared_from_this< T > const *pe)
bool operator<(shared_ctrl_handle const &lhs, shared_ctrl_handle const &rhs)
shared_ptr< P > dynamic_pointer_cast(shared_ptr< P2 > const &)
P * get_pointer(shared_ptr< P > const &)
bool operator!=(shared_ptr< P > const &, shared_ptr< P2 > const &)
void swap(shared_ptr< P > &, shared_ptr< P > &)
shared_ptr< P > static_pointer_cast(shared_ptr< P2 > const &)
bool operator<(shared_ptr< P > const &, shared_ptr< P2 > const &)
bool operator==(shared_ptr< P > const &, shared_ptr< P2 > const &)
shared_ptr< P > const_pointer_cast(shared_ptr< P2 > const &)
D * get_deleter(shared_ptr< P > const &)
std::ostream & operator<<(std::ostream &os, const HepRandom &dist)
void operator()(void const *) const