| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 | // Copyright David Abrahams 2002.// Distributed under the Boost Software License, Version 1.0. (See// accompanying file LICENSE_1_0.txt or copy at// http://www.boost.org/LICENSE_1_0.txt)#ifndef TO_PYTHON_INDIRECT_DWA200221_HPP# define TO_PYTHON_INDIRECT_DWA200221_HPP# include <boost/python/detail/prefix.hpp># include <boost/python/object/pointer_holder.hpp># include <boost/python/object/make_ptr_instance.hpp># include <boost/python/detail/none.hpp>#ifndef BOOST_PYTHON_NO_PY_SIGNATURES# include <boost/python/converter/pytype_function.hpp>#endif# include <boost/python/refcount.hpp># include <boost/python/detail/type_traits.hpp># if defined(__ICL) && __ICL < 600 #  include <boost/shared_ptr.hpp># else #  include <memory># endifnamespace boost { namespace python {template <class T, class MakeHolder>struct to_python_indirect{    template <class U>    inline PyObject*    operator()(U const& ref) const    {        return this->execute(const_cast<U&>(ref), detail::is_pointer<U>());    }#ifndef BOOST_PYTHON_NO_PY_SIGNATURES    inline PyTypeObject const*    get_pytype()const    {        return converter::registered_pytype<T>::get_pytype();    }#endif private:    template <class U>    inline PyObject* execute(U* ptr, detail::true_) const    {        // No special NULL treatment for references        if (ptr == 0)            return python::detail::none();        else            return this->execute(*ptr, detail::false_());    }        template <class U>    inline PyObject* execute(U const& x, detail::false_) const    {        U* const p = &const_cast<U&>(x);        if (detail::is_polymorphic<U>::value)        {            if (PyObject* o = detail::wrapper_base_::owner(p))                return incref(o);        }        return MakeHolder::execute(p);    }};//// implementations//namespace detail{  struct make_owning_holder  {      template <class T>      static PyObject* execute(T* p)      {          // can't use auto_ptr with Intel 5 and VC6 Dinkum library          // for some reason. We get link errors against the auto_ptr          // copy constructor.# if defined(__ICL) && __ICL < 600           typedef boost::shared_ptr<T> smart_pointer;# elif defined(BOOST_NO_CXX11_SMART_PTR)          typedef std::auto_ptr<T> smart_pointer;# else          typedef std::unique_ptr<T> smart_pointer;# endif          typedef objects::pointer_holder<smart_pointer, T> holder_t;          smart_pointer ptr(const_cast<T*>(p));          return objects::make_ptr_instance<T, holder_t>::execute(ptr);      }  };  struct make_reference_holder  {      template <class T>      static PyObject* execute(T* p)      {          typedef objects::pointer_holder<T*, T> holder_t;          T* q = const_cast<T*>(p);          return objects::make_ptr_instance<T, holder_t>::execute(q);      }  };}}} // namespace boost::python#endif // TO_PYTHON_INDIRECT_DWA200221_HPP
 |