avwait: Don't consider it a segment change if the segment is the same except for...
authorSebastian Dröge <sebastian@centricular.com>
Thu, 10 Jun 2021 08:46:35 +0000 (11:46 +0300)
committerGStreamer Marge Bot <gitlab-merge-bot@gstreamer-foundation.org>
Wed, 23 Jun 2021 16:03:38 +0000 (16:03 +0000)
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/2319>

gst/timecode/gstavwait.c

index 7f7305306738a473fad2a8006d1c4076a7403ced..e089505c92902024b9203448833c8af2fc1fffc7 100644 (file)
@@ -617,14 +617,15 @@ gst_avwait_vsink_event (GstPad * pad, GstObject * parent, GstEvent * event)
 
   switch (GST_EVENT_TYPE (event)) {
     case GST_EVENT_SEGMENT:{
-      const GstSegment *segment;
+      GstSegment segment;
       gboolean send_message = FALSE;
       gboolean segment_changed;
 
       g_mutex_lock (&self->mutex);
-      gst_event_parse_segment (event, &segment);
-      segment_changed = !gst_segment_is_equal (segment, &self->vsegment);
-      self->vsegment = *segment;
+      gst_event_copy_segment (event, &segment);
+      segment.position = self->vsegment.position;
+      segment_changed = !gst_segment_is_equal (&segment, &self->vsegment);
+      self->vsegment = segment;
       if (self->vsegment.format != GST_FORMAT_TIME) {
         GST_ERROR_OBJECT (self, "Invalid segment format");
         g_mutex_unlock (&self->mutex);
@@ -758,13 +759,14 @@ gst_avwait_asink_event (GstPad * pad, GstObject * parent, GstEvent * event)
 
   switch (GST_EVENT_TYPE (event)) {
     case GST_EVENT_SEGMENT:{
-      const GstSegment *segment;
+      GstSegment segment;
       gboolean segment_changed;
 
       g_mutex_lock (&self->mutex);
-      gst_event_parse_segment (event, &segment);
-      segment_changed = !gst_segment_is_equal (segment, &self->asegment);
-      self->asegment = *segment;
+      gst_event_copy_segment (event, &segment);
+      segment.position = self->asegment.position;
+      segment_changed = !gst_segment_is_equal (&segment, &self->asegment);
+      self->asegment = segment;
 
       if (self->asegment.format != GST_FORMAT_TIME) {
         GST_ERROR_OBJECT (self, "Invalid segment format");