// please note that this replacement implementation does not
// provide the performance benefit of the original, which
// makes only one allocation as opposed to two allocations
// (smart pointer counter and payload) which are usually
// required if object and smart pointer are constructed
// independently.

#ifndef INCLUDED_AI_BOOST_MAKE_SHARED
#define INCLUDED_AI_BOOST_MAKE_SHARED


namespace boost {

	template <typename T>
	shared_ptr<T> make_shared() {
		return shared_ptr<T>(new T());
	}

	template <typename T, typename T0>
	shared_ptr<T> make_shared(const T0& t0) {
		return shared_ptr<T>(new T(t0));
	}

	template <typename T, typename T0,typename T1>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1) {
		return shared_ptr<T>(new T(t0,t1));
	}

	template <typename T, typename T0,typename T1,typename T2>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1, const T2& t2) {
		return shared_ptr<T>(new T(t0,t1,t2));
	}

	template <typename T, typename T0,typename T1,typename T2,typename T3>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1, const T2& t2, const T3& t3) {
		return shared_ptr<T>(new T(t0,t1,t2,t3));
	}

	template <typename T, typename T0,typename T1,typename T2,typename T3, typename T4>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1, const T2& t2, const T3& t3, const T4& t4) {
		return shared_ptr<T>(new T(t0,t1,t2,t3,t4));
	}

	template <typename T, typename T0,typename T1,typename T2,typename T3, typename T4, typename T5>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1, const T2& t2, const T3& t3, const T4& t4, const T5& t5) {
		return shared_ptr<T>(new T(t0,t1,t2,t3,t4,t5));
	}

	template <typename T, typename T0,typename T1,typename T2,typename T3, typename T4, typename T5, typename T6>
	shared_ptr<T> make_shared(const T0& t0, const T1& t1, const T2& t2, const T3& t3, const T4& t4, const T5& t5, const T6& t6) {
		return shared_ptr<T>(new T(t0,t1,t2,t3,t4,t5,t6));
	}
}


#endif