Mercurial > libavcodec.hg
changeset 12325:6da1651834cb libavcodec
Simplify fallback to verbatim mode encoding.
author | jbr |
---|---|
date | Sat, 31 Jul 2010 17:23:29 +0000 |
parents | 549a40628c70 |
children | e9efc7168faf |
files | flacenc.c |
diffstat | 1 files changed, 14 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/flacenc.c Sat Jul 31 17:07:24 2010 +0000 +++ b/flacenc.c Sat Jul 31 17:23:29 2010 +0000 @@ -1177,6 +1177,16 @@ } +static int write_frame(FlacEncodeContext *s, uint8_t *frame, int buf_size) +{ + init_put_bits(&s->pb, frame, buf_size); + output_frame_header(s); + output_subframes(s); + output_frame_footer(s); + return put_bits_count(&s->pb) >> 3; +} + + static void update_md5_sum(FlacEncodeContext *s, const int16_t *samples) { #if HAVE_BIGENDIAN @@ -1197,7 +1207,6 @@ FlacEncodeContext *s; const int16_t *samples = data; int out_bytes; - int reencoded=0; s = avctx->priv_data; @@ -1222,25 +1231,14 @@ encode_frame(s); -write_frame: - init_put_bits(&s->pb, frame, buf_size); - output_frame_header(s); - output_subframes(s); - output_frame_footer(s); - out_bytes = put_bits_count(&s->pb) >> 3; + out_bytes = write_frame(s, frame, buf_size); + /* fallback to verbatim mode if the compressed frame is larger than it + would be if encoded uncompressed. */ if (out_bytes > s->max_framesize) { - if (reencoded) { - /* still too large. must be an error. */ - av_log(avctx, AV_LOG_ERROR, "error encoding frame\n"); - return -1; - } - - /* frame too large. use verbatim mode */ s->frame.verbatim_only = 1; encode_frame(s); - reencoded = 1; - goto write_frame; + out_bytes = write_frame(s, frame, buf_size); } s->frame_count++;