summaryrefslogtreecommitdiff
path: root/libavformat
diff options
context:
space:
mode:
authorDerek Buitenhuis <derek.buitenhuis@gmail.com>2015-11-18 16:40:16 +0000
committerDerek Buitenhuis <derek.buitenhuis@gmail.com>2015-11-18 16:40:16 +0000
commit3e0daf0716888d166329cffa554893846d6ec3be (patch)
tree22940eccfbca20d6dba3251cd7410f4fccb830ae /libavformat
parente73a4d8491615e751b1229ce1cdc2eee4dfff191 (diff)
parentbef3b1f59f036aba4a5fe599b2480f6bd9e6b280 (diff)
Merge commit 'bef3b1f59f036aba4a5fe599b2480f6bd9e6b280'
* commit 'bef3b1f59f036aba4a5fe599b2480f6bd9e6b280': movenc: Allow setting start_dts/start_cts before writing actual packets Merged-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/movenc.c18
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.