From 96684b72ca367bfd4dbe2e45a9a66c56204eb533 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Fri, 4 May 2007 11:41:58 +0000 Subject: Added code for converting ledger::string and boost::date_time to their respective Python counterparts. --- src/py_utils.cc | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 src/py_utils.cc (limited to 'src/py_utils.cc') diff --git a/src/py_utils.cc b/src/py_utils.cc new file mode 100644 index 00000000..0f82d683 --- /dev/null +++ b/src/py_utils.cc @@ -0,0 +1,46 @@ +#include "pyinterp.h" +#include "pyutils.h" + +#include +#include +#include + +namespace ledger { + +using namespace boost::python; + +struct string_to_python +{ + static PyObject* convert(const string& str) + { + return incref(object(*boost::polymorphic_downcast(&str)).ptr()); + } +}; + +struct string_from_python +{ + static void* convertible(PyObject* obj_ptr) + { + if (!PyString_Check(obj_ptr)) return 0; + return obj_ptr; + } + + static void construct(PyObject* obj_ptr, converter::rvalue_from_python_stage1_data* data) + { + const char* value = PyString_AsString(obj_ptr); + if (value == 0) throw_error_already_set(); + void* storage = ((converter::rvalue_from_python_storage*) data)->storage.bytes; + new (storage) string(value); + data->convertible = storage; + } +}; + +typedef register_python_conversion + string_python_conversion; + +void export_utils() +{ + string_python_conversion(); +} + +} // namespace ledger -- cgit v1.2.3