X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=src%2Fbindings%2Fpython%2Fbt2%2Fbt2%2Fnative_bt_trace_class.i;h=3e4916932caf24b5c2be68acf9de6a9a1de44c52;hb=43c59509042845f8d42c3e99ec74d45fa2dc0908;hp=e060566425ded1fea062456a9c723e8e5516b3db;hpb=12cd44903163531e12412edde3fb41ea7245c91f;p=babeltrace.git diff --git a/src/bindings/python/bt2/bt2/native_bt_trace_class.i b/src/bindings/python/bt2/bt2/native_bt_trace_class.i index e0605664..3e491693 100644 --- a/src/bindings/python/bt2/bt2/native_bt_trace_class.i +++ b/src/bindings/python/bt2/bt2/native_bt_trace_class.i @@ -22,52 +22,11 @@ * THE SOFTWARE. */ -%include %include /* Helper functions for Python */ %{ -static void -trace_class_destroyed_listener(const bt_trace_class *trace_class, void *py_callable) -{ - PyObject *py_trace_class_ptr = NULL; - PyObject *py_res = NULL; - - py_trace_class_ptr = SWIG_NewPointerObj(SWIG_as_voidptr(trace_class), - SWIGTYPE_p_bt_trace_class, 0); - if (!py_trace_class_ptr) { - BT_LOGF_STR("Failed to create a SWIG pointer object."); - abort(); - } - - py_res = PyObject_CallFunction(py_callable, "(O)", py_trace_class_ptr); - if (py_res) { - BT_ASSERT(py_res == Py_None); - } else { - loge_exception("Trace class's destruction listener (Python)", - BT_LOG_OUTPUT_LEVEL); - } - - Py_DECREF(py_trace_class_ptr); - Py_XDECREF(py_res); -} - -int bt_bt2_trace_class_add_destruction_listener( - bt_trace_class *trace_class, PyObject *py_callable, - bt_listener_id *id) -{ - bt_trace_class_add_listener_status status; - - BT_ASSERT(trace_class); - BT_ASSERT(py_callable); - status = bt_trace_class_add_destruction_listener( - trace_class, trace_class_destroyed_listener, py_callable, id); - if (status == __BT_FUNC_STATUS_OK) { - Py_INCREF(py_callable); - } - - return status; -} +#include "native_bt_trace_class.i.h" %} int bt_bt2_trace_class_add_destruction_listener(