13 #ifndef ZYPP_BASE_PTRTYPES_H
14 #define ZYPP_BASE_PTRTYPES_H
19 #include <boost/scoped_ptr.hpp>
20 #include <boost/shared_ptr.hpp>
21 #include <boost/weak_ptr.hpp>
22 #include <boost/intrusive_ptr.hpp>
31 std::string
form(
const char * format, ... ) __attribute__ ((format (printf, 1, 2)));
89 using boost::scoped_ptr;
92 using boost::shared_ptr;
95 using boost::weak_ptr;
98 using boost::intrusive_ptr;
101 using boost::static_pointer_cast;
103 using boost::const_pointer_cast;
105 using boost::dynamic_pointer_cast;
126 inline std::ostream & operator<<( std::ostream & str, const zypp::shared_ptr<_D> & obj )
130 return str << std::string(
"NULL");
134 inline std::ostream & operator<<( std::ostream & str, const zypp::shared_ptr<void> & obj )
138 return str << std::string(
"NULL");
143 inline std::ostream &
dumpOn( std::ostream & str,
const zypp::shared_ptr<_D> & obj )
146 return dumpOn( str, *obj );
147 return str << std::string(
"NULL");
151 inline std::ostream &
dumpOn( std::ostream & str,
const zypp::shared_ptr<void> & obj )
152 {
return str << obj; }
156 inline std::ostream & operator<<( std::ostream & str, const zypp::intrusive_ptr<_D> & obj )
160 return str << std::string(
"NULL");
164 inline std::ostream &
dumpOn( std::ostream & str,
const zypp::intrusive_ptr<_D> & obj )
167 return dumpOn( str, *obj );
168 return str << std::string(
"NULL");
187 namespace rw_pointer {
196 {
return !ptr_r || ptr_r.unique(); }
198 {
return !ptr_r || ptr_r.unique(); }
201 {
return ptr_r.use_count(); }
203 {
return ptr_r.use_count(); }
209 typedef intrusive_ptr<_D>
_Ptr;
213 {
return !ptr_r || (ptr_r->refCount() <= 1); }
215 {
return !ptr_r || (ptr_r->refCount() <= 1); }
218 {
return ptr_r ? ptr_r->refCount() : 0; }
220 {
return ptr_r ? ptr_r->refCount() : 0; }
235 {
return ptr_r ? 1 : 0; }
237 {
return ptr_r ? 1 : 0; }
284 template<
class _D,
class _Traits = rw_po
inter::Shared<_D> >
287 typedef typename _Traits::_Ptr
_Ptr;
307 {
reset();
return *
this; }
312 void reset(
typename _Ptr::element_type * dptr )
319 {
_dptr.swap( rhs ); }
322 {
return _dptr.get() !=
nullptr; }
328 {
return _dptr.operator->(); }
330 const _D *
get()
const
331 {
return _dptr.get(); }
337 {
return _dptr.operator->(); }
340 {
return _dptr.get(); }
344 {
return _Traits().unique(
_dptr ); }
347 {
return _Traits().use_count(
_dptr ); }
368 template<
class _D,
class _Ptr>
369 inline std::ostream & operator<<( std::ostream & str, const RW_pointer<_D, _Ptr> & obj )
372 return str << *obj.get();
373 return str << std::string(
"NULL");
377 template<
class _D,
class _Ptr>
379 {
return( lhs.
get() == rhs.
get() ); }
381 template<
class _D,
class _Ptr>
383 {
return( lhs.
get() == rhs.get() ); }
385 template<
class _D,
class _Ptr>
387 {
return( lhs.get() == rhs.
get() ); }
389 template<
class _D,
class _Ptr>
391 {
return( lhs.
get() == rhs.get() ); }
393 template<
class _D,
class _Ptr>
395 {
return( lhs.get() == rhs.
get() ); }
397 template<
class _D,
class _Ptr>
401 template<
class _D,
class _Ptr>
403 {
return(
nullptr == rhs.
get() ); }
407 template<
class _D,
class _Ptr>
409 {
return ! ( lhs == rhs ); }
411 template<
class _D,
class _Ptr>
413 {
return ! ( lhs == rhs ); }
415 template<
class _D,
class _Ptr>
417 {
return ! ( lhs == rhs ); }
419 template<
class _D,
class _Ptr>
421 {
return ! ( lhs == rhs ); }
423 template<
class _D,
class _Ptr>
425 {
return ! ( lhs == rhs ); }
427 template<
class _D,
class _Ptr>
431 template<
class _D,
class _Ptr>
433 {
return(
nullptr != rhs.
get() ); }
444 {
return rhs->clone(); }
457 template<
class _D,
class _Traits = rw_po
inter::Shared<_D> >
460 typedef typename _Traits::_Ptr
_Ptr;
480 {
reset();
return *
this; }
485 void reset(
typename _Ptr::element_type * dptr )
492 {
_dptr.swap( rhs ); }
495 {
return _dptr.get() !=
nullptr; }
501 {
return _dptr.operator->(); }
503 const _D *
get()
const
504 {
return _dptr.get(); }
517 {
return _Traits().unique(
_dptr ); }
520 {
return _Traits().use_count(
_dptr ); }
549 template<
class _D,
class _Ptr>
550 inline std::ostream & operator<<( std::ostream & str, const RWCOW_pointer<_D, _Ptr> & obj )
553 return str << *obj.get();
554 return str << std::string(
"NULL");
558 template<
class _D,
class _Ptr>
560 {
return( lhs.
get() == rhs.
get() ); }
562 template<
class _D,
class _Ptr>
564 {
return( lhs.
get() == rhs.get() ); }
566 template<
class _D,
class _Ptr>
568 {
return( lhs.get() == rhs.
get() ); }
570 template<
class _D,
class _Ptr>
572 {
return( lhs.
get() == rhs.get() ); }
574 template<
class _D,
class _Ptr>
576 {
return( lhs.get() == rhs.
get() ); }
578 template<
class _D,
class _Ptr>
582 template<
class _D,
class _Ptr>
584 {
return(
nullptr == rhs.
get() ); }
587 template<
class _D,
class _Ptr>
589 {
return ! ( lhs == rhs ); }
591 template<
class _D,
class _Ptr>
593 {
return ! ( lhs == rhs ); }
595 template<
class _D,
class _Ptr>
597 {
return ! ( lhs == rhs ); }
599 template<
class _D,
class _Ptr>
601 {
return ! ( lhs == rhs ); }
603 template<
class _D,
class _Ptr>
605 {
return ! ( lhs == rhs ); }
607 template<
class _D,
class _Ptr>
611 template<
class _D,
class _Ptr>
613 {
return(
nullptr != rhs.
get() ); }
623 #define DEFINE_PTR_TYPE(NAME) \
625 extern void intrusive_ptr_add_ref( const NAME * ); \
626 extern void intrusive_ptr_release( const NAME * ); \
627 typedef zypp::intrusive_ptr<NAME> NAME##_Ptr; \
628 typedef zypp::intrusive_ptr<const NAME> NAME##_constPtr;
631 #endif // ZYPP_BASE_PTRTYPES_H
bool operator!=(const RW_pointer< _D, _Ptr > &lhs, const RW_pointer< _D, _Ptr > &rhs)
bool operator!=(const RWCOW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_Ptr &rhs)
bool operator!=(const RWCOW_pointer< _D, _Ptr > &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator==(const RW_pointer< _D, _Ptr > &lhs, const RW_pointer< _D, _Ptr > &rhs)
bool unique(const _Ptr &ptr_r)
RWCOW_pointer & operator=(std::nullptr_t)
bool operator==(const RW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_constPtr &rhs)
bool operator!=(const typename _Ptr::_constPtr &lhs, const RW_pointer< _D, _Ptr > &rhs)
bool operator==(const RWCOW_pointer< _D, _Ptr > &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator==(const typename _Ptr::_constPtr &lhs, const RW_pointer< _D, _Ptr > &rhs)
long use_count(const _constPtr &ptr_r) const
Return number of references.
bool operator!=(const typename _Ptr::_Ptr &lhs, const RW_pointer< _D, _Ptr > &rhs)
const _D & operator*() const
RW_pointer(std::nullptr_t)
std::ostream & dumpOn(std::ostream &str, const zypp::shared_ptr< void > &obj)
bool unique(const _constPtr &ptr_r)
Check whether pointer is not shared.
bool operator==(const typename _Ptr::_Ptr &lhs, const RW_pointer< _D, _Ptr > &rhs)
bool unique(const _constPtr &ptr_r)
Check whether pointer is not shared.
bool operator!=(const RW_pointer< _D, _Ptr > &lhs, std::nullptr_t)
std::string form(const char *format,...) __attribute__((format(printf
Printf style construction of std::string.
void reset(typename _Ptr::element_type *dptr)
void reset(typename _Ptr::element_type *dptr)
bool operator==(const RWCOW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_constPtr &rhs)
_Traits::_constPtr _constPtr
RW_pointer & operator=(std::nullptr_t)
RW_pointer(typename _Ptr::element_type *dptr)
bool operator==(std::nullptr_t, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator!=(const RWCOW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_constPtr &rhs)
bool unique(const _Ptr &ptr_r)
bool unique(const _constPtr &ptr_r)
Check whether pointer is not shared.
long use_count(const _Ptr &ptr_r) const
bool operator!=(const RW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_constPtr &rhs)
bool operator==(const typename _Ptr::_Ptr &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator!=(std::nullptr_t, const RW_pointer< _D, _Ptr > &rhs)
long use_count(const _constPtr &ptr_r) const
Return number of references.
shared_ptr< const _D > _constPtr
const _D & operator*() const
RWCOW_pointer(std::nullptr_t)
bool operator==(const typename _Ptr::_constPtr &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator!=(const typename _Ptr::_constPtr &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
shared_ptr custom deleter doing nothing.
Wrapper for const correct access via Smart pointer types.
bool operator==(const RWCOW_pointer< _D, _Ptr > &lhs, std::nullptr_t)
void swap(RW_pointer &rhs)
bool operator!=(const RWCOW_pointer< _D, _Ptr > &lhs, std::nullptr_t)
long use_count(const _Ptr &ptr_r) const
void swap(RWCOW_pointer &rhs)
scoped_ptr< const _D > _constPtr
_Traits::_constPtr _constPtr
const _D * operator->() const
bool operator!=(const typename _Ptr::_Ptr &lhs, const RWCOW_pointer< _D, _Ptr > &rhs)
long use_count(const _Ptr &ptr_r) const
const _D * operator->() const
intrusive_ptr< const _D > _constPtr
bool operator!=(const RW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_Ptr &rhs)
bool operator==(const RW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_Ptr &rhs)
bool unique(const _Ptr &ptr_r)
long use_count(const _constPtr &ptr_r) const
Return number of references.
bool operator==(std::nullptr_t, const RW_pointer< _D, _Ptr > &rhs)
bool operator!=(std::nullptr_t, const RWCOW_pointer< _D, _Ptr > &rhs)
bool operator==(const RW_pointer< _D, _Ptr > &lhs, std::nullptr_t)
_D * rwcowClone(const _D *rhs)
bool operator==(const RWCOW_pointer< _D, _Ptr > &lhs, const typename _Ptr::_Ptr &rhs)
RW_pointer supporting 'copy on write' functionality.
RWCOW_pointer(typename _Ptr::element_type *dptr)
void operator()(const void *const ) const