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:
Benjamin Otte 2003-04-29 21:54:47 +00:00
parent bd1013b086
commit 98cfd56ea3

View file

@ -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);