aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/flacenc.c
diff options
context:
space:
mode:
authorJustin Ruggles <justin.ruggles@gmail.com>2010-07-30 20:24:15 +0000
committerJustin Ruggles <justin.ruggles@gmail.com>2010-07-30 20:24:15 +0000
commit89912b5ff13778527c814b8bcc8a9459d1e8d557 (patch)
tree932352cb8d51798e3dc3d17c3a786847d59b26a2 /libavcodec/flacenc.c
parent1f1c05b09f7321a8cb065e7d38230dadfa61ef9f (diff)
downloadffmpeg-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
Diffstat (limited to 'libavcodec/flacenc.c')
-rw-r--r--libavcodec/flacenc.c36
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;
+ }
}
}