diff options
author | Stefano Sabatini <stefasab@gmail.com> | 2015-03-13 16:45:08 +0100 |
---|---|---|
committer | Stefano Sabatini <stefasab@gmail.com> | 2015-03-20 09:41:32 +0100 |
commit | e6547cce72789d6e650ae3017dcf6370e24f6314 (patch) | |
tree | b286bf322a5f34b4fefcca811b94443a53dee1dd /libavfilter | |
parent | 6b940b8c998cd8205a9cd2ebcedb9e34d0a8af45 (diff) | |
download | ffmpeg-streaming-e6547cce72789d6e650ae3017dcf6370e24f6314.zip ffmpeg-streaming-e6547cce72789d6e650ae3017dcf6370e24f6314.tar.gz |
lavfi/eq: factorize code in process_command()
Diffstat (limited to 'libavfilter')
-rw-r--r-- | libavfilter/vf_eq.c | 66 |
1 files changed, 23 insertions, 43 deletions
diff --git a/libavfilter/vf_eq.c b/libavfilter/vf_eq.c index fe31dc0..520fd46 100644 --- a/libavfilter/vf_eq.c +++ b/libavfilter/vf_eq.c @@ -276,54 +276,34 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) return ff_filter_frame(outlink, out); } +static inline int set_param(AVExpr **pexpr, const char *args, const char *cmd, + void (*set_fn)(EQContext *eq), AVFilterContext *ctx) +{ + EQContext *eq = ctx->priv; + int ret; + if ((ret = set_expr(pexpr, args, cmd, ctx)) < 0) + return ret; + set_fn(eq); + return 0; +} + static int process_command(AVFilterContext *ctx, const char *cmd, const char *args, char *res, int res_len, int flags) { EQContext *eq = ctx->priv; - int ret; - if (!strcmp(cmd, "contrast")) { - ret = set_expr(&eq->contrast_pexpr, args, cmd, ctx); - set_contrast(eq); - return ret; - } - else if (!strcmp(cmd, "brightness")) { - ret = set_expr(&eq->brightness_pexpr, args, cmd, ctx); - set_brightness(eq); - return ret; - } - else if (!strcmp(cmd, "saturation")) { - ret = set_expr(&eq->saturation_pexpr, args, cmd, ctx); - set_saturation(eq); - return ret; - } - else if (!strcmp(cmd, "gamma")) { - ret = set_expr(&eq->gamma_pexpr, args, cmd, ctx); - set_gamma(eq); - return ret; - } - else if (!strcmp(cmd, "gamma_r")) { - ret = set_expr(&eq->gamma_r_pexpr, args, cmd, ctx); - set_gamma(eq); - return ret; - } - else if (!strcmp(cmd, "gamma_g")) { - ret = set_expr(&eq->gamma_g_pexpr, args, cmd, ctx); - set_gamma(eq); - return ret; - } - else if (!strcmp(cmd, "gamma_b")) { - ret = set_expr(&eq->gamma_b_pexpr, args, cmd, ctx); - set_gamma(eq); - return ret; - } - else if (!strcmp(cmd, "gamma_weight")) { - ret = set_expr(&eq->gamma_weight_pexpr, args, cmd, ctx); - set_gamma(eq); - return ret; - } - else - return AVERROR(ENOSYS); +#define SET_PARAM(param_name, set_fn_name) \ + if (!strcmp(cmd, #param_name)) return set_param(&eq->param_name##_pexpr, args, cmd, set_##set_fn_name, ctx); + + SET_PARAM(contrast, contrast) + else SET_PARAM(brightness, brightness) + else SET_PARAM(saturation, saturation) + else SET_PARAM(gamma, gamma) + else SET_PARAM(gamma_r, gamma) + else SET_PARAM(gamma_g, gamma) + else SET_PARAM(gamma_b, gamma) + else SET_PARAM(gamma_weight, gamma) + else return AVERROR(ENOSYS); } static const AVFilterPad eq_inputs[] = { |