+2007-07-18 Michael Smith <msmith@fluendo.com>
+
+ * ext/soundtouch/gstpitch.cc:
+ If we receive a new segment event, don't try to push buffers out
+ in response (without first sending it on!).
+ Instead, flush internal buffers on receiving flush events.
+ Fixes playback after seeking.
+
2007-07-18 Stefan Kost <ensonic@users.sf.net>
* gst/bayer/gstbayer2rgb.c: (gst_bayer2rgb_set_caps),
* samples are sent out here as strictly necessary, because soundtouch could
* append zero samples, which could disturb looping. */
static GstFlowReturn
-gst_pitch_flush_buffer (GstPitch * pitch)
+gst_pitch_flush_buffer (GstPitch * pitch, gboolean send)
{
GstBuffer *buffer;
return GST_FLOW_OK;
pitch->priv->st->flush ();
+ if (!send)
+ return GST_FLOW_OK;
+
buffer = gst_pitch_prepare_buffer (pitch);
if (!buffer)
GST_LOG_OBJECT (pad, "received %s event", GST_EVENT_TYPE_NAME (event));
switch (GST_EVENT_TYPE (event)) {
- case GST_EVENT_NEWSEGMENT:
+ case GST_EVENT_FLUSH_STOP:
+ gst_pitch_flush_buffer (pitch, FALSE);
+ break;
case GST_EVENT_EOS:
- gst_pitch_flush_buffer (pitch);
+ gst_pitch_flush_buffer (pitch, TRUE);
break;
default:
break;