aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDerek Buitenhuis <derek.buitenhuis@gmail.com>2015-11-17 14:55:22 +0000
committerDerek Buitenhuis <derek.buitenhuis@gmail.com>2015-11-17 14:55:22 +0000
commit6c9fb32ae47678ca1025d92f30926015d5e8a9ad (patch)
treea94997131ba7bc8074fad5f5be4686e7df7eebce
parentbf6d41d8a233368a2ef7b56cbb762db95c799e2a (diff)
parent09e431b9e3674804172e7b0a0f865b65ec09739a (diff)
downloadffmpeg-6c9fb32ae47678ca1025d92f30926015d5e8a9ad.tar.gz
Merge commit '09e431b9e3674804172e7b0a0f865b65ec09739a'
* commit '09e431b9e3674804172e7b0a0f865b65ec09739a': movenc: Assume streams starting at pts=0 for discontinuous fragments with editlists Merged-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
-rw-r--r--libavformat/movenc.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index 53e3772c61..363501b759 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -4486,10 +4486,18 @@ int ff_mov_write_packet(AVFormatContext *s, AVPacket *pkt)
if (trk->start_dts == AV_NOPTS_VALUE) {
trk->start_dts = pkt->dts;
if (trk->frag_discont) {
- /* Pretend the whole stream started at dts=0, with earlier fragments
- * already written, with a duration summing up to pkt->dts. */
- trk->frag_start = pkt->dts;
- trk->start_dts = 0;
+ if (mov->use_editlist) {
+ /* Pretend the whole stream started at pts=0, with earlier fragments
+ * already written. If the stream started at pts=0, the duration sum
+ * of earlier fragments would have been pkt->pts. */
+ trk->frag_start = pkt->pts;
+ trk->start_dts = pkt->dts - pkt->pts;
+ } else {
+ /* Pretend the whole stream started at dts=0, with earlier fragments
+ * already written, with a duration summing up to pkt->dts. */
+ trk->frag_start = pkt->dts;
+ trk->start_dts = 0;
+ }
trk->frag_discont = 0;
} else if (pkt->dts && mov->moov_written)
av_log(s, AV_LOG_WARNING,