diff options
author | Derek Buitenhuis <derek.buitenhuis@gmail.com> | 2015-11-18 16:40:16 +0000 |
---|---|---|
committer | Derek Buitenhuis <derek.buitenhuis@gmail.com> | 2015-11-18 16:40:16 +0000 |
commit | 3e0daf0716888d166329cffa554893846d6ec3be (patch) | |
tree | 22940eccfbca20d6dba3251cd7410f4fccb830ae | |
parent | e73a4d8491615e751b1229ce1cdc2eee4dfff191 (diff) | |
parent | bef3b1f59f036aba4a5fe599b2480f6bd9e6b280 (diff) | |
download | ffmpeg-3e0daf0716888d166329cffa554893846d6ec3be.tar.gz |
Merge commit 'bef3b1f59f036aba4a5fe599b2480f6bd9e6b280'
* commit 'bef3b1f59f036aba4a5fe599b2480f6bd9e6b280':
movenc: Allow setting start_dts/start_cts before writing actual packets
Merged-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
-rw-r--r-- | libavformat/movenc.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c index 363501b759..372c41f800 100644 --- a/libavformat/movenc.c +++ b/libavformat/movenc.c @@ -4564,9 +4564,6 @@ static int mov_write_single_packet(AVFormatContext *s, AVPacket *pkt) int64_t frag_duration = 0; int size = pkt->size; - if (!pkt->size) - return 0; /* Discard 0 sized packets */ - if (mov->flags & FF_MOV_FLAG_FRAG_DISCONT) { int i; for (i = 0; i < s->nb_streams; i++) @@ -4574,6 +4571,18 @@ static int mov_write_single_packet(AVFormatContext *s, AVPacket *pkt) mov->flags &= ~FF_MOV_FLAG_FRAG_DISCONT; } + if (!pkt->size) { + if (trk->start_dts == AV_NOPTS_VALUE && trk->frag_discont) { + trk->start_dts = pkt->dts; + if (pkt->pts != AV_NOPTS_VALUE) + trk->start_cts = pkt->pts - pkt->dts; + else + trk->start_cts = 0; + } + + return 0; /* Discard 0 sized packets */ + } + if (trk->entry && pkt->stream_index < s->nb_streams) frag_duration = av_rescale_q(pkt->dts - trk->cluster[0].dts, s->streams[pkt->stream_index]->time_base, @@ -4628,7 +4637,8 @@ static int mov_write_packet(AVFormatContext *s, AVPacket *pkt) int i; MOVMuxContext *mov = s->priv_data; - if (!pkt->size) return 0; /* Discard 0 sized packets */ + if (!pkt->size) + return mov_write_single_packet(s, pkt); /* Passthrough. */ /* * Subtitles require special handling. |