aboutsummaryrefslogtreecommitdiffstats
path: root/common/pybindings.h
diff options
context:
space:
mode:
authorDavid Shah <davey1576@gmail.com>2018-06-07 12:40:31 +0200
committerDavid Shah <davey1576@gmail.com>2018-06-07 12:40:31 +0200
commita5249da02d2a55d4b838dd8c29e159513dd71418 (patch)
treeb290c203607b8d05a4c10e0febde92c027890a3e /common/pybindings.h
parente576f71838290ff12b98145fb02af84563fc03c1 (diff)
downloadnextpnr-a5249da02d2a55d4b838dd8c29e159513dd71418.tar.gz
nextpnr-a5249da02d2a55d4b838dd8c29e159513dd71418.tar.bz2
nextpnr-a5249da02d2a55d4b838dd8c29e159513dd71418.zip
Working on global Python design object
Signed-off-by: David Shah <davey1576@gmail.com>
Diffstat (limited to 'common/pybindings.h')
-rw-r--r--common/pybindings.h53
1 files changed, 40 insertions, 13 deletions
diff --git a/common/pybindings.h b/common/pybindings.h
index 3dfadeee..44898198 100644
--- a/common/pybindings.h
+++ b/common/pybindings.h
@@ -29,12 +29,14 @@
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
#include <boost/python/suite/indexing/map_indexing_suite.hpp>
#include <boost/python/suite/indexing/map_indexing_suite.hpp>
+#include <Python.h>
using namespace boost::python;
/*
A wrapper to enable custom type/ID to/from string conversions
*/
-template <typename T> struct string_wrapper {
+template<typename T>
+struct string_wrapper {
template<typename F>
struct from_pystring_converter {
from_pystring_converter() {
@@ -44,34 +46,37 @@ template <typename T> struct string_wrapper {
boost::python::type_id<T>());
};
- static void* convertible(PyObject* object) {
+ static void *convertible(PyObject *object) {
return PyUnicode_Check(object) ? object : 0;
}
static void construct(
- PyObject* object,
- converter::rvalue_from_python_stage1_data* data) {
- const wchar_t* value = PyUnicode_AsUnicode(object);
+ PyObject *object,
+ converter::rvalue_from_python_stage1_data *data) {
+ const wchar_t *value = PyUnicode_AsUnicode(object);
const std::wstring value_ws(value);
if (value == 0) throw_error_already_set();
- void* storage = (
- (boost::python::converter::rvalue_from_python_storage<T>*)
+ void *storage = (
+ (boost::python::converter::rvalue_from_python_storage<T> *)
data)->storage.bytes;
- new (storage) T(fn(std::string(value_ws.begin(), value_ws.end())));
+ new(storage) T(fn(std::string(value_ws.begin(), value_ws.end())));
data->convertible = storage;
}
- static F fn;
+ static F fn;
};
- template<typename F> struct to_str_wrapper {
+ template<typename F>
+ struct to_str_wrapper {
static F fn;
- std::string str(T& x) {
+
+ std::string str(T &x) {
return fn(x);
}
};
- template<typename F1, typename F2> static void wrap(const char *type_name, F1 to_str_fn, F2 from_str_fn) {
+ template<typename F1, typename F2>
+ static void wrap(const char *type_name, F1 to_str_fn, F2 from_str_fn) {
from_pystring_converter<F2>::fn = from_str_fn;
from_pystring_converter<F2>();
to_str_wrapper<F1>::fn = to_str_fn;
@@ -79,12 +84,34 @@ template <typename T> struct string_wrapper {
};
};
+std::string parse_python_exception();
+
+template<typename Tn>
+void python_export_global(const char *name, Tn &x) {
+ PyObject * m, *d;
+ m = PyImport_AddModule("__main__");
+ if (m == NULL)
+ return;
+ d = PyModule_GetDict(m);
+ try {
+ PyObject * p = object(boost::ref(x)).ptr();
+ PyDict_SetItemString(d, name, p);
+ } catch (boost::python::error_already_set const &) {
+ // Parse and output the exception
+ std::string perror_str = parse_python_exception();
+ std::cout << "Error in Python: " << perror_str << std::endl;
+ std::terminate();
+ }
+};
void init_python(const char *executable);
+
void deinit_python();
-void execute_python_file(const char* python_file);
+void execute_python_file(const char *python_file);
+
std::string parse_python_exception();
+
void arch_appendinittab();
#endif /* end of include guard: COMMON_PYBINDINGS_HH */