mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
qtmux: Don't reset request pad numbering across uses
When reset, don't restart request pad numberings, as request pads can survive across state changes. Only restart at 0 if all request pads are handed back first. https://bugzilla.gnome.org/show_bug.cgi?id=777174
This commit is contained in:
parent
191330cba8
commit
b0e38ed374
1 changed files with 7 additions and 2 deletions
|
@ -557,8 +557,6 @@ gst_qt_mux_reset (GstQTMux * qtmux, gboolean alloc)
|
||||||
qtmux->moov_pos = 0;
|
qtmux->moov_pos = 0;
|
||||||
qtmux->mdat_pos = 0;
|
qtmux->mdat_pos = 0;
|
||||||
qtmux->longest_chunk = GST_CLOCK_TIME_NONE;
|
qtmux->longest_chunk = GST_CLOCK_TIME_NONE;
|
||||||
qtmux->video_pads = 0;
|
|
||||||
qtmux->audio_pads = 0;
|
|
||||||
qtmux->fragment_sequence = 0;
|
qtmux->fragment_sequence = 0;
|
||||||
|
|
||||||
if (qtmux->ftyp) {
|
if (qtmux->ftyp) {
|
||||||
|
@ -4735,6 +4733,13 @@ gst_qt_mux_release_pad (GstElement * element, GstPad * pad)
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_collect_pads_remove_pad (mux->collect, pad);
|
gst_collect_pads_remove_pad (mux->collect, pad);
|
||||||
|
|
||||||
|
if (mux->sinkpads == NULL) {
|
||||||
|
/* No more outstanding request pads, reset our counters */
|
||||||
|
mux->video_pads = 0;
|
||||||
|
mux->audio_pads = 0;
|
||||||
|
mux->subtitle_pads = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstPad *
|
static GstPad *
|
||||||
|
|
Loading…
Reference in a new issue