// Copyright David Abrahams 2002. Permission to copy, use, // modify, sell and distribute this software is granted provided this // copyright notice appears in all copies. This software is provided // "as is" without express or implied warranty, and with no claim as // to its suitability for any purpose. #include #include #include #include #include #include #include #include template struct by_value { static T rewrap(T x) { return x; } }; template struct by_const_reference { static T rewrap(T const& x) { return x; } }; template struct by_reference { static T rewrap(T& x) { return x; } }; using boost::python::def; using boost::python::handle; using boost::python::object; using boost::python::borrowed; // Used to test that arbitrary handle<>s can be returned handle get_type(handle<> x) { return handle(borrowed(x->ob_type)); } handle<> return_null_handle() { return handle<>(); } char const* rewrap_value_mutable_cstring(char* x) { return x; } BOOST_PYTHON_MODULE(builtin_converters) { def("get_type", get_type); def("return_null_handle", return_null_handle); def("rewrap_value_bool", by_value::rewrap); def("rewrap_value_char", by_value::rewrap); def("rewrap_value_signed_char", by_value::rewrap); def("rewrap_value_unsigned_char", by_value::rewrap); def("rewrap_value_int", by_value::rewrap); def("rewrap_value_unsigned_int", by_value::rewrap); def("rewrap_value_short", by_value::rewrap); def("rewrap_value_unsigned_short", by_value::rewrap); def("rewrap_value_long", by_value::rewrap); def("rewrap_value_unsigned_long", by_value::rewrap); // using Python's macro instead of Boost's - we don't seem to get the // config right all the time. #ifdef HAVE_LONG_LONG def("rewrap_value_long_long", by_value::rewrap); def("rewrap_value_unsigned_long_long", by_value::rewrap); #endif def("rewrap_value_float", by_value::rewrap); def("rewrap_value_double", by_value::rewrap); def("rewrap_value_long_double", by_value::rewrap); def("rewrap_value_complex_float", by_value >::rewrap); def("rewrap_value_complex_double", by_value >::rewrap); def("rewrap_value_complex_long_double", by_value >::rewrap); def("rewrap_value_string", by_value::rewrap); def("rewrap_value_cstring", by_value::rewrap); def("rewrap_value_handle", by_value >::rewrap); def("rewrap_value_object", by_value::rewrap); // Expose this to illustrate our failings ;-). See test_builtin_converters.py def("rewrap_value_mutable_cstring", rewrap_value_mutable_cstring); def("rewrap_const_reference_bool", by_const_reference::rewrap); def("rewrap_const_reference_char", by_const_reference::rewrap); def("rewrap_const_reference_signed_char", by_const_reference::rewrap); def("rewrap_const_reference_unsigned_char", by_const_reference::rewrap); def("rewrap_const_reference_int", by_const_reference::rewrap); def("rewrap_const_reference_unsigned_int", by_const_reference::rewrap); def("rewrap_const_reference_short", by_const_reference::rewrap); def("rewrap_const_reference_unsigned_short", by_const_reference::rewrap); def("rewrap_const_reference_long", by_const_reference::rewrap); def("rewrap_const_reference_unsigned_long", by_const_reference::rewrap); // using Python's macro instead of Boost's - we don't seem to get the // config right all the time. #ifdef HAVE_LONG_LONG def("rewrap_const_reference_long_long", by_const_reference::rewrap); def("rewrap_const_reference_unsigned_long_long", by_const_reference::rewrap); #endif def("rewrap_const_reference_float", by_const_reference::rewrap); def("rewrap_const_reference_double", by_const_reference::rewrap); def("rewrap_const_reference_long_double", by_const_reference::rewrap); def("rewrap_const_reference_complex_float", by_const_reference >::rewrap); def("rewrap_const_reference_complex_double", by_const_reference >::rewrap); def("rewrap_const_reference_complex_long_double", by_const_reference >::rewrap); def("rewrap_const_reference_string", by_const_reference::rewrap); def("rewrap_const_reference_cstring", by_const_reference::rewrap); def("rewrap_const_reference_handle", by_const_reference >::rewrap); def("rewrap_const_reference_object", by_const_reference::rewrap); def("rewrap_reference_object", by_reference::rewrap); }