From 139163d89e2e1fc2489d75f6892507bea14a40f9 Mon Sep 17 00:00:00 2001 From: Edward Hervey Date: Thu, 4 Aug 2005 10:44:16 +0000 Subject: [PATCH] gst/: We now have debugging in gst-python ;) gst.[log|debug|info|warning|error]() Original commit message from CVS: * gst/gst.defs: * gst/gst.override: * gst/gstmodule.c: We now have debugging in gst-python ;) gst.[log|debug|info|warning|error]() --- ChangeLog | 8 +++++++ gst/gst.defs | 41 ++++++++++++++++++++++++++++++++ gst/gst.override | 62 ++++++++++++++++++++++++++++++++++++++++++++++++ gst/gstmodule.c | 3 +++ 4 files changed, 114 insertions(+) diff --git a/ChangeLog b/ChangeLog index 15a206aa4d..4177d18468 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2005-08-04 Edward Hervey + + * gst/gst.defs: + * gst/gst.override: + * gst/gstmodule.c: + We now have debugging in gst-python ;) + gst.[log|debug|info|warning|error]() + 2005-08-03 Edward Hervey * configure.ac: diff --git a/gst/gst.defs b/gst/gst.defs index 30642a60fe..232c6d393e 100644 --- a/gst/gst.defs +++ b/gst/gst.defs @@ -2273,7 +2273,48 @@ ) ) +;; DEBUGGING FUNCTIONS FROM PYTHON +;; The c functions don't actually exist +(define-function log + (c-name "gst_log") + (return-type "none") + (parameters + '("gchar *" "msg") + ) +) + +(define-function debug + (c-name "gst_debug") + (return-type "none") + (parameters + '("gchar *" "msg") + ) +) + +(define-function info + (c-name "gst_info") + (return-type "none") + (parameters + '("gchar *" "msg") + ) +) + +(define-function warning + (c-name "gst_warning") + (return-type "none") + (parameters + '("gchar *" "msg") + ) +) + +(define-function error + (c-name "gst_error") + (return-type "none") + (parameters + '("gchar *" "msg") + ) +) ;; From ../gstreamer/gst/gstinterface.h diff --git a/gst/gst.override b/gst/gst.override index 57ee1031d9..4d270e55c1 100644 --- a/gst/gst.override +++ b/gst/gst.override @@ -53,6 +53,9 @@ headers PyObject *PyGstExc_LinkError = NULL; +GST_DEBUG_CATEGORY_EXTERN (gst_python); +#define GST_CAT_DEFAULT gst_python + GSList *mainloops = NULL; void _pygst_main_quit(void) @@ -217,6 +220,30 @@ _pygst_element_init (gpointer gclass, PyTypeObject *pyclass) } #endif +static PyObject * +pygst_debug_log (PyObject *whatever, PyObject *string, GstDebugLevel level) +{ + gchar *str; + gchar *function; + gchar *filename; + gchar lineno; + PyFrameObject *frame; + + if (!PyArg_ParseTuple(string, "s:gst.debug_log", &str)) { + PyErr_SetString(PyExc_TypeError, "Need a string!"); + return NULL; + } + + frame = PyEval_GetFrame(); + function = PyString_AsString(frame->f_code->co_name); + filename = PyString_AsString(frame->f_code->co_filename); + lineno = frame->f_code->co_firstlineno; + /* gst_debug_log : category, level, file, function, line, object, format, va_list */ + gst_debug_log (GST_CAT_DEFAULT, level, filename, function, lineno, NULL, str); + Py_INCREF (Py_None); + return Py_None; +} + %% include gstbin.override @@ -959,3 +986,38 @@ _wrap_gst_flow_get_name(PyObject *self, PyObject *args, PyObject *kwargs) Py_INCREF(Py_None); return Py_None; } +%% +override gst_log args +static PyObject * +_wrap_gst_log (PyObject *whatever, PyObject *string) +{ + return pygst_debug_log (whatever, string, GST_LEVEL_LOG); +} +%% +override gst_debug args +static PyObject * +_wrap_gst_debug (PyObject *whatever, PyObject *string) +{ + return pygst_debug_log (whatever, string, GST_LEVEL_DEBUG); +} +%% +override gst_info args +static PyObject * +_wrap_gst_info (PyObject *whatever, PyObject *string) +{ + return pygst_debug_log (whatever, string, GST_LEVEL_INFO); +} +%% +override gst_warning +static PyObject * +_wrap_gst_warning (PyObject *whatever, PyObject *string) +{ + return pygst_debug_log (whatever, string, GST_LEVEL_WARNING); +} +%% +override gst_error +static PyObject * +_wrap_gst_error (PyObject *whatever, PyObject *string) +{ + return pygst_debug_log (whatever, string, GST_LEVEL_ERROR); +} diff --git a/gst/gstmodule.c b/gst/gstmodule.c index a6699f69f2..da9bb40d75 100644 --- a/gst/gstmodule.c +++ b/gst/gstmodule.c @@ -42,6 +42,7 @@ extern GSList *mainloops; extern void _pygst_main_quit(void); extern PyObject *PyGstExc_LinkError; +GST_DEBUG_CATEGORY (gst_python); /* This is a timeout that gets added to the mainloop to handle SIGINT (Ctrl-C) * Other signals get handled at some other point where transition from @@ -168,6 +169,8 @@ init_gst (void) pygst_register_classes (d); pygst_add_constants (m, "GST_"); + /* Initialize debugging category */ + GST_DEBUG_CATEGORY_INIT (gst_python, "gst-python", 0, "GStreamer python bindings"); g_timeout_add_full (0, 100, python_do_pending_calls, NULL, NULL);