X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=python-plugin-provider%2Fpython-plugin-provider.c;h=d32ff8290e929fbe6f066e4d28b2d31a94599092;hb=0cbc2c3316814e4b4bf3fd3ba3b361b165949e95;hp=2404fc7acbdb434064758faa51b88ec2231dd488;hpb=edc733b969ed9b3366f01259fd61dac61b0717e4;p=babeltrace.git diff --git a/python-plugin-provider/python-plugin-provider.c b/python-plugin-provider/python-plugin-provider.c index 2404fc7a..d32ff829 100644 --- a/python-plugin-provider/python-plugin-provider.c +++ b/python-plugin-provider/python-plugin-provider.c @@ -25,12 +25,10 @@ */ #define BT_LOG_TAG "PLUGIN-PY" -#include "logging.h" #include #include -#include -#include +#include #include #include #include @@ -81,7 +79,9 @@ void init_python(void) { PyObject *py_bt2_py_plugin_mod = NULL; const char *dis_python_env; +#ifndef __MINGW32__ sighandler_t old_sigint = signal(SIGINT, SIG_DFL); +#endif if (python_state != PYTHON_STATE_NOT_INITED) { goto end; @@ -128,9 +128,11 @@ void init_python(void) python_state = PYTHON_STATE_FULLY_INITIALIZED; end: +#ifndef __MINGW32__ if (old_sigint != SIG_ERR) { (void) signal(SIGINT, old_sigint); } +#endif print_python_traceback_warn(); pyerr_clear(); @@ -154,9 +156,9 @@ void fini_python(void) { } static -struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) +bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) { - struct bt_plugin *plugin = NULL; + bt_plugin *plugin = NULL; PyObject *py_name = NULL; PyObject *py_author = NULL; PyObject *py_description = NULL; @@ -171,8 +173,8 @@ struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) const char *version_extra = NULL; int ret; - assert(plugin_info); - assert(python_state == PYTHON_STATE_FULLY_INITIALIZED); + BT_ASSERT(plugin_info); + BT_ASSERT(python_state == PYTHON_STATE_FULLY_INITIALIZED); py_name = PyObject_GetAttrString(plugin_info, "name"); if (!py_name) { BT_LOGW("Cannot find `name` attribute in Python plugin info object: " @@ -263,9 +265,9 @@ struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) PyObject *py_minor = PyTuple_GetItem(py_version, 1); PyObject *py_patch = PyTuple_GetItem(py_version, 2); - assert(py_major); - assert(py_minor); - assert(py_patch); + BT_ASSERT(py_major); + BT_ASSERT(py_minor); + BT_ASSERT(py_patch); if (PyLong_Check(py_major)) { major = PyLong_AsUnsignedLong(py_major); @@ -290,7 +292,7 @@ struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) if (PyTuple_Size(py_version) >= 4) { PyObject *py_extra = PyTuple_GetItem(py_version, 3); - assert(py_extra); + BT_ASSERT(py_extra); if (PyUnicode_Check(py_extra)) { version_extra = PyUnicode_AsUTF8(py_extra); @@ -329,15 +331,14 @@ struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) size_t i; for (i = 0; i < PyList_Size(py_comp_class_addrs); i++) { - struct bt_component_class *comp_class; + bt_component_class *comp_class; PyObject *py_comp_class_addr; py_comp_class_addr = PyList_GetItem(py_comp_class_addrs, i); - assert(py_comp_class_addr); + BT_ASSERT(py_comp_class_addr); if (PyLong_Check(py_comp_class_addr)) { - comp_class = (struct bt_component_class *) - PyLong_AsUnsignedLongLong(py_comp_class_addr); + comp_class = PyLong_AsVoidPtr(py_comp_class_addr); } else { BT_LOGW("Component class address is not an integer in Python plugin info object: " "py-plugin-info-addr=%p, index=%zu", @@ -364,14 +365,12 @@ struct bt_plugin *bt_plugin_from_python_plugin_info(PyObject *plugin_info) } } - bt_plugin_freeze(plugin); - goto end; error: print_python_traceback_warn(); pyerr_clear(); - BT_PUT(plugin); + BT_OBJECT_PUT_REF_AND_RESET(plugin); end: Py_XDECREF(py_name); @@ -384,15 +383,15 @@ end: } G_MODULE_EXPORT -struct bt_plugin_set *bt_plugin_python_create_all_from_file(const char *path) +bt_plugin_set *bt_plugin_python_create_all_from_file(const char *path) { - struct bt_plugin_set *plugin_set = NULL; - struct bt_plugin *plugin = NULL; + bt_plugin_set *plugin_set = NULL; + bt_plugin *plugin = NULL; PyObject *py_plugin_info = NULL; gchar *basename = NULL; size_t path_len; - assert(path); + BT_ASSERT(path); if (python_state == PYTHON_STATE_CANNOT_INITIALIZE) { /* @@ -488,10 +487,10 @@ struct bt_plugin_set *bt_plugin_python_create_all_from_file(const char *path) goto end; error: - BT_PUT(plugin_set); + BT_OBJECT_PUT_REF_AND_RESET(plugin_set); end: - bt_put(plugin); + bt_plugin_put_ref(plugin); Py_XDECREF(py_plugin_info); g_free(basename); return plugin_set;