From dd901080d779a32aea3b623926191f2f0dfa06c5 Mon Sep 17 00:00:00 2001 From: Thomas Vander Stichele Date: Tue, 12 Apr 2005 16:29:49 +0000 Subject: [PATCH] wrap gst_plugin_get_version so it returns a tuple Original commit message from CVS: wrap gst_plugin_get_version so it returns a tuple --- ChangeLog | 6 ++++++ gst/gst.defs | 6 ++++++ gst/gst.override | 27 ++++++++++++++++++++++++++- 3 files changed, 38 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index b39c444166..4157820ccb 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2005-04-12 Thomas Vander Stichele + + * gst/gst.defs: + * gst/gst.override: + wrap gst_plugin_get_version so it returns a tuple + 2005-04-12 Thomas Vander Stichele * testsuite/test_probe.py: diff --git a/gst/gst.defs b/gst/gst.defs index 0a89792ab5..99a5fc7509 100644 --- a/gst/gst.defs +++ b/gst/gst.defs @@ -3756,6 +3756,12 @@ (return-type "const-gchar*") ) +(define-method get_version + (of-object "GstPlugin") + (c-name "gst_plugin_get_version") + (return-type "const-gchar*") +) + (define-method get_module (of-object "GstPlugin") (c-name "gst_plugin_get_module") diff --git a/gst/gst.override b/gst/gst.override index cdc2d48474..88291a606c 100644 --- a/gst/gst.override +++ b/gst/gst.override @@ -99,7 +99,6 @@ ignore gst_alloc_trace_list gst_alloc_trace_get gst_error_get_message - gst_object_default_deep_notify gst_object_check_uniqueness gst_object_replace gst_parse_launchv @@ -739,3 +738,29 @@ _wrap_gst_probe_perform(PyGBoxed *self, PyObject *args, PyObject *kwargs) return PyBool_FromLong(gst_probe_perform(self->boxed, &data)); } +%% +override gst_plugin_get_version +static PyObject * +_wrap_gst_plugin_get_version(PyGObject *self) +{ + PyObject *tuple; + const gchar *version; + gchar **items, **p; + gint i = 0; + gint count = 0; + + version = gst_plugin_get_version((GstPlugin *) self->obj); + items = g_strsplit(version, ".", 4); + for (p = items; *p; ++p) ++count; + + tuple = PyTuple_New(count); + for (p = items; *p; ++p) { + PyObject *item; + item = PyInt_FromString(*p, NULL, 10); + PyTuple_SetItem(tuple, i, item); + i++; + } + + g_strfreev(items); + return tuple; +}