rtpbasedepayload: Properly propagate segment seqnum

This wasn't done previously and the outgoing SEGMENT events had
seqnums which weren't consistent with the upstream ones
This commit is contained in:
Edward Hervey 2018-06-05 17:24:55 +02:00 committed by Edward Hervey
parent 5c118e5924
commit 924eb8d8a7

View file

@ -56,6 +56,7 @@ struct _GstRTPBaseDepayloadPrivate
GstCaps *last_caps; GstCaps *last_caps;
GstEvent *segment_event; GstEvent *segment_event;
guint32 segment_seqnum; /* Note: this is a GstEvent seqnum */
}; };
/* Filter signals and args */ /* Filter signals and args */
@ -583,6 +584,7 @@ gst_rtp_base_depayload_handle_event (GstRTPBaseDepayload * filter,
GST_ERROR_OBJECT (filter, "Segment with non-TIME format not supported"); GST_ERROR_OBJECT (filter, "Segment with non-TIME format not supported");
res = FALSE; res = FALSE;
} }
filter->priv->segment_seqnum = gst_event_get_seqnum (event);
filter->segment = segment; filter->segment = segment;
GST_OBJECT_UNLOCK (filter); GST_OBJECT_UNLOCK (filter);
@ -703,6 +705,8 @@ create_segment_event (GstRTPBaseDepayload * filter, guint rtptime,
GST_DEBUG_OBJECT (filter, "Creating segment event %" GST_SEGMENT_FORMAT, GST_DEBUG_OBJECT (filter, "Creating segment event %" GST_SEGMENT_FORMAT,
&segment); &segment);
event = gst_event_new_segment (&segment); event = gst_event_new_segment (&segment);
if (filter->priv->segment_seqnum != GST_SEQNUM_INVALID)
gst_event_set_seqnum (event, filter->priv->segment_seqnum);
return event; return event;
} }
@ -877,6 +881,7 @@ gst_rtp_base_depayload_change_state (GstElement * element,
priv->next_seqnum = -1; priv->next_seqnum = -1;
priv->negotiated = FALSE; priv->negotiated = FALSE;
priv->discont = FALSE; priv->discont = FALSE;
priv->segment_seqnum = GST_SEQNUM_INVALID;
break; break;
case GST_STATE_CHANGE_PAUSED_TO_PLAYING: case GST_STATE_CHANGE_PAUSED_TO_PLAYING:
break; break;