Mercurial > libavformat.hg
changeset 2345:b73b443c43d0 libavformat
move header writing into its own function
author | michael |
---|---|
date | Thu, 09 Aug 2007 21:10:11 +0000 |
parents | a7fd892b1a57 |
children | cbcd840cf971 |
files | nutenc.c |
diffstat | 1 files changed, 21 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/nutenc.c Thu Aug 09 21:04:10 2007 +0000 +++ b/nutenc.c Thu Aug 09 21:10:11 2007 +0000 @@ -311,10 +311,28 @@ return 0; } +static void write_headers(NUTContext *nut, ByteIOContext *bc){ + ByteIOContext dyn_bc; + int i; + + put_be64(bc, MAIN_STARTCODE); + url_open_dyn_buf(&dyn_bc); + write_mainheader(nut, &dyn_bc); + put_packet(nut, bc, &dyn_bc, 1); + + for (i=0; i < nut->avf->nb_streams; i++){ + AVCodecContext *codec = nut->avf->streams[i]->codec; + + put_be64(bc, STREAM_STARTCODE); + url_open_dyn_buf(&dyn_bc); + write_streamheader(nut, &dyn_bc, codec, i); + put_packet(nut, bc, &dyn_bc, 1); + } +} + static int write_header(AVFormatContext *s){ NUTContext *nut = s->priv_data; - ByteIOContext *bc = &s->pb, dyn_bc; - AVCodecContext *codec; + ByteIOContext *bc = &s->pb; int i, j; nut->avf= s; @@ -353,20 +371,7 @@ put_buffer(bc, ID_STRING, strlen(ID_STRING)); put_byte(bc, 0); - /* main header */ - put_be64(bc, MAIN_STARTCODE); - url_open_dyn_buf(&dyn_bc); - write_mainheader(nut, &dyn_bc); - put_packet(nut, bc, &dyn_bc, 1); - - for (i=0; i < s->nb_streams; i++){ - codec = s->streams[i]->codec; - - put_be64(bc, STREAM_STARTCODE); - url_open_dyn_buf(&dyn_bc); - write_streamheader(nut, &dyn_bc, codec, i); - put_packet(nut, bc, &dyn_bc, 1); - } + write_headers(nut, bc); put_flush_packet(bc);