From 4e11b596cbf479e683bc8fd394769c7a5497fb5b Mon Sep 17 00:00:00 2001 From: Wim Taymans Date: Tue, 17 Mar 2009 19:53:44 +0100 Subject: [PATCH] oggdemux: report -1 for duration in push mode In push mode we must return TRUE from the duration query with a value of -1 meaning that we know that we don't know the duration. --- ext/ogg/gstoggdemux.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/ext/ogg/gstoggdemux.c b/ext/ogg/gstoggdemux.c index 6d640b3578..77b6fa1453 100644 --- a/ext/ogg/gstoggdemux.c +++ b/ext/ogg/gstoggdemux.c @@ -275,15 +275,22 @@ gst_ogg_pad_src_query (GstPad * pad, GstQuery * query) case GST_QUERY_DURATION: { GstFormat format; + gint64 total_time; gst_query_parse_duration (query, &format, NULL); /* can only get position in time */ if (format != GST_FORMAT_TIME) goto wrong_format; - /* can only return the total time position */ - /* FIXME, return time for this specific stream */ - gst_query_set_duration (query, GST_FORMAT_TIME, ogg->total_time); + if (ogg->seekable) { + /* we must return the total seekable length */ + total_time = ogg->total_time; + } else { + /* in non-seek mode we can answer the query and we must return -1 */ + total_time = -1; + } + + gst_query_set_duration (query, GST_FORMAT_TIME, total_time); break; } case GST_QUERY_SEEKING: