Mercurial > libavformat.hg
changeset 2455:5589c058b0f9 libavformat
Simplify
author | conrad |
---|---|
date | Wed, 05 Sep 2007 00:23:38 +0000 |
parents | ad38b19b0f1a |
children | bceeae973b13 |
files | matroskaenc.c |
diffstat | 1 files changed, 3 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/matroskaenc.c Wed Sep 05 00:23:34 2007 +0000 +++ b/matroskaenc.c Wed Sep 05 00:23:38 2007 +0000 @@ -525,6 +525,7 @@ { MatroskaMuxContext *mkv = s->priv_data; ByteIOContext *pb = &s->pb; + int keyframe = !!(pkt->flags & PKT_FLAG_KEY); // start a new cluster every 5 MB or 5 sec if (url_ftell(pb) > mkv->cluster + 5*1024*1024 || pkt->pts > mkv->cluster_pts + 5000) { @@ -543,10 +544,10 @@ put_ebml_size(pb, pkt->size + 4, 0); put_byte(pb, 0x80 | (pkt->stream_index + 1)); // this assumes stream_index is less than 126 put_be16(pb, pkt->pts - mkv->cluster_pts); - put_byte(pb, !!(pkt->flags & PKT_FLAG_KEY)); + put_byte(pb, keyframe); put_buffer(pb, pkt->data, pkt->size); - if (s->streams[pkt->stream_index]->codec->codec_type == CODEC_TYPE_VIDEO && pkt->flags & PKT_FLAG_KEY) { + if (s->streams[pkt->stream_index]->codec->codec_type == CODEC_TYPE_VIDEO && keyframe) { if (mkv_add_cuepoint(mkv->cues, pkt, mkv->cluster_pos) < 0) return -1; }