summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--gst/modplug/gstmodplug.cc11
2 files changed, 18 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index ff48eec0..7e8566da 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2004-03-14 Benjamin Otte <otte@gnome.org>
+ * gst/modplug/gstmodplug.cc:
+ handle events - don't do crap when a discont arrives that's not
+ necessary
+ This allows correct loading and playback of mods in Rhythmbox
+
+2004-03-14 Benjamin Otte <otte@gnome.org>
+
* configure.ac:
* gst-libs/gst/gconf/Makefile.am:
* pkgconfig/Makefile.am:
diff --git a/gst/modplug/gstmodplug.cc b/gst/modplug/gstmodplug.cc
index c4f143d5..06701c6d 100644
--- a/gst/modplug/gstmodplug.cc
+++ b/gst/modplug/gstmodplug.cc
@@ -270,6 +270,7 @@ gst_modplug_init (GstModPlug *modplug)
modplug->buffer_in = NULL;
modplug->state = MODPLUG_STATE_NEED_TUNE;
+ GST_FLAG_SET (modplug, GST_ELEMENT_EVENT_AWARE);
}
static void
@@ -484,6 +485,7 @@ gst_modplug_fixate (GstPad *pad, const GstCaps *caps)
static void
gst_modplug_handle_event (GstModPlug *modplug)
{
+ gint64 value;
guint32 remaining;
GstEvent *event;
@@ -495,7 +497,16 @@ gst_modplug_handle_event (GstModPlug *modplug)
}
switch (GST_EVENT_TYPE (event)) {
+ case GST_EVENT_EOS:
+ gst_event_unref (event);
+ break;
case GST_EVENT_DISCONTINUOUS:
+ if (gst_event_discont_get_value (event, GST_FORMAT_BYTES, &value)) {
+ if (remaining == value) {
+ gst_event_unref (event);
+ break;
+ }
+ }
gst_bytestream_flush_fast (modplug->bs, remaining);
default:
gst_pad_event_default (modplug->sinkpad, event);