mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
isomp4: Only set moov header into streamheader at EOS
Only update the moov header into the caps if it's the finalised moov at EOS time. Avoids posting a bogus moov at startup and repeated updates in robust-recording mode
This commit is contained in:
parent
c16c381a89
commit
3e17cd8acb
1 changed files with 9 additions and 5 deletions
|
@ -1824,6 +1824,10 @@ gst_qt_mux_send_moov (GstQTMux * qtmux, guint64 * _offset,
|
||||||
goto too_small_reserved;
|
goto too_small_reserved;
|
||||||
buf = _gst_buffer_new_take_data (data, offset);
|
buf = _gst_buffer_new_take_data (data, offset);
|
||||||
GST_DEBUG_OBJECT (qtmux, "Pushing moov atoms");
|
GST_DEBUG_OBJECT (qtmux, "Pushing moov atoms");
|
||||||
|
|
||||||
|
/* If at EOS, this is the final moov, put in the streamheader
|
||||||
|
* (apparently used by a flumotion util) */
|
||||||
|
if (qtmux->state == GST_QT_MUX_STATE_EOS)
|
||||||
gst_qt_mux_set_header_on_caps (qtmux, buf);
|
gst_qt_mux_set_header_on_caps (qtmux, buf);
|
||||||
ret = gst_qt_mux_send_buffer (qtmux, buf, _offset, mind_fast);
|
ret = gst_qt_mux_send_buffer (qtmux, buf, _offset, mind_fast);
|
||||||
|
|
||||||
|
@ -2381,7 +2385,7 @@ gst_qt_mux_update_edit_lists (GstQTMux * qtmux)
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstFlowReturn
|
static GstFlowReturn
|
||||||
gst_qt_mux_stop_file (GstQTMux * qtmux, gboolean at_eos)
|
gst_qt_mux_stop_file (GstQTMux * qtmux)
|
||||||
{
|
{
|
||||||
gboolean ret = GST_FLOW_OK;
|
gboolean ret = GST_FLOW_OK;
|
||||||
guint64 offset = 0, size = 0;
|
guint64 offset = 0, size = 0;
|
||||||
|
@ -2390,7 +2394,7 @@ gst_qt_mux_stop_file (GstQTMux * qtmux, gboolean at_eos)
|
||||||
GST_DEBUG_OBJECT (qtmux, "Updating remaining values and sending last data");
|
GST_DEBUG_OBJECT (qtmux, "Updating remaining values and sending last data");
|
||||||
|
|
||||||
/* pushing last buffers for each pad */
|
/* pushing last buffers for each pad */
|
||||||
if (at_eos && (ret = gst_qt_mux_send_last_buffers (qtmux)) != GST_FLOW_OK)
|
if ((ret = gst_qt_mux_send_last_buffers (qtmux)) != GST_FLOW_OK)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
if (qtmux->mux_mode == GST_QT_MUX_MODE_FRAGMENTED_STREAMABLE) {
|
if (qtmux->mux_mode == GST_QT_MUX_MODE_FRAGMENTED_STREAMABLE) {
|
||||||
|
@ -3174,7 +3178,8 @@ gst_qt_mux_handle_buffer (GstCollectPads * pads, GstCollectData * cdata,
|
||||||
GST_PAD_NAME (best_pad->collect.pad), GST_TIME_ARGS (best_time));
|
GST_PAD_NAME (best_pad->collect.pad), GST_TIME_ARGS (best_time));
|
||||||
ret = gst_qt_mux_add_buffer (qtmux, best_pad, buf);
|
ret = gst_qt_mux_add_buffer (qtmux, best_pad, buf);
|
||||||
} else {
|
} else {
|
||||||
ret = gst_qt_mux_stop_file (qtmux, TRUE);
|
qtmux->state = GST_QT_MUX_STATE_EOS;
|
||||||
|
ret = gst_qt_mux_stop_file (qtmux);
|
||||||
if (ret == GST_FLOW_OK) {
|
if (ret == GST_FLOW_OK) {
|
||||||
GST_DEBUG_OBJECT (qtmux, "Pushing eos");
|
GST_DEBUG_OBJECT (qtmux, "Pushing eos");
|
||||||
gst_pad_push_event (qtmux->srcpad, gst_event_new_eos ());
|
gst_pad_push_event (qtmux->srcpad, gst_event_new_eos ());
|
||||||
|
@ -3183,7 +3188,6 @@ gst_qt_mux_handle_buffer (GstCollectPads * pads, GstCollectData * cdata,
|
||||||
GST_WARNING_OBJECT (qtmux, "Failed to stop file: %s",
|
GST_WARNING_OBJECT (qtmux, "Failed to stop file: %s",
|
||||||
gst_flow_get_name (ret));
|
gst_flow_get_name (ret));
|
||||||
}
|
}
|
||||||
qtmux->state = GST_QT_MUX_STATE_EOS;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in a new issue