[FFmpeg-devel] [PATCH] lavfi/volume_justin: add support to option shorthands and introspection
Stefano Sabatini
stefasab at gmail.com
Sat Dec 8 15:36:23 CET 2012
On date Saturday 2012-12-08 15:19:38 +0100, Clément Bœsch encoded:
> On Sat, Dec 08, 2012 at 12:10:02PM +0100, Stefano Sabatini wrote:
> > TODO: bump micro
> > ---
> > doc/filters.texi | 8 +++++++-
> > libavfilter/af_volume_justin.c | 28 +++++++++++-----------------
> > 2 files changed, 18 insertions(+), 18 deletions(-)
> >
> > diff --git a/doc/filters.texi b/doc/filters.texi
> > index 9e0c041..cb2c899 100644
> > --- a/doc/filters.texi
> > +++ b/doc/filters.texi
> > @@ -923,7 +923,13 @@ raising it by +5 dB causes clipping for 6 samples, etc.
> >
> > Adjust the input audio volume.
> >
> > -The filter accepts the following named parameters:
> > +The filter accepts the following named parameters. If the key of the
> > +first options is omitted, the arguments are interpreted according to
> > +the following syntax:
> > + at example
> > +drawbox=@var{volume}:@var{precision}
>
> drawbox?
>
> > + at end example
> > +
> > @table @option
> >
> > @item volume
> > diff --git a/libavfilter/af_volume_justin.c b/libavfilter/af_volume_justin.c
> > index 0f45a9e..0ba466a 100644
> > --- a/libavfilter/af_volume_justin.c
> > +++ b/libavfilter/af_volume_justin.c
> > @@ -41,37 +41,32 @@ static const char *precision_str[] = {
> >
> > #define OFFSET(x) offsetof(VolumeContext, x)
> > #define A AV_OPT_FLAG_AUDIO_PARAM
> > +#define F AV_OPT_FLAG_FILTERING_PARAM
> >
> > -static const AVOption options[] = {
> > +static const AVOption volume_options[] = {
> > { "volume", "set volume adjustment",
> > - OFFSET(volume), AV_OPT_TYPE_DOUBLE, { .dbl = 1.0 }, 0, 0x7fffff, A },
> > + OFFSET(volume), AV_OPT_TYPE_DOUBLE, { .dbl = 1.0 }, 0, 0x7fffff, A|F },
> > { "precision", "select mathematical precision",
> > - OFFSET(precision), AV_OPT_TYPE_INT, { .i64 = PRECISION_FLOAT }, PRECISION_FIXED, PRECISION_DOUBLE, A, "precision" },
> > - { "fixed", "select 8-bit fixed-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_FIXED }, INT_MIN, INT_MAX, A, "precision" },
> > - { "float", "select 32-bit floating-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_FLOAT }, INT_MIN, INT_MAX, A, "precision" },
> > - { "double", "select 64-bit floating-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_DOUBLE }, INT_MIN, INT_MAX, A, "precision" },
> > + OFFSET(precision), AV_OPT_TYPE_INT, { .i64 = PRECISION_FLOAT }, PRECISION_FIXED, PRECISION_DOUBLE, A|F, "precision" },
> > + { "fixed", "select 8-bit fixed-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_FIXED }, INT_MIN, INT_MAX, A|F, "precision" },
> > + { "float", "select 32-bit floating-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_FLOAT }, INT_MIN, INT_MAX, A|F, "precision" },
> > + { "double", "select 64-bit floating-point", 0, AV_OPT_TYPE_CONST, { .i64 = PRECISION_DOUBLE }, INT_MIN, INT_MAX, A|F, "precision" },
> > { NULL },
> > };
> >
> > -static const AVClass volume_class = {
> > - .class_name = "volume filter",
> > - .item_name = av_default_item_name,
> > - .option = options,
> > - .version = LIBAVUTIL_VERSION_INT,
> > -};
> > +AVFILTER_DEFINE_CLASS(volume);
> >
> > static av_cold int init(AVFilterContext *ctx, const char *args)
> > {
> > VolumeContext *vol = ctx->priv;
> > + static const char *shorthand[] = { "volume", "precision", NULL };
> > int ret;
> >
> > vol->class = &volume_class;
> > av_opt_set_defaults(vol);
> >
> > - if ((ret = av_set_options_string(vol, args, "=", ":")) < 0) {
> > - av_log(ctx, AV_LOG_ERROR, "Error parsing options string '%s'.\n", args);
> > + if ((ret = av_opt_set_from_string(vol, args, shorthand, "=", ":")) < 0)
> > return ret;
> > - }
> >
> > if (vol->precision == PRECISION_FIXED) {
> > vol->volume_i = (int)(vol->volume * 256 + 0.5);
> > @@ -182,8 +177,6 @@ static inline void scale_samples_s32(uint8_t *dst, const uint8_t *src,
> > smp_dst[i] = av_clipl_int32((((int64_t)smp_src[i] * volume + 128) >> 8));
> > }
> >
> > -
> > -
> > static void volume_init(VolumeContext *vol)
> > {
> > vol->samples_align = 1;
> > @@ -314,4 +307,5 @@ AVFilter avfilter_af_volume_justin = {
> > .init = init,
> > .inputs = avfilter_af_volume_inputs,
> > .outputs = avfilter_af_volume_outputs,
> > + .priv_class = &volume_class,
> > };
>
> LGTM otherwise, thanks
Pushed.
--
FFmpeg = Fierce Fascinating Mere Powerful Enlightened Gospel
More information about the ffmpeg-devel
mailing list