[FFmpeg-cvslog] r22639 - in trunk/libavformat: Makefile flacenc.c flacenc.h
Måns Rullgård
mans
Mon Mar 22 23:43:32 CET 2010
jbr <subversion at mplayerhq.hu> writes:
> Author: jbr
> Date: Mon Mar 22 22:58:38 2010
> New Revision: 22639
>
> Log:
> Move ff_flac_write_header() to flacenc.h, which removes the Matroska muxer's
> dependency on flacenc.o and fixes the unnecessary dependency on vorbiscomment.o.
>
> Modified:
> trunk/libavformat/Makefile
> trunk/libavformat/flacenc.c
> trunk/libavformat/flacenc.h
>
> Modified: trunk/libavformat/flacenc.h
> ==============================================================================
> --- trunk/libavformat/flacenc.h Mon Mar 22 22:12:31 2010 (r22638)
> +++ trunk/libavformat/flacenc.h Mon Mar 22 22:58:38 2010 (r22639)
> @@ -22,9 +22,32 @@
> #ifndef AVFORMAT_FLACENC_H
> #define AVFORMAT_FLACENC_H
>
> +#include "libavcodec/flac.h"
> +#include "libavcodec/bytestream.h"
> #include "avformat.h"
>
> -int ff_flac_write_header(ByteIOContext *pb, AVCodecContext *codec,
> - int last_block);
> +static int ff_flac_write_header(ByteIOContext *pb, AVCodecContext *codec,
> + int last_block)
> +{
> + uint8_t header[8] = {
> + 0x66, 0x4C, 0x61, 0x43, 0x00, 0x00, 0x00, 0x22
> + };
> + uint8_t *streaminfo;
> + enum FLACExtradataFormat format;
> +
> + header[4] = last_block ? 0x80 : 0x00;
> + if (!ff_flac_is_extradata_valid(codec, &format, &streaminfo))
> + return -1;
> +
> + /* write "fLaC" stream marker and first metadata block header if needed */
> + if (format == FLAC_EXTRADATA_FORMAT_STREAMINFO) {
> + put_buffer(pb, header, 8);
> + }
> +
> + /* write STREAMINFO or full header */
> + put_buffer(pb, codec->extradata, codec->extradata_size);
> +
> + return 0;
> +}
Why are you putting this function in a header file? That only results
in duplicated code. If just this function needs to be shared, put it
alone in a C file. Files are cheap.
--
M?ns Rullg?rd
mans at mansr.com
More information about the ffmpeg-cvslog
mailing list