| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 | 
#ifndef INCLUDED_AI_BOOST_SHARED_PTR#define INCLUDED_AI_BOOST_SHARED_PTR#ifndef BOOST_SHARED_PTR_HPP_INCLUDED// ------------------------------// Internal stub#include <stddef.h> //NULL#include <algorithm> //std::swapnamespace boost {	namespace detail {		class controller {		public:			controller()				: cnt(1)			{}				public:			template <typename T>			controller* decref(T* pt) {				if (--cnt <= 0) {					delete this;					delete pt;				}				return NULL;			}					controller* incref() {				++cnt;				return this;			}			long get() const {				return cnt;			}		private:			long cnt;		};		struct empty {};				template <typename DEST, typename SRC>		struct is_convertible_stub {						struct yes {char s[1];};			struct no  {char s[2];};			static yes foo(DEST*);			static no  foo(...);			enum {result = (sizeof(foo((SRC*)0)) == sizeof(yes) ? 1 : 0)};			};		template <bool> struct enable_if {};		template <> struct enable_if<true> {			typedef empty result;		};		template <typename DEST, typename SRC>		struct is_convertible : public enable_if<is_convertible_stub<DEST,SRC>::result > {		};	}// ------------------------------// Small replacement for std::shared_ptr, not threadsafe because no// atomic reference counter is in use.// ------------------------------template <class T>class shared_ptr{	template <typename TT> friend class shared_ptr;	template<class TT, class U> friend shared_ptr<TT> static_pointer_cast   (shared_ptr<U> ptr);	template<class TT, class U> friend shared_ptr<TT> dynamic_pointer_cast  (shared_ptr<U> ptr);	template<class TT, class U> friend shared_ptr<TT> const_pointer_cast    (shared_ptr<U> ptr);	template<class TT> friend bool operator== (const shared_ptr<TT>& a, const shared_ptr<TT>& b);	template<class TT> friend bool operator!= (const shared_ptr<TT>& a, const shared_ptr<TT>& b);	template<class TT> friend bool operator<  (const shared_ptr<TT>& a, const shared_ptr<TT>& b);public:	typedef T element_type;public:	// provide a default constructor	shared_ptr()		: ptr()		, ctr(NULL)	{	}	// construction from an existing object of type T	explicit shared_ptr(T* ptr)		: ptr(ptr)		, ctr(ptr ? new detail::controller() : NULL)	{	}	shared_ptr(const shared_ptr& r)		: ptr(r.ptr)		, ctr(r.ctr ? r.ctr->incref() : NULL)	{	}	template <typename Y>	shared_ptr(const shared_ptr<Y>& r,typename detail::is_convertible<T,Y>::result = detail::empty())		: ptr(r.ptr)		, ctr(r.ctr ? r.ctr->incref() : NULL)	{	}	// automatic destruction of the wrapped object when all	// references are freed.	~shared_ptr()	{		if (ctr) {			ctr = ctr->decref(ptr);		}	}	shared_ptr& operator=(const shared_ptr& r) {		if (this == &r) {			return *this;		}		if (ctr) {			ctr->decref(ptr);		}		ptr = r.ptr;		ctr = ptr?r.ctr->incref():NULL;		return *this;	}	template <typename Y>	shared_ptr& operator=(const shared_ptr<Y>& r) {		if (this == &r) {			return *this;		}		if (ctr) {			ctr->decref(ptr);		}		ptr = r.ptr;		ctr = ptr?r.ctr->incref():NULL;		return *this;	}	// pointer access	inline operator T*() const {		return ptr;	}	inline T* operator-> () const	{		return ptr;	}	// standard semantics	inline T* get() {		return ptr;	}	inline const T* get() const	{		return ptr;	}	inline operator bool () const {		return ptr != NULL;	}	inline bool unique() const {		return use_count() == 1;	}	inline long use_count() const {		return ctr->get();	}	inline void reset (T* t = 0)	{		if (ctr) {			ctr->decref(ptr);		}		ptr = t;		ctr = ptr?new detail::controller():NULL;	}	void swap(shared_ptr & b)	{		std::swap(ptr, b.ptr);		std::swap(ctr, b.ctr);	}private:	// for use by the various xxx_pointer_cast helper templates	explicit shared_ptr(T* ptr, detail::controller* ctr)		: ptr(ptr)		, ctr(ctr->incref())	{	}private:	// encapsulated object pointer	T* ptr;	// control block	detail::controller* ctr;};template<class T>inline void swap(shared_ptr<T> & a, shared_ptr<T> & b){	a.swap(b);}template<class T>bool operator== (const shared_ptr<T>& a, const shared_ptr<T>& b) {	return a.ptr == b.ptr;}template<class T>bool operator!= (const shared_ptr<T>& a, const shared_ptr<T>& b) {	return a.ptr != b.ptr;}	template<class T>bool operator< (const shared_ptr<T>& a, const shared_ptr<T>& b) {	return a.ptr < b.ptr;}template<class T, class U>inline shared_ptr<T> static_pointer_cast( shared_ptr<U> ptr){     return shared_ptr<T>(static_cast<T*>(ptr.ptr),ptr.ctr);}template<class T, class U>inline shared_ptr<T> dynamic_pointer_cast( shared_ptr<U> ptr){     return shared_ptr<T>(dynamic_cast<T*>(ptr.ptr),ptr.ctr);}template<class T, class U>inline shared_ptr<T> const_pointer_cast( shared_ptr<U> ptr){     return shared_ptr<T>(const_cast<T*>(ptr.ptr),ptr.ctr);}} // end of namespace boost#else#	error "shared_ptr.h was already included"#endif#endif // INCLUDED_AI_BOOST_SHARED_PTR
 |