diff options
author | nicodvb <nicodvb@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2006-12-18 21:03:59 +0000 |
---|---|---|
committer | nicodvb <nicodvb@b3059339-0415-0410-9bf9-f77b7e298cf2> | 2006-12-18 21:03:59 +0000 |
commit | cf099b21004558223ed3132dc42d37f5f814541e (patch) | |
tree | 1f69aaeaefe8da1ebb4b82bf63be442783c163c0 | |
parent | ac9465059730747f59b07ad00b5daebbbece8c9f (diff) |
muxers now write to output muxer->stream rather than to muxer->file
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@21676 b3059339-0415-0410-9bf9-f77b7e298cf2
-rw-r--r-- | libmpcodecs/ae.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_faac.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_lame.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_lavc.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_pcm.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_toolame.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ae_twolame.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_libdv.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_nuv.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_qtvideo.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_raw.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_vfw.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_x264.c | 1 | ||||
-rw-r--r-- | libmpcodecs/ve_xvid4.c | 1 | ||||
-rw-r--r-- | libmpdemux/muxer.c | 6 | ||||
-rw-r--r-- | libmpdemux/muxer.h | 4 | ||||
-rw-r--r-- | libmpdemux/muxer_avi.c | 106 | ||||
-rw-r--r-- | libmpdemux/muxer_lavf.c | 22 | ||||
-rw-r--r-- | libmpdemux/muxer_mpeg.c | 22 | ||||
-rw-r--r-- | libmpdemux/muxer_rawaudio.c | 3 | ||||
-rw-r--r-- | libmpdemux/muxer_rawvideo.c | 7 | ||||
-rw-r--r-- | mencoder.c | 27 |
22 files changed, 121 insertions, 90 deletions
diff --git a/libmpcodecs/ae.c b/libmpcodecs/ae.c index 85ec1dbda2..e14c8e868b 100644 --- a/libmpcodecs/ae.c +++ b/libmpcodecs/ae.c @@ -7,6 +7,7 @@ #include <math.h> #include "aviheader.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "ae.h" #include "config.h" diff --git a/libmpcodecs/ae_faac.c b/libmpcodecs/ae_faac.c index efd1e8aaff..1f8f423518 100644 --- a/libmpcodecs/ae_faac.c +++ b/libmpcodecs/ae_faac.c @@ -9,6 +9,7 @@ #include "aviheader.h" #include "libaf/af_format.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include <faac.h> #include "ae.h" diff --git a/libmpcodecs/ae_lame.c b/libmpcodecs/ae_lame.c index aa99972570..f7b74a94b7 100644 --- a/libmpcodecs/ae_lame.c +++ b/libmpcodecs/ae_lame.c @@ -8,6 +8,7 @@ #include "mp_msg.h" #include "aviheader.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "help_mp.h" #include "ae_pcm.h" diff --git a/libmpcodecs/ae_lavc.c b/libmpcodecs/ae_lavc.c index be909aa26e..ff0172b662 100644 --- a/libmpcodecs/ae_lavc.c +++ b/libmpcodecs/ae_lavc.c @@ -8,6 +8,7 @@ #include "mp_msg.h" #include "aviheader.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "ae_lavc.h" #include "help_mp.h" diff --git a/libmpcodecs/ae_pcm.c b/libmpcodecs/ae_pcm.c index 02fd04cec7..895fe9623e 100644 --- a/libmpcodecs/ae_pcm.c +++ b/libmpcodecs/ae_pcm.c @@ -9,6 +9,7 @@ #include "aviheader.h" #include "libaf/af_format.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "ae_pcm.h" diff --git a/libmpcodecs/ae_toolame.c b/libmpcodecs/ae_toolame.c index dfc21d92df..aba61db80c 100644 --- a/libmpcodecs/ae_toolame.c +++ b/libmpcodecs/ae_toolame.c @@ -9,6 +9,7 @@ #include "aviheader.h" #include "libaf/af_format.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "ae_toolame.h" #include "libmpdemux/mp3_hdr.h" diff --git a/libmpcodecs/ae_twolame.c b/libmpcodecs/ae_twolame.c index b42b84ff05..0cf25a0504 100644 --- a/libmpcodecs/ae_twolame.c +++ b/libmpcodecs/ae_twolame.c @@ -9,6 +9,7 @@ #include "aviheader.h" #include "libaf/af_format.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" #include "ae_twolame.h" #include "libmpdemux/mp3_hdr.h" diff --git a/libmpcodecs/ve_libdv.c b/libmpcodecs/ve_libdv.c index 48c2b7fd06..ae61b5eb12 100644 --- a/libmpcodecs/ve_libdv.c +++ b/libmpcodecs/ve_libdv.c @@ -13,6 +13,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpcodecs/ve_nuv.c b/libmpcodecs/ve_nuv.c index 4ed2e20dac..b8da531954 100644 --- a/libmpcodecs/ve_nuv.c +++ b/libmpcodecs/ve_nuv.c @@ -12,6 +12,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpcodecs/ve_qtvideo.c b/libmpcodecs/ve_qtvideo.c index e830156836..bddc70d4a6 100644 --- a/libmpcodecs/ve_qtvideo.c +++ b/libmpcodecs/ve_qtvideo.c @@ -25,6 +25,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpcodecs/ve_raw.c b/libmpcodecs/ve_raw.c index 804266b867..878f4feeab 100644 --- a/libmpcodecs/ve_raw.c +++ b/libmpcodecs/ve_raw.c @@ -11,6 +11,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpcodecs/ve_vfw.c b/libmpcodecs/ve_vfw.c index 16458f012c..965bca3487 100644 --- a/libmpcodecs/ve_vfw.c +++ b/libmpcodecs/ve_vfw.c @@ -23,6 +23,7 @@ #include "mp_image.h" #include "vf.h" +#include "stream.h" #include "muxer.h" //===========================================================================// diff --git a/libmpcodecs/ve_x264.c b/libmpcodecs/ve_x264.c index 8fee8d1d8c..c240ad7927 100644 --- a/libmpcodecs/ve_x264.c +++ b/libmpcodecs/ve_x264.c @@ -39,6 +39,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpcodecs/ve_xvid4.c b/libmpcodecs/ve_xvid4.c index 5af21bd7e5..b69103ca0c 100644 --- a/libmpcodecs/ve_xvid4.c +++ b/libmpcodecs/ve_xvid4.c @@ -41,6 +41,7 @@ #include "demuxer.h" #include "stheader.h" +#include "stream.h" #include "muxer.h" #include "img_format.h" diff --git a/libmpdemux/muxer.c b/libmpdemux/muxer.c index 3e7537307a..0bb34f5254 100644 --- a/libmpdemux/muxer.c +++ b/libmpdemux/muxer.c @@ -11,18 +11,18 @@ #include "aviheader.h" #include "ms_hdr.h" -#include "muxer.h" #include "stream.h" +#include "muxer.h" #include "demuxer.h" #include "mp_msg.h" #include "help_mp.h" #include "stheader.h" -muxer_t *muxer_new_muxer(int type,FILE *f){ +muxer_t *muxer_new_muxer(int type,stream_t *stream){ muxer_t* muxer=calloc(1,sizeof(muxer_t)); if(!muxer) return NULL; - muxer->file = f; + muxer->stream = stream; switch (type) { case MUXER_TYPE_MPEG: if(! muxer_init_muxer_mpeg(muxer)) diff --git a/libmpdemux/muxer.h b/libmpdemux/muxer.h index 1dae84ec8e..6770e5d85f 100644 --- a/libmpdemux/muxer.h +++ b/libmpdemux/muxer.h @@ -79,12 +79,12 @@ typedef struct muxer_t{ int muxbuf_num; int muxbuf_skip_buffer; // functions: + stream_t *stream; void (*fix_stream_parameters)(muxer_stream_t *); void (*cont_write_chunk)(muxer_stream_t *,size_t,unsigned int, double dts, double pts); void (*cont_write_header)(struct muxer_t *); void (*cont_write_index)(struct muxer_t *); muxer_stream_t* (*cont_new_stream)(struct muxer_t *,int); - FILE* file; void *priv; } muxer_t; @@ -98,7 +98,7 @@ typedef struct muxbuf_t { unsigned int flags; } muxbuf_t; -muxer_t *muxer_new_muxer(int type,FILE *); +muxer_t *muxer_new_muxer(int type,stream_t *stream); #define muxer_new_stream(muxer,a) muxer->cont_new_stream(muxer,a) #define muxer_stream_fix_parameters(muxer, a) muxer->fix_stream_parameters(a) void muxer_write_chunk(muxer_stream_t *s, size_t len, unsigned int flags, double dts, double pts); diff --git a/libmpdemux/muxer_avi.c b/libmpdemux/muxer_avi.c index 45294325b5..19e3bb6c90 100644 --- a/libmpdemux/muxer_avi.c +++ b/libmpdemux/muxer_avi.c @@ -130,19 +130,19 @@ static muxer_stream_t* avifile_new_stream(muxer_t *muxer,int type){ return s; } -static void write_avi_chunk(FILE *f,unsigned int id,int len,void* data){ +static void write_avi_chunk(stream_t *stream,unsigned int id,int len,void* data){ int le_len = le2me_32(len); int le_id = le2me_32(id); - fwrite(&le_id,4,1,f); - fwrite(&le_len,4,1,f); + stream_write_buffer(stream, &le_id, 4); + stream_write_buffer(stream, &le_len, 4); if(len>0){ if(data){ // DATA - fwrite(data,len,1,f); + stream_write_buffer(stream, data, len); if(len&1){ // padding unsigned char zerobyte=0; - fwrite(&zerobyte,1,1,f); + stream_write_buffer(stream, &zerobyte, 1); } } else { // JUNK @@ -151,20 +151,19 @@ if(len>0){ while(len>0){ int l=strlen(avi_junk_data); if(l>len) l=len; - fwrite(avi_junk_data,l,1,f); + stream_write_buffer(stream, avi_junk_data, l); len-=l; } } } } -static void write_avi_list(FILE *f,unsigned int id,int len); +static void write_avi_list(stream_t *s,unsigned int id,int len); static void avifile_write_standard_index(muxer_t *muxer); static void avifile_odml_new_riff(muxer_t *muxer) { struct avi_stream_info *vsi = muxer->def_v->priv; - FILE *f = muxer->file; uint32_t riff[3]; mp_msg(MSGT_MUXER, MSGL_INFO, "ODML: Starting new RIFF chunk at %dMB.\n", (int)(muxer->file_end/1024/1024)); @@ -174,17 +173,17 @@ static void avifile_odml_new_riff(muxer_t *muxer) vsi->riffofssize+=16; vsi->riffofs=realloc_struct(vsi->riffofs,(vsi->riffofssize+1),sizeof(off_t)); } - vsi->riffofs[vsi->riffofspos] = ftello(f); + vsi->riffofs[vsi->riffofspos] = stream_tell(muxer->stream); /* RIFF/AVIX chunk */ riff[0]=le2me_32(mmioFOURCC('R','I','F','F')); riff[1]=0; riff[2]=le2me_32(mmioFOURCC('A','V','I','X')); - fwrite(riff,12,1,f); + stream_write_buffer(muxer->stream, riff, 12); - write_avi_list(f,listtypeAVIMOVIE,0); + write_avi_list(muxer->stream,listtypeAVIMOVIE,0); - muxer->file_end = ftello(f); + muxer->file_end = stream_tell(muxer->stream); } static void avifile_write_header(muxer_t *muxer); @@ -197,10 +196,10 @@ static void avifile_write_chunk(muxer_stream_t *s,size_t len,unsigned int flags, int paddedlen = len + (len&1); if (s->type == MUXER_TYPE_VIDEO && !s->h.dwSuggestedBufferSize) { - off_t pos=ftell(muxer->file); - fseek(muxer->file, 0, SEEK_SET); + off_t pos=stream_tell(muxer->stream); + stream_seek(muxer->stream, 0); avifile_write_header(muxer); - fseek(muxer->file, pos, SEEK_SET); + stream_seek(muxer->stream, pos); } rifflen = muxer->file_end - vsi->riffofs[vsi->riffofspos] - 8; @@ -238,7 +237,7 @@ static void avifile_write_chunk(muxer_stream_t *s,size_t len,unsigned int flags, ++si->idxpos; // write out the chunk: - write_avi_chunk(muxer->file,s->ckid,len,s->buffer); /* unsigned char */ + write_avi_chunk(muxer->stream,s->ckid,len,s->buffer); /* unsigned char */ if (len > s->h.dwSuggestedBufferSize){ s->h.dwSuggestedBufferSize = len; @@ -248,7 +247,7 @@ static void avifile_write_chunk(muxer_stream_t *s,size_t len,unsigned int flags, muxer->file_end += 8 + paddedlen; } -static void write_avi_list(FILE *f,unsigned int id,int len){ +static void write_avi_list(stream_t *stream,unsigned int id,int len){ unsigned int list_id=FOURCC_LIST; int le_len; int le_id; @@ -256,9 +255,9 @@ static void write_avi_list(FILE *f,unsigned int id,int len){ list_id = le2me_32(list_id); le_len = le2me_32(len); le_id = le2me_32(id); - fwrite(&list_id,4,1,f); - fwrite(&le_len,4,1,f); - fwrite(&le_id,4,1,f); + stream_write_buffer(stream, &list_id, 4); + stream_write_buffer(stream, &le_len, 4); + stream_write_buffer(stream, &le_id, 4); } #define WFSIZE(wf) (sizeof(WAVEFORMATEX)+(wf)->cbSize) @@ -269,7 +268,6 @@ static void avifile_write_header(muxer_t *muxer){ unsigned int i; unsigned int hdrsize; muxer_info_t info[16]; - FILE *f = muxer->file; VideoPropHeader vprp; uint32_t aspect = avi_aspect(muxer->def_v); struct avi_stream_info *vsi = muxer->def_v->priv; @@ -306,17 +304,17 @@ static void avifile_write_header(muxer_t *muxer){ rifflen = vsi->riffofs[i+1] - vsi->riffofs[i] - 8; movilen = le2me_32(rifflen - 12); rifflen = le2me_32(rifflen); - fseeko(f, vsi->riffofs[i]+4, SEEK_SET); - fwrite(&rifflen,4,1,f); + stream_seek(muxer->stream, vsi->riffofs[i]+4); + stream_write_buffer(muxer->stream,&rifflen,4); /* fixup movi length */ if (i > 0) { - fseeko(f, vsi->riffofs[i]+16, SEEK_SET); - fwrite(&movilen,4,1,f); + stream_seek(muxer->stream, vsi->riffofs[i]+16); + stream_write_buffer(muxer->stream,&movilen,4); } } - fseeko(f, 12, SEEK_SET); + stream_seek(muxer->stream, 12); } else { // RIFF header: riff[0]=mmioFOURCC('R','I','F','F'); @@ -325,7 +323,7 @@ static void avifile_write_header(muxer_t *muxer){ riff[0]=le2me_32(riff[0]); riff[1]=le2me_32(riff[1]); riff[2]=le2me_32(riff[2]); - fwrite(&riff,12,1,f); + stream_write_buffer(muxer->stream,&riff,12); } // update AVI header: @@ -370,10 +368,10 @@ static void avifile_write_header(muxer_t *muxer){ hdrsize += 32 + 16*si->superidxsize; //indx } } - write_avi_list(f,listtypeAVIHEADER,hdrsize); + write_avi_list(muxer->stream,listtypeAVIHEADER,hdrsize); le2me_MainAVIHeader(&muxer->avih); - write_avi_chunk(f,ckidAVIMAINHDR,sizeof(muxer->avih),&muxer->avih); /* MainAVIHeader */ + write_avi_chunk(muxer->stream,ckidAVIMAINHDR,sizeof(muxer->avih),&muxer->avih); /* MainAVIHeader */ le2me_MainAVIHeader(&muxer->avih); // stream headers: @@ -416,9 +414,9 @@ static void avifile_write_header(muxer_t *muxer){ break; } - write_avi_list(f,listtypeSTREAMHEADER,hdrsize); + write_avi_list(muxer->stream,listtypeSTREAMHEADER,hdrsize); le2me_AVIStreamHeader(&s->h); - write_avi_chunk(f,ckidSTREAMHEADER,sizeof(s->h),&s->h); /* AVISTreamHeader */ // strh + write_avi_chunk(muxer->stream,ckidSTREAMHEADER,sizeof(s->h),&s->h); /* AVISTreamHeader */ // strh le2me_AVIStreamHeader(&s->h); switch(s->type){ @@ -426,7 +424,7 @@ static void avifile_write_header(muxer_t *muxer){ { int biSize=s->bih->biSize; le2me_BITMAPINFOHEADER(s->bih); - write_avi_chunk(f,ckidSTREAMFORMAT,biSize,s->bih); /* BITMAPINFOHEADER */ + write_avi_chunk(muxer->stream,ckidSTREAMFORMAT,biSize,s->bih); /* BITMAPINFOHEADER */ le2me_BITMAPINFOHEADER(s->bih); if (aspect != 0) { @@ -434,7 +432,7 @@ static void avifile_write_header(muxer_t *muxer){ le2me_VideoPropHeader(&vprp); le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[0]); le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[1]); - write_avi_chunk(f,mmioFOURCC('v','p','r','p'), + write_avi_chunk(muxer->stream,mmioFOURCC('v','p','r','p'), sizeof(VideoPropHeader) - sizeof(VIDEO_FIELD_DESC)*(2-fields), &vprp); /* Video Properties Header */ @@ -445,7 +443,7 @@ static void avifile_write_header(muxer_t *muxer){ { int wfsize = WFSIZE(s->wf); le2me_WAVEFORMATEX(s->wf); - write_avi_chunk(f,ckidSTREAMFORMAT,wfsize,s->wf); /* WAVEFORMATEX */ + write_avi_chunk(muxer->stream,ckidSTREAMFORMAT,wfsize,s->wf); /* WAVEFORMATEX */ le2me_WAVEFORMATEX(s->wf); } break; @@ -462,7 +460,7 @@ static void avifile_write_header(muxer_t *muxer){ idxhdr[6] = 0; idxhdr[7] = 0; - fwrite(idxhdr,sizeof(idxhdr),1,f); + stream_write_buffer(muxer->stream,idxhdr,sizeof(idxhdr)); for (j=0; j<n; j++) { struct avi_odmlsuperidx_entry *entry = &si->superidx[j]; unsigned int data[4]; @@ -470,7 +468,7 @@ static void avifile_write_header(muxer_t *muxer){ data[1] = le2me_32(entry->ofs >> 32); data[2] = le2me_32(entry->len); data[3] = le2me_32(entry->duration); - fwrite(data,sizeof(data),1,f); + stream_write_buffer(muxer->stream,data,sizeof(data)); } } } @@ -479,8 +477,8 @@ static void avifile_write_header(muxer_t *muxer){ if (isodml) { memset(dmlh, 0, sizeof(dmlh)); dmlh[0] = le2me_32(muxer->avih.dwTotalFrames); - write_avi_list(f,mmioFOURCC('o','d','m','l'),sizeof(dmlh)+8); - write_avi_chunk(f,mmioFOURCC('d','m','l','h'),sizeof(dmlh),dmlh); + write_avi_list(muxer->stream,mmioFOURCC('o','d','m','l'),sizeof(dmlh)+8); + write_avi_chunk(muxer->stream,mmioFOURCC('d','m','l','h'),sizeof(dmlh),dmlh); } // ============= INFO =============== @@ -527,27 +525,27 @@ info[i].id=0; } // write infos: if (hdrsize!=0){ - write_avi_list(f,mmioFOURCC('I','N','F','O'),hdrsize); + write_avi_list(muxer->stream,mmioFOURCC('I','N','F','O'),hdrsize); for(i=0;info[i].id!=0;i++) if(info[i].text){ - write_avi_chunk(f,info[i].id,strlen(info[i].text)+1,info[i].text); + write_avi_chunk(muxer->stream,info[i].id,strlen(info[i].text)+1,info[i].text); } } // JUNK: - write_avi_chunk(f,ckidAVIPADDING,MOVIALIGN-(ftello(f)%MOVIALIGN)-8,NULL); /* junk */ + write_avi_chunk(muxer->stream,ckidAVIPADDING,MOVIALIGN-(stream_tell(muxer->stream)%MOVIALIGN)-8,NULL); /* junk */ if (!isodml) { // 'movi' header: - write_avi_list(f,listtypeAVIMOVIE,muxer->movi_end-ftello(f)-12); + write_avi_list(muxer->stream,listtypeAVIMOVIE,muxer->movi_end-stream_tell(muxer->stream)-12); } else { - if (ftello(f) != MOVIALIGN) { + if (stream_tell(muxer->stream) != MOVIALIGN) { mp_msg(MSGT_MUXER, MSGL_ERR, "Opendml superindex is too big for reserved space!\n"); - mp_msg(MSGT_MUXER, MSGL_ERR, "Expected filepos %d, real filepos %ld, missing space %ld\n", MOVIALIGN, ftell(muxer->file), ftell(muxer->file)-MOVIALIGN); + mp_msg(MSGT_MUXER, MSGL_ERR, "Expected filepos %d, real filepos %ld, missing space %ld\n", MOVIALIGN, stream_tell(muxer->stream), stream_tell(muxer->stream)-MOVIALIGN); mp_msg(MSGT_MUXER, MSGL_ERR, "Try increasing MOVIALIGN in libmpdemux/muxer_avi.c\n"); } - write_avi_list(f,listtypeAVIMOVIE,muxer->movi_end-ftello(f)-12); + write_avi_list(muxer->stream,listtypeAVIMOVIE,muxer->movi_end-stream_tell(muxer->stream)-12); } - muxer->movi_start=ftello(muxer->file); - if (muxer->file_end == 0) muxer->file_end = ftello(muxer->file); + muxer->movi_start=stream_tell(muxer->stream); + if (muxer->file_end == 0) muxer->file_end = stream_tell(muxer->stream); } static void avifile_odml_write_index(muxer_t *muxer){ @@ -619,36 +617,36 @@ static void avifile_odml_write_index(muxer_t *muxer){ idxhdr[7] = 0; /* unused */ si->superidx[j].len = 32 + 8*k; - si->superidx[j].ofs = ftello(muxer->file); + si->superidx[j].ofs = stream_tell(muxer->stream); si->superidx[j].duration = duration; - fwrite(idxhdr,sizeof(idxhdr),1,muxer->file); + stream_write_buffer(muxer->stream, idxhdr,sizeof(idxhdr)); for (k=0; k<entries_per_subidx && idxpos<si->idxpos; k++) { unsigned int entry[2]; entry[0] = le2me_32(si->idx[idxpos].ofs - start); entry[1] = le2me_32(si->idx[idxpos].len | si->idx[idxpos].flags); idxpos++; - fwrite(entry,sizeof(entry),1,muxer->file); + stream_write_buffer(muxer->stream, entry, sizeof(entry)); } } } - muxer->file_end=ftello(muxer->file); + muxer->file_end=stream_tell(muxer->stream); } static void avifile_write_standard_index(muxer_t *muxer){ - muxer->movi_end=ftello(muxer->file); + muxer->movi_end=stream_tell(muxer->stream); if(muxer->idx && muxer->idx_pos>0){ int i; // fixup index entries: // for(i=0;i<muxer->idx_pos;i++) muxer->idx[i].dwChunkOffset-=muxer->movi_start-4; // write index chunk: for (i=0; i<muxer->idx_pos; i++) le2me_AVIINDEXENTRY((&muxer->idx[i])); - write_avi_chunk(muxer->file,ckidAVINEWINDEX,16*muxer->idx_pos,muxer->idx); /* AVIINDEXENTRY */ + write_avi_chunk(muxer->stream,ckidAVINEWINDEX,16*muxer->idx_pos,muxer->idx); /* AVIINDEXENTRY */ for (i=0; i<muxer->idx_pos; i++) le2me_AVIINDEXENTRY((&muxer->idx[i])); muxer->avih.dwFlags|=AVIF_HASINDEX; } - muxer->file_end=ftello(muxer->file); + muxer->file_end=stream_tell(muxer->stream); } static void avifile_write_index(muxer_t *muxer){ diff --git a/libmpdemux/muxer_lavf.c b/libmpdemux/muxer_lavf.c index e06ff6abe6..17cc80d00a 100644 --- a/libmpdemux/muxer_lavf.c +++ b/libmpdemux/muxer_lavf.c @@ -12,8 +12,8 @@ #include "aviheader.h" #include "ms_hdr.h" -#include "muxer.h" #include "stream.h" +#include "muxer.h" #include "demuxer.h" #include "stheader.h" #include "m_option.h" @@ -89,14 +89,30 @@ static int mp_read(URLContext *h, unsigned char *buf, int size) static int mp_write(URLContext *h, unsigned char *buf, int size) { muxer_t *muxer = (muxer_t*)h->priv_data; - return fwrite(buf, 1, size, muxer->file); + return stream_write_buffer(muxer->stream, buf, size); } static offset_t mp_seek(URLContext *h, offset_t pos, int whence) { muxer_t *muxer = (muxer_t*)h->priv_data; + if(whence == SEEK_CUR) + { + off_t cur = stream_tell(muxer->stream); + if(cur == -1) + return -1; + pos += cur; + } + else if(whence == SEEK_END) + { + off_t size=0; + if(stream_control(muxer->stream, STREAM_CTRL_GET_SIZE, &size) == STREAM_UNSUPORTED || size < pos) + return -1; + pos = size - pos; + } mp_msg(MSGT_MUXER, MSGL_DBG2, "SEEK %"PRIu64"\n", (int64_t)pos); - return fseeko(muxer->file, pos, whence); + if(!stream_seek(muxer->stream, pos)) + return -1; + return 0; } diff --git a/libmpdemux/muxer_mpeg.c b/libmpdemux/muxer_mpeg.c index a96fc9989a..35d32900ab 100644 --- a/libmpdemux/muxer_mpeg.c +++ b/libmpdemux/muxer_mpeg.c @@ -12,8 +12,8 @@ #include "aviheader.h" #include "ms_hdr.h" -#include "muxer.h" #include "stream.h" +#include "muxer.h" #include "demuxer.h" #include "stheader.h" #include "m_option.h" @@ -748,7 +748,7 @@ static void write_pes_padding(uint8_t *buff, uint16_t len) memset(&buff[6], 0xff, len - 6); } -static void write_psm_block(muxer_t *muxer, FILE *f) +static void write_psm_block(muxer_t *muxer, stream_t *stream) { uint16_t offset, stuffing_len; muxer_priv_t *priv = (muxer_priv_t *) muxer->priv; @@ -763,7 +763,7 @@ static void write_psm_block(muxer_t *muxer, FILE *f) write_pes_padding(&buff[offset], stuffing_len); offset += stuffing_len; } - fwrite(buff, offset, 1, f); + stream_write_buffer(stream, buff, offset); priv->headers_size += offset; } @@ -824,7 +824,7 @@ static uint32_t calc_pes_hlen(int format, muxer_headers_t *h, muxer_priv_t *priv } -static int write_mpeg_pack(muxer_t *muxer, muxer_stream_t *s, FILE *f, int isoend) +static int write_mpeg_pack(muxer_t *muxer, muxer_stream_t *s, stream_t *stream, int isoend) { size_t tot, offset; muxer_priv_t *priv; @@ -842,7 +842,7 @@ static int write_mpeg_pack(muxer_t *muxer, muxer_stream_t *s, FILE *f, int isoen buff[offset + 2] = 1; buff[offset + 3] = 0xb9; - fwrite(buff, priv->packet_size, 1, f); + stream_write_buffer(stream, buff, priv->packet_size); return 1; } else //FAKE DVD NAV PACK @@ -863,7 +863,7 @@ static int write_mpeg_pack(muxer_t *muxer, muxer_stream_t *s, FILE *f, int isoen offset += stuffing_len; } - fwrite(buff, offset, 1, f); + stream_write_buffer(stream, buff, offset); priv->headers_size += offset; tot = offset; muxer->movi_end += tot; @@ -1240,7 +1240,7 @@ static int fill_packet(muxer_t *muxer, muxer_stream_t *s, int finalize) spriv->size += len; if(dvd_pack && (spriv->pack_offset == priv->packet_size)) - write_mpeg_pack(muxer, NULL, muxer->file, 0); //insert fake Nav Packet + write_mpeg_pack(muxer, NULL, muxer->stream, 0); //insert fake Nav Packet if(n > 0) remove_frames(spriv, n); @@ -1259,7 +1259,7 @@ static int fill_packet(muxer_t *muxer, muxer_stream_t *s, int finalize) spriv->pack_offset += diff; } - fwrite(spriv->pack, spriv->pack_offset, 1, muxer->file); + stream_write_buffer(muxer->stream, spriv->pack, spriv->pack_offset); priv->headers_size += spriv->pack_offset - len; priv->data_size += len; @@ -2351,7 +2351,7 @@ static void mpegfile_write_chunk(muxer_stream_t *s,size_t len,unsigned int flags spriv->psm_fixed = 1; priv->psm_streams_cnt++; if((priv->psm_streams_cnt == muxer->num_videos + muxer->num_audios) && priv->use_psm) - write_psm_block(muxer, muxer->file); + write_psm_block(muxer, muxer->stream); } flush_buffers(muxer, 0); @@ -2374,7 +2374,7 @@ static void mpegfile_write_index(muxer_t *muxer) while(flush_buffers(muxer, 0) > 0); flush_buffers(muxer, 1); if(priv->is_genmpeg1 || priv->is_genmpeg2) - write_mpeg_pack(muxer, NULL, muxer->file, 1); //insert fake Nav Packet + write_mpeg_pack(muxer, NULL, muxer->stream, 1); //insert fake Nav Packet mp_msg(MSGT_MUXER, MSGL_INFO, "\nOverhead: %.3lf%% (%"PRIu64" / %"PRIu64")\n", 100.0 * (double)priv->headers_size / (double)priv->data_size, priv->headers_size, priv->data_size); } @@ -2400,7 +2400,7 @@ static void mpegfile_write_header(muxer_t *muxer) //write the first system header only for generic mpeg1/2 muxes, and only when we have collected all necessary infos if(priv->is_genmpeg1 || priv->is_genmpeg2 || ((priv->is_xvcd || priv->is_xsvcd) && (priv->headers_cnt == 1))) { - write_mpeg_pack(muxer, NULL, muxer->file, 0); + write_mpeg_pack(muxer, NULL, muxer->stream, 0); priv->update_system_header = 0; } diff --git a/libmpdemux/muxer_rawaudio.c b/libmpdemux/muxer_rawaudio.c index a7132d227b..f839707380 100644 --- a/libmpdemux/muxer_rawaudio.c +++ b/libmpdemux/muxer_rawaudio.c @@ -9,6 +9,7 @@ #include "aviheader.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" static muxer_stream_t* rawaudiofile_new_stream(muxer_t *muxer,int type){ @@ -50,7 +51,7 @@ static void rawaudiofile_write_chunk(muxer_stream_t *s,size_t len,unsigned int f // write out the chunk: if (s->type==MUXER_TYPE_AUDIO) - fwrite(s->buffer,len,1,muxer->file); + stream_write_buffer(muxer->stream, s->buffer, len); } static void rawaudiofile_write_header(muxer_t *muxer){ diff --git a/libmpdemux/muxer_rawvideo.c b/libmpdemux/muxer_rawvideo.c index b12a0ef1ac..8f2f4b29f3 100644 --- a/libmpdemux/muxer_rawvideo.c +++ b/libmpdemux/muxer_rawvideo.c @@ -14,6 +14,7 @@ #include "aviheader.h" #include "ms_hdr.h" +#include "stream.h" #include "muxer.h" static muxer_stream_t* rawvideofile_new_stream(muxer_t *muxer,int type){ @@ -39,11 +40,11 @@ static muxer_stream_t* rawvideofile_new_stream(muxer_t *muxer,int type){ return s; } -static void write_rawvideo_chunk(FILE *f,int len,void* data){ +static void write_rawvideo_chunk(stream_t *stream,int len,void* data){ if(len>0){ if(data){ // DATA - fwrite(data,len,1,f); + stream_write_buffer(stream,data,len); } } } @@ -53,7 +54,7 @@ static void rawvideofile_write_chunk(muxer_stream_t *s,size_t len,unsigned int f // write out the chunk: if (s->type == MUXER_TYPE_VIDEO) - write_rawvideo_chunk(muxer->file,len,s->buffer); /* unsigned char */ + write_rawvideo_chunk(muxer->stream,len,s->buffer); /* unsigned char */ // if((unsigned int)len>s->h.dwSuggestedBufferSize) s->h.dwSuggestedBufferSize=len; diff --git a/mencoder.c b/mencoder.c index ecec996a6d..449111a5aa 100644 --- a/mencoder.c +++ b/mencoder.c @@ -359,13 +359,13 @@ static void exit_sighandler(int x){ } static muxer_t* muxer=NULL; -static FILE* muxer_f=NULL; extern void print_wave_header(WAVEFORMATEX *h, int verbose_level); int main(int argc,char* argv[]){ stream_t* stream=NULL; +stream_t* ostream=NULL; demuxer_t* demuxer=NULL; stream_t* stream2=NULL; demuxer_t* demuxer2=NULL; @@ -402,6 +402,7 @@ int decoded_frameno=0; int next_frameno=-1; int curfile=0; int new_srate=0; +int fformat=DEMUXER_TYPE_UNKNOWN; unsigned int timer_start=0; ao_data_t ao_data = {0,0,0,0,OUTBURST,-1,0}; @@ -713,17 +714,13 @@ vo_spudec=spudec_new_scaled(stream->type==STREAMTYPE_DVD?((dvd_priv_t *)(stream- // Apply current settings for forced subs spudec_set_forced_subs_only(vo_spudec,forced_subs_only); -// set up output file: -if(!strcmp(out_filename, "-")) - muxer_f=stdout; -else - muxer_f=fopen(out_filename,"wb"); -if(!muxer_f) { +ostream = open_output_stream(out_filename, 0); +if(!ostream) { mp_msg(MSGT_MENCODER, MSGL_FATAL, MSGTR_CannotOpenOutputFile, out_filename); mencoder_exit(1,NULL); } -muxer=muxer_new_muxer(out_file_format,muxer_f); +muxer=muxer_new_muxer(out_file_format,ostream); if(!muxer) { mp_msg(MSGT_MENCODER, MSGL_FATAL, MSGTR_CannotInitializeMuxer); mencoder_exit(1,NULL); @@ -1092,7 +1089,7 @@ while(!at_eof){ float v_pts=0; int skip_flag=0; // 1=skip -1=duplicate - if((end_at.type == END_AT_SIZE && end_at.pos <= ftello(muxer_f)) || + if((end_at.type == END_AT_SIZE && end_at.pos <= stream_tell(muxer->stream)) || (end_at.type == END_AT_TIME && end_at.pos < mux_v->timer)) break; @@ -1451,7 +1448,7 @@ if(sh_audio && !demuxer2){ mux_v->timer, decoded_frameno, (int)(p*100), (t>1) ? (int)(decoded_frameno/t+0.5) : 0, (p>0.001) ? (int)((t/p-t)/60) : 0, - (p>0.001) ? (int)(ftello(muxer_f)/p/1024/1024) : 0, + (p>0.001) ? (int)(stream_tell(muxer->stream)/p/1024/1024) : 0, v_pts_corr, (mux_v->timer>1) ? (int)(mux_v->size/mux_v->timer/125) : 0, (mux_a && mux_a->timer>1) ? (int)(mux_a->size/mux_a->timer/125) : 0, @@ -1463,7 +1460,7 @@ if(sh_audio && !demuxer2){ mux_v->timer, decoded_frameno, (int)(p*100), (t>1) ? (float)(decoded_frameno/t) : 0, (p>0.001) ? (int)((t/p-t)/60) : 0, - (p>0.001) ? (int)(ftello(muxer_f)/p/1024/1024) : 0, + (p>0.001) ? (int)(stream_tell(muxer->stream)/p/1024/1024) : 0, v_pts_corr, (mux_v->timer>1) ? (int)(mux_v->size/mux_v->timer/125) : 0, (mux_a && mux_a->timer>1) ? (int)(mux_a->size/mux_a->timer/125) : 0 @@ -1506,10 +1503,12 @@ if(sh_audio && !demuxer2){ frame_data = (s_frame_data){ .start = NULL, .in_size = 0, .frame_time = 0., .already_read = 0 }; +#if 0 if(ferror(muxer_f)) { mp_msg(MSGT_MENCODER,MSGL_FATAL,MSGTR_ErrorWritingFile, out_filename); mencoder_exit(1, NULL); } +#endif } // while(!at_eof) @@ -1549,13 +1548,15 @@ if(aencoder) aencoder->fixup(aencoder); if (muxer->cont_write_index) muxer_write_index(muxer); -muxer_f_size=ftello(muxer_f); -fseek(muxer_f,0,SEEK_SET); +muxer_f_size=stream_tell(muxer->stream); +stream_seek(muxer->stream,0); if (muxer->cont_write_header) muxer_write_header(muxer); // update header +#if 0 if(ferror(muxer_f) || fclose(muxer_f) != 0) { mp_msg(MSGT_MENCODER,MSGL_FATAL,MSGTR_ErrorWritingFile, out_filename); mencoder_exit(1, NULL); } +#endif if(vobsub_writer) vobsub_out_close(vobsub_writer); |