| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 | 
#ifndef INCLUDED_AI_BOOST_SHARED_PTR#define INCLUDED_AI_BOOST_SHARED_PTR#ifndef BOOST_SCOPED_PTR_HPP_INCLUDED// ------------------------------// Internal stubnamespace boost {	namespace detail {		class controller {		public:			controller()				: cnt(0)			{}			template <typename T>			controller(T* ptr)				: cnt(ptr?1:0)			{}				public:			template <typename T>			controller* decref(T* pt) {				if (!pt) {					return NULL;				}				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 boost::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> 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(new detail::controller())	{	}	// construction from an existing object of type T	explicit shared_ptr(T* _ptr)		: ptr(_ptr)		, ctr(new detail::controller(ptr))	{	}	template <typename Y>	shared_ptr(const shared_ptr<Y>& o,typename detail::is_convertible<T,Y>::result = detail::empty())		: ptr(o.ptr)		, ctr(o.ctr->incref())	{	}	shared_ptr& operator= (const shared_ptr& r) {		if(r == *this) {			return *this;		}		ctr->decref(ptr);		ctr = r.ctr->incref();		ptr = r.ptr;		return *this;	}	// automatic destruction of the wrapped object when all	// references are freed.	~shared_ptr()	{		ctr = ctr->decref(ptr);	}	// pointer access	inline operator T*()	{		return ptr;	}	inline T* operator-> ()	{		return ptr;	}	// standard semantics	inline T* get()	{		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)	{		ctr = ctr->decref(ptr);		ptr = t;		if(ptr) {			ctr = new detail::controller(ptr);		}	}	void swap(shared_ptr & b)	{		std::swap(ptr, b.ptr);		std::swap(ctr, b.ctr);	}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;}} // end of namespace boost#else#	error "shared_ptr.h was already included"#endif#endif // INCLUDED_AI_BOOST_SCOPED_PTR
 |