oggmux: only drop flushing seeks after we started to mux
authorStefan Sauer <ensonic@users.sf.net>
Tue, 10 Jul 2012 06:13:02 +0000 (08:13 +0200)
committerStefan Sauer <ensonic@users.sf.net>
Mon, 16 Jul 2012 09:27:57 +0000 (11:27 +0200)
Don't drop all seek events. It is okay to seek before we send the headers. Non
flushing seeks are okay at any time later as well.

ext/ogg/gstoggmux.c

index 0620e3157b58149cee6383cffa917a31df56dcdd..943c94ab3511464462d0265fcddce5916f797bea 100644 (file)
@@ -521,19 +521,28 @@ static gboolean
 gst_ogg_mux_handle_src_event (GstPad * pad, GstObject * parent,
     GstEvent * event)
 {
-  GstEventType type;
-
-  type = event ? GST_EVENT_TYPE (event) : GST_EVENT_UNKNOWN;
+  gboolean res = FALSE;
+  GstOggMux *ogg_mux = GST_OGG_MUX (parent);
+  GstEventType type = event ? GST_EVENT_TYPE (event) : GST_EVENT_UNKNOWN;
 
   switch (type) {
-    case GST_EVENT_SEEK:
-      /* disable seeking for now */
-      return FALSE;
+    case GST_EVENT_SEEK:{
+      GstSeekFlags flags;
+
+      gst_event_parse_seek (event, NULL, NULL, &flags, NULL, NULL, NULL, NULL);
+      if (!ogg_mux->need_headers && (flags & GST_SEEK_FLAG_FLUSH) != 0) {
+        /* disable flushing seeks once we started */
+        goto eat;
+      }
+      break;
+    }
     default:
       break;
   }
 
-  return gst_pad_event_default (pad, parent, event);
+  res = gst_pad_event_default (pad, parent, event);
+eat:
+  return res;
 }
 
 static GstBuffer *