summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulien Moutte <julien@moutte.net>2003-12-16 14:56:06 +0000
committerJulien Moutte <julien@moutte.net>2003-12-16 14:56:06 +0000
commit84ccaf3a8a3afd1a4af7bf716e6b11c37bbf10ca (patch)
treec92480ddb331bc6c7e5034a5a547a2d8d4b5033c
parentd4b8214f7b2478ec6048c0288802dd18d265207e (diff)
downloadgst-plugins-bad-84ccaf3a8a3afd1a4af7bf716e6b11c37bbf10ca.tar.gz
gst-plugins-bad-84ccaf3a8a3afd1a4af7bf716e6b11c37bbf10ca.tar.bz2
gst-plugins-bad-84ccaf3a8a3afd1a4af7bf716e6b11c37bbf10ca.zip
Adding tag dumping support.
Original commit message from CVS: Adding tag dumping support.
-rw-r--r--examples/gstplay/player.c37
1 files changed, 36 insertions, 1 deletions
diff --git a/examples/gstplay/player.c b/examples/gstplay/player.c
index 09811e63..846d58ac 100644
--- a/examples/gstplay/player.c
+++ b/examples/gstplay/player.c
@@ -23,6 +23,39 @@ static GMainLoop *loop = NULL;
static gint64 length = 0;
static void
+print_tag (const GstTagList *list, const gchar *tag, gpointer unused)
+{
+ gint i, count;
+
+ count = gst_tag_list_get_tag_size (list, tag);
+
+ for (i = 0; i < count; i++) {
+ gchar *str;
+
+ if (gst_tag_get_type (tag) == G_TYPE_STRING) {
+ g_assert (gst_tag_list_get_string_index (list, tag, i, &str));
+ } else {
+ str = g_strdup_value_contents (
+ gst_tag_list_get_value_index (list, tag, i));
+ }
+
+ if (i == 0) {
+ g_print ("%15s: %s\n", gst_tag_get_nick (tag), str);
+ } else {
+ g_print (" : %s\n", str);
+ }
+
+ g_free (str);
+ }
+}
+
+static void
+got_found_tag (GstPlay *play,GstElement *source, GstTagList *tag_list)
+{
+ gst_tag_list_foreach (tag_list, print_tag, NULL);
+}
+
+static void
got_time_tick (GstPlay *play, gint64 time_nanos)
{
g_message ("time tick %llu", time_nanos);
@@ -82,7 +115,7 @@ main (int argc, char *argv[])
/* Getting default audio and video plugins from GConf */
audio_sink = gst_element_factory_make ("osssink", "audio_sink");
- video_sink = gst_element_factory_make ("ximagesink", "video_sink");
+ video_sink = gst_element_factory_make ("xvimagesink", "video_sink");
vis_element = gst_element_factory_make ("goom", "vis_element");
data_src = gst_element_factory_make ("gnomevfssrc", "source");
@@ -103,6 +136,8 @@ main (int argc, char *argv[])
G_CALLBACK (got_stream_length), NULL);
g_signal_connect (G_OBJECT (play), "have_video_size",
G_CALLBACK (got_video_size), NULL);
+ g_signal_connect (G_OBJECT (play), "found_tag",
+ G_CALLBACK (got_found_tag), NULL);
g_signal_connect (G_OBJECT (play), "eos",
G_CALLBACK (got_eos), NULL);