From ebd9a6d04bbf073f34f7444044c32c7a986c6f38 Mon Sep 17 00:00:00 2001 From: Wim Taymans Date: Wed, 28 Feb 2007 16:57:49 +0000 Subject: [PATCH] gst/gstvalue.c: Implement GstObject -> string transform so we print object names when serializing GValues containing ... Original commit message from CVS: * gst/gstvalue.c: (gst_value_transform_object_string), (_gst_value_initialize): Implement GstObject -> string transform so we print object names when serializing GValues containing GstObjects. --- ChangeLog | 7 +++++++ gst/gstvalue.c | 15 +++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/ChangeLog b/ChangeLog index 1b2ce4b802..fc9753e815 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2007-02-28 Wim Taymans + + * gst/gstvalue.c: (gst_value_transform_object_string), + (_gst_value_initialize): + Implement GstObject -> string transform so we print object names + when serializing GValues containing GstObjects. + 2007-02-28 Wim Taymans * docs/gst/gstreamer-sections.txt: diff --git a/gst/gstvalue.c b/gst/gstvalue.c index e47364c841..9d64ed273d 100644 --- a/gst/gstvalue.c +++ b/gst/gstvalue.c @@ -3834,6 +3834,19 @@ gst_value_transform_string_date (const GValue * src_value, GValue * dest_value) gst_value_deserialize_date (dest_value, src_value->data[0].v_pointer); } +static void +gst_value_transform_object_string (const GValue * src_value, + GValue * dest_value) +{ + GstObject *obj; + gchar *str; + + obj = g_value_get_object (src_value); + str = obj ? GST_OBJECT_NAME (obj) : "NULL"; + + dest_value->data[0].v_pointer = g_strdup (str); +} + static GTypeInfo _info = { 0, NULL, @@ -4158,6 +4171,8 @@ _gst_value_initialize (void) gst_value_transform_date_string); g_value_register_transform_func (G_TYPE_STRING, GST_TYPE_DATE, gst_value_transform_string_date); + g_value_register_transform_func (GST_TYPE_OBJECT, G_TYPE_STRING, + gst_value_transform_object_string); gst_value_register_intersect_func (G_TYPE_INT, GST_TYPE_INT_RANGE, gst_value_intersect_int_int_range);