mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
bugfixes:
Original commit message from CVS: bugfixes: - seek correctly on SEEK_METHOD_END - don't emit a warning when mp3's in wav's have no width information - use BYTES format on discontinuous events and omit timestamp when invalid (mp3 anyone?)
This commit is contained in:
parent
bd1013b086
commit
98cfd56ea3
1 changed files with 13 additions and 6 deletions
|
@ -267,10 +267,18 @@ gst_wavparse_chain (GstPad *pad, GstBuffer *buf)
|
||||||
&GST_BUFFER_TIMESTAMP (buf));
|
&GST_BUFFER_TIMESTAMP (buf));
|
||||||
|
|
||||||
if (wavparse->need_discont) {
|
if (wavparse->need_discont) {
|
||||||
gst_pad_push (wavparse->srcpad,
|
if (GST_BUFFER_TIMESTAMP_IS_VALID (buf)) {
|
||||||
GST_BUFFER (gst_event_new_discontinuous (FALSE,
|
gst_pad_push (wavparse->srcpad,
|
||||||
|
GST_BUFFER (gst_event_new_discontinuous (FALSE,
|
||||||
|
GST_FORMAT_BYTES, wavparse->offset,
|
||||||
GST_FORMAT_TIME, GST_BUFFER_TIMESTAMP (buf),
|
GST_FORMAT_TIME, GST_BUFFER_TIMESTAMP (buf),
|
||||||
NULL)));
|
NULL)));
|
||||||
|
} else {
|
||||||
|
gst_pad_push (wavparse->srcpad,
|
||||||
|
GST_BUFFER (gst_event_new_discontinuous (FALSE,
|
||||||
|
GST_FORMAT_BYTES, wavparse->offset,
|
||||||
|
NULL)));
|
||||||
|
}
|
||||||
wavparse->need_discont = FALSE;
|
wavparse->need_discont = FALSE;
|
||||||
}
|
}
|
||||||
gst_pad_push (wavparse->srcpad, buf);
|
gst_pad_push (wavparse->srcpad, buf);
|
||||||
|
@ -499,9 +507,8 @@ gst_wavparse_pad_convert (GstPad *pad,
|
||||||
|
|
||||||
bytes_per_sample = wavparse->channels * wavparse->width / 8;
|
bytes_per_sample = wavparse->channels * wavparse->width / 8;
|
||||||
if (bytes_per_sample == 0) {
|
if (bytes_per_sample == 0) {
|
||||||
g_warning ("bytes_per_sample is 0, internal error\n");
|
GST_DEBUG (0, "bytes_per_sample is 0, probably an mp3 - channels %d, width %d\n",
|
||||||
g_warning ("channels %d, width %d\n",
|
wavparse->channels, wavparse->width);
|
||||||
wavparse->channels, wavparse->width);
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
byterate = (glong) (bytes_per_sample * wavparse->rate);
|
byterate = (glong) (bytes_per_sample * wavparse->rate);
|
||||||
|
@ -630,7 +637,7 @@ gst_wavparse_srcpad_event (GstPad *pad, GstEvent *event)
|
||||||
seek = gst_event_new_seek (
|
seek = gst_event_new_seek (
|
||||||
GST_FORMAT_BYTES |
|
GST_FORMAT_BYTES |
|
||||||
(GST_EVENT_SEEK_TYPE (event) & ~GST_SEEK_FORMAT_MASK),
|
(GST_EVENT_SEEK_TYPE (event) & ~GST_SEEK_FORMAT_MASK),
|
||||||
byteoffset + wavparse->datastart);
|
byteoffset + (GST_EVENT_SEEK_METHOD (event) == GST_SEEK_METHOD_END ? 0 : wavparse->datastart));
|
||||||
|
|
||||||
res = gst_pad_send_event (GST_PAD_PEER (wavparse->sinkpad), seek);
|
res = gst_pad_send_event (GST_PAD_PEER (wavparse->sinkpad), seek);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue