diff options
author | Wim Taymans <wim.taymans@gmail.com> | 2005-10-19 15:57:04 +0000 |
---|---|---|
committer | Wim Taymans <wim.taymans@gmail.com> | 2005-10-19 15:57:04 +0000 |
commit | ba7ee6ae6cc73b5620b517e03ddac8a2b4badb90 (patch) | |
tree | a950dccd74a3f01c613ce5c89fe37529869b7dad /ext | |
parent | 97f39d46478583613258d50acdc209e5c489a969 (diff) |
API change fix.
Original commit message from CVS:
* ext/dv/gstdvdemux.c: (gst_dvdemux_get_src_query_types),
(gst_dvdemux_src_query):
* ext/flac/gstflacdec.c: (gst_flacdec_length),
(gst_flacdec_src_query):
* ext/raw1394/gstdv1394src.c: (gst_dv1394src_query):
* ext/speex/gstspeexdec.c: (speex_dec_src_query):
* gst/avi/gstavidemux.c: (gst_avi_demux_handle_src_query):
* gst/debug/gstnavseek.c: (gst_navseek_seek):
* gst/debug/progressreport.c: (gst_progress_report_report):
* gst/matroska/ebml-read.c: (gst_ebml_read_get_length):
* gst/matroska/matroska-demux.c:
(gst_matroska_demux_handle_src_query):
* gst/matroska/matroska-mux.c: (gst_matroska_mux_start):
* gst/wavparse/gstwavparse.c: (gst_wavparse_handle_seek),
(gst_wavparse_stream_headers), (gst_wavparse_stream_data),
(gst_wavparse_pad_convert), (gst_wavparse_pad_query),
(gst_wavparse_srcpad_event):
API change fix.
Diffstat (limited to 'ext')
-rw-r--r-- | ext/dv/gstdvdemux.c | 38 | ||||
-rw-r--r-- | ext/flac/gstflacdec.c | 24 | ||||
-rw-r--r-- | ext/raw1394/gstdv1394src.c | 4 | ||||
-rw-r--r-- | ext/speex/gstspeexdec.c | 51 |
4 files changed, 79 insertions, 38 deletions
diff --git a/ext/dv/gstdvdemux.c b/ext/dv/gstdvdemux.c index d6fefe5e..9e6e2055 100644 --- a/ext/dv/gstdvdemux.c +++ b/ext/dv/gstdvdemux.c @@ -413,6 +413,7 @@ gst_dvdemux_get_src_query_types (GstPad * pad) { static const GstQueryType src_query_types[] = { GST_QUERY_POSITION, + GST_QUERY_DURATION, GST_QUERY_CONVERT, 0 }; @@ -432,15 +433,30 @@ gst_dvdemux_src_query (GstPad * pad, GstQuery * query) case GST_QUERY_POSITION: { GstFormat format; + gint64 cur; + + /* get target format */ + gst_query_parse_position (query, &format, NULL); + + /* bring the position to the requested format. */ + if (!(res = gst_pad_query_convert (pad, + GST_FORMAT_TIME, dvdemux->timestamp, &format, &cur))) + goto error; + gst_query_set_position (query, format, cur); + break; + } + case GST_QUERY_DURATION: + { + GstFormat format; GstFormat format2; - gint64 cur, end; + gint64 end; GstPad *peer; /* get target format */ - gst_query_parse_position (query, &format, NULL, NULL); + gst_query_parse_duration (query, &format, NULL); - /* change query to perform on peer */ - gst_query_set_position (query, GST_FORMAT_BYTES, -1, -1); + /* change query to bytes to perform on peer */ + gst_query_set_duration (query, GST_FORMAT_BYTES, -1); if ((peer = gst_pad_get_peer (dvdemux->sinkpad))) { /* ask peer for total length */ @@ -450,28 +466,22 @@ gst_dvdemux_src_query (GstPad * pad, GstQuery * query) } /* get peer total length */ - gst_query_parse_position (query, NULL, NULL, &end); + gst_query_parse_duration (query, NULL, &end); + + gst_object_unref (peer); /* convert end to requested format */ if (end != -1) { format2 = format; if (!(res = gst_pad_query_convert (dvdemux->sinkpad, GST_FORMAT_BYTES, end, &format2, &end))) { - gst_object_unref (peer); goto error; } } - gst_object_unref (peer); } else { end = -1; } - /* bring the position to the requested format. */ - if (!(res = gst_pad_query_convert (pad, - GST_FORMAT_TIME, dvdemux->timestamp, &format, &cur))) - goto error; - if (!(res = gst_pad_query_convert (pad, format2, end, &format, &end))) - goto error; - gst_query_set_position (query, format, cur, end); + gst_query_set_duration (query, format, end); break; } case GST_QUERY_CONVERT: diff --git a/ext/flac/gstflacdec.c b/ext/flac/gstflacdec.c index 3079c880..c609e2e5 100644 --- a/ext/flac/gstflacdec.c +++ b/ext/flac/gstflacdec.c @@ -359,7 +359,7 @@ gst_flacdec_length (const FLAC__SeekableStreamDecoder * decoder, if (!(peer = gst_pad_get_peer (flacdec->sinkpad))) return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR; - gst_pad_query_position (peer, &fmt, NULL, &len); + gst_pad_query_duration (peer, &fmt, &len); gst_object_unref (peer); if (fmt != GST_FORMAT_BYTES || len == -1) return FLAC__SEEKABLE_STREAM_DECODER_TELL_STATUS_ERROR; @@ -706,20 +706,30 @@ gst_flacdec_src_query (GstPad * pad, GstQuery * query) switch (GST_QUERY_TYPE (query)) { case GST_QUERY_POSITION:{ - gint64 len, pos; + gint64 pos; + GstFormat fmt = GST_FORMAT_TIME; + + pos = flacdec->total_samples; + + if (gst_flacdec_convert_src (flacdec->srcpad, + GST_FORMAT_DEFAULT, pos, &fmt, &pos)) + gst_query_set_position (query, GST_FORMAT_TIME, pos); + else + res = FALSE; + break; + } + case GST_QUERY_DURATION:{ + gint64 len; GstFormat fmt = GST_FORMAT_TIME; if (flacdec->stream_samples == 0) len = flacdec->total_samples; else len = flacdec->stream_samples; - pos = flacdec->total_samples; if (gst_flacdec_convert_src (flacdec->srcpad, - GST_FORMAT_DEFAULT, len, &fmt, &len) && - gst_flacdec_convert_src (flacdec->srcpad, - GST_FORMAT_DEFAULT, pos, &fmt, &pos)) - gst_query_set_position (query, GST_FORMAT_TIME, pos, len); + GST_FORMAT_DEFAULT, len, &fmt, &len)) + gst_query_set_duration (query, GST_FORMAT_TIME, len); else res = FALSE; break; diff --git a/ext/raw1394/gstdv1394src.c b/ext/raw1394/gstdv1394src.c index e39bb198..30ea6176 100644 --- a/ext/raw1394/gstdv1394src.c +++ b/ext/raw1394/gstdv1394src.c @@ -789,13 +789,13 @@ gst_dv1394src_query (GstPad * pad, GstQuery * query) GstFormat format; gint64 current; - gst_query_parse_position (query, &format, NULL, NULL); + gst_query_parse_position (query, &format, NULL); /* bring our current frame to the requested format */ res = gst_pad_query_convert (pad, GST_FORMAT_DEFAULT, src->frame_sequence, &format, ¤t); - gst_query_set_position (query, format, current, -1); + gst_query_set_position (query, format, current); break; } case GST_QUERY_CONVERT: diff --git a/ext/speex/gstspeexdec.c b/ext/speex/gstspeexdec.c index adf00790..c495cf1d 100644 --- a/ext/speex/gstspeexdec.c +++ b/ext/speex/gstspeexdec.c @@ -211,23 +211,44 @@ speex_dec_convert (GstPad * pad, static gboolean speex_dec_src_query (GstPad * pad, GstQuery * query) { - gint64 samples_out = 0, total_samples; GstSpeexDec *dec = GST_SPEEXDEC (GST_OBJECT_PARENT (pad)); - GstFormat my_format = GST_FORMAT_TIME; - GstPad *peer; - if (GST_QUERY_TYPE (query) != GST_QUERY_POSITION) - return FALSE; - if (!(peer = gst_pad_get_peer (dec->sinkpad))) - return FALSE; - gst_pad_query_position (peer, &my_format, NULL, &total_samples); - gst_object_unref (peer); - samples_out = dec->samples_out; - speex_dec_convert (dec->srcpad, GST_FORMAT_DEFAULT, samples_out, - &my_format, &samples_out); - speex_dec_convert (dec->srcpad, GST_FORMAT_DEFAULT, total_samples, - &my_format, &total_samples); - gst_query_set_position (query, GST_FORMAT_TIME, samples_out, total_samples); + switch (GST_QUERY_TYPE (query)) { + case GST_QUERY_POSITION: + { + gint64 cur; + GstFormat format; + + gst_query_parse_position (query, &format, NULL); + + speex_dec_convert (dec->srcpad, GST_FORMAT_DEFAULT, dec->samples_out, + &format, &cur); + + gst_query_set_position (query, format, cur); + break; + } + case GST_QUERY_DURATION: + { + GstPad *peer; + GstFormat my_format = GST_FORMAT_TIME; + gint64 total_samples; + + if (!(peer = gst_pad_get_peer (dec->sinkpad))) + return FALSE; + + gst_pad_query_duration (peer, &my_format, &total_samples); + gst_object_unref (peer); + + speex_dec_convert (dec->srcpad, GST_FORMAT_DEFAULT, total_samples, + &my_format, &total_samples); + + gst_query_set_duration (query, GST_FORMAT_TIME, total_samples); + break; + } + default: + return FALSE; + break; + } return TRUE; } |