# HG changeset patch # User conrad # Date 1188951803 0 # Node ID 1226842f8de054bcd3df745af9459f0ba9ed9621 # Parent bc52328116ac71bf5367fd793c14065ac9813800 Calculate the size of a SimpleBlock before writing it so that bytes aren't wasted in writing the size diff -r bc52328116ac -r 1226842f8de0 matroskaenc.c --- a/matroskaenc.c Wed Sep 05 00:23:21 2007 +0000 +++ b/matroskaenc.c Wed Sep 05 00:23:23 2007 +0000 @@ -428,7 +428,6 @@ { MatroskaMuxContext *mkv = s->priv_data; ByteIOContext *pb = &s->pb; - offset_t block; // 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) { @@ -442,12 +441,12 @@ mkv->cluster_pts = pkt->pts; } - block = start_ebml_master(pb, MATROSKA_ID_SIMPLEBLOCK); + put_ebml_id(pb, MATROSKA_ID_SIMPLEBLOCK); + 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_buffer(pb, pkt->data, pkt->size); - end_ebml_master(pb, block); mkv->duration = pkt->pts + pkt->duration; return 0;