blob: 4dfe8d7e90d4d4cebbcfa28ff29f4c27e61c1445 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
#include "pyinterp.h"
#include "pyutils.h"
#include <boost/python/module.hpp>
#include <boost/python/def.hpp>
#include <boost/python/to_python_converter.hpp>
namespace ledger {
using namespace boost::python;
struct bool_to_python
{
static PyObject * convert(const bool truth)
{
if (truth)
Py_RETURN_TRUE;
else
Py_RETURN_FALSE;
}
};
struct bool_from_python
{
static void* convertible(PyObject* obj_ptr)
{
if (!PyBool_Check(obj_ptr)) return 0;
return obj_ptr;
}
static void construct(PyObject* obj_ptr,
converter::rvalue_from_python_stage1_data* data)
{
void* storage = ((converter::rvalue_from_python_storage<bool>*) data)->storage.bytes;
if (obj_ptr == Py_True)
new (storage) bool(true);
else
new (storage) bool(false);
data->convertible = storage;
}
};
typedef register_python_conversion<bool, bool_to_python, bool_from_python>
bool_python_conversion;
struct string_to_python
{
static PyObject* convert(const string& str)
{
return incref(object(*boost::polymorphic_downcast<const std::string *>(&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<string>*) data)->storage.bytes;
new (storage) string(value);
data->convertible = storage;
}
};
typedef register_python_conversion<string, string_to_python, string_from_python>
string_python_conversion;
void export_utils()
{
bool_python_conversion();
string_python_conversion();
}
} // namespace ledger
|