#if !defined(BOOST_PP_IS_ITERATING) // 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 SIGNATURE_DWA20021121_HPP # define SIGNATURE_DWA20021121_HPP # include # include # include # include # include # include # include # include namespace boost { namespace python { namespace detail { struct signature_element { char const* basename; converter::pytype_function pytype_f; bool lvalue; }; struct py_func_sig_info { signature_element const *signature; signature_element const *ret; }; template struct signature_arity; # define BOOST_PP_ITERATION_PARAMS_1 \ (3, (0, BOOST_PYTHON_MAX_ARITY + 1, )) # include BOOST_PP_ITERATE() // A metafunction returning the base class used for // // signature. // template struct signature_base_select { enum { arity = mpl::size::value - 1 }; typedef typename signature_arity::template impl type; }; template struct signature : signature_base_select::type { }; }}} // namespace boost::python::detail # endif // SIGNATURE_DWA20021121_HPP #else # define N BOOST_PP_ITERATION() template <> struct signature_arity { template struct impl { static signature_element const* elements() { static signature_element const result[N+2] = { #ifndef BOOST_PYTHON_NO_PY_SIGNATURES # define BOOST_PP_LOCAL_MACRO(i) \ { \ type_id::type>().name() \ , &converter::expected_pytype_for_arg::type>::get_pytype \ , indirect_traits::is_reference_to_non_const::type>::value \ }, #else # define BOOST_PP_LOCAL_MACRO(i) \ { \ type_id::type>().name() \ , 0 \ , indirect_traits::is_reference_to_non_const::type>::value \ }, #endif # define BOOST_PP_LOCAL_LIMITS (0, N) # include BOOST_PP_LOCAL_ITERATE() {0,0,0} }; return result; } }; }; #endif // BOOST_PP_IS_ITERATING