diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2010-07-30 20:24:15 +0000 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2010-07-30 20:24:15 +0000 |
commit | 89912b5ff13778527c814b8bcc8a9459d1e8d557 (patch) | |
tree | 932352cb8d51798e3dc3d17c3a786847d59b26a2 | |
parent | 1f1c05b09f7321a8cb065e7d38230dadfa61ef9f (diff) | |
download | ffmpeg-89912b5ff13778527c814b8bcc8a9459d1e8d557.tar.gz |
Combine and simplify output_subframe_constant() and output_subframe_verbatim().
Originally committed as revision 24604 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavcodec/flacenc.c | 36 |
1 files changed, 11 insertions, 25 deletions
diff --git a/libavcodec/flacenc.c b/libavcodec/flacenc.c index 773c3448f4..ef29548c3f 100644 --- a/libavcodec/flacenc.c +++ b/libavcodec/flacenc.c @@ -1101,26 +1101,14 @@ static void output_frame_header(FlacEncodeContext *s) } -static void output_subframe_constant(FlacEncodeContext *s, FlacSubframe *sub) -{ - int32_t res; - - res = sub->residual[0]; - put_sbits(&s->pb, sub->obits, res); -} - - static void output_subframe_verbatim(FlacEncodeContext *s, FlacSubframe *sub) { - int i; - FlacFrame *frame; - int32_t res; + put_sbits(&s->pb, sub->obits, sub->residual[0]); - frame = &s->frame; - - for (i = 0; i < frame->blocksize; i++) { - res = sub->residual[i]; - put_sbits(&s->pb, sub->obits, res); + if (sub->type == FLAC_SUBFRAME_VERBATIM) { + int i; + for (i = 0; i < s->frame.blocksize; i++) + put_sbits(&s->pb, sub->obits, sub->residual[i]); } } @@ -1212,14 +1200,12 @@ static void output_subframes(FlacEncodeContext *s) put_bits(&s->pb, 1, 0); /* no wasted bits */ /* subframe */ - if(sub->type == FLAC_SUBFRAME_CONSTANT) - output_subframe_constant(s, sub); - else if(sub->type == FLAC_SUBFRAME_VERBATIM) - output_subframe_verbatim(s, sub); - else if(sub->type == FLAC_SUBFRAME_FIXED) - output_subframe_fixed(s, sub); - else if(sub->type == FLAC_SUBFRAME_LPC) - output_subframe_lpc(s, sub); + switch (sub->type) { + case FLAC_SUBFRAME_CONSTANT: + case FLAC_SUBFRAME_VERBATIM: output_subframe_verbatim(s, sub); break; + case FLAC_SUBFRAME_FIXED: output_subframe_fixed( s, sub); break; + case FLAC_SUBFRAME_LPC: output_subframe_lpc( s, sub); break; + } } } |