aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorJustin Ruggles <justin.ruggles@gmail.com>2011-01-20 21:59:23 +0000
committerMichael Niedermayer <michaelni@gmx.at>2011-01-21 20:36:01 +0100
commita994f861965ce9837d0c7089b8f358c682604729 (patch)
tree9acd9f5764a7512a6a29e18645b043a1662a9f25 /libavcodec
parentaa226b246007d71fd2e3c9ddf8e83d9c85df3317 (diff)
downloadffmpeg-a994f861965ce9837d0c7089b8f358c682604729.tar.gz
iir: change filter type if/else to a switch.
Simplifies error handling and makes it easier to add additional filter types. Signed-off-by: Mans Rullgard <mans@mansr.com> (cherry picked from commit 0361d13cf3956dcf38f31b9df97aca9301cdc86a)
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/iirfilter.c25
1 files changed, 13 insertions, 12 deletions
diff --git a/libavcodec/iirfilter.c b/libavcodec/iirfilter.c
index 085482032b..6133a54055 100644
--- a/libavcodec/iirfilter.c
+++ b/libavcodec/iirfilter.c
@@ -164,6 +164,7 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc,
float stopband, float ripple)
{
FFIIRFilterCoeffs *c;
+ int ret = 0;
if (order <= 0 || order > MAXORDER || cutoff_ratio >= 1.0)
return NULL;
@@ -176,22 +177,22 @@ av_cold struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc,
init_fail);
c->order = order;
- if (filt_type == FF_FILTER_TYPE_BUTTERWORTH) {
- if (butterworth_init_coeffs(avc, c, filt_mode, order, cutoff_ratio,
- stopband)) {
- goto init_fail;
- }
- } else if (filt_type == FF_FILTER_TYPE_BIQUAD) {
- if (biquad_init_coeffs(avc, c, filt_mode, order, cutoff_ratio,
- stopband)) {
- goto init_fail;
- }
- } else {
+ switch (filt_type) {
+ case FF_FILTER_TYPE_BUTTERWORTH:
+ ret = butterworth_init_coeffs(avc, c, filt_mode, order, cutoff_ratio,
+ stopband);
+ break;
+ case FF_FILTER_TYPE_BIQUAD:
+ ret = biquad_init_coeffs(avc, c, filt_mode, order, cutoff_ratio,
+ stopband);
+ break;
+ default:
av_log(avc, AV_LOG_ERROR, "filter type is not currently implemented\n");
goto init_fail;
}
- return c;
+ if (!ret)
+ return c;
init_fail:
ff_iir_filter_free_coeffs(c);