subparse: ensure serialized sending of segment event at proper time
authorMark Nauwelaerts <mnauw@users.sourceforge.net>
Sat, 24 Jun 2017 20:03:21 +0000 (22:03 +0200)
committerMark Nauwelaerts <mnauw@users.sourceforge.net>
Sun, 25 Jun 2017 20:25:40 +0000 (22:25 +0200)
gst/subparse/gstsubparse.c

index f61c6d4e646d99d9423d779fef9ec00eb4861051..4cf354d9a474ee9b51cc6fc00158b8d5c3a23c68 100644 (file)
@@ -284,7 +284,9 @@ gst_sub_parse_src_event (GstPad * pad, GstObject * parent, GstEvent * event)
         GST_DEBUG_OBJECT (self, "segment after seek: %" GST_SEGMENT_FORMAT,
             &self->segment);
 
-        self->need_segment = TRUE;
+        /* will mark need_segment when receiving segment from upstream,
+         * after FLUSH and all that has happened,
+         * rather than racing with chain */
       } else {
         GST_WARNING_OBJECT (self, "seek to 0 bytes failed");
       }
@@ -1881,6 +1883,10 @@ gst_sub_parse_sink_event (GstPad * pad, GstObject * parent, GstEvent * event)
        * it received via its video pads instead, so all is fine then too) */
       ret = TRUE;
       gst_event_unref (event);
+      /* in either case, let's not simply discard this event;
+       * trigger sending of the saved requested seek segment
+       * or the one taken here from upstream */
+      self->need_segment = TRUE;
       break;
     }
     case GST_EVENT_FLUSH_START: