diff options
author | Anton Khirnov <anton@khirnov.net> | 2024-09-04 15:11:22 +0200 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2024-09-09 17:26:18 +0200 |
commit | 363d4a75593b79a643a4c0eabee0c7688ae17a7f (patch) | |
tree | e479cf2daaf32867cf937b035ea2c119c96eed07 | |
parent | 75b2f5a7d316c20dc36fdca213ec1285d6d7afbd (diff) | |
download | ffmpeg-363d4a75593b79a643a4c0eabee0c7688ae17a7f.tar.gz |
lavfi/af_replaygain: convert to query_func2()
-rw-r--r-- | libavfilter/af_replaygain.c | 35 |
1 files changed, 24 insertions, 11 deletions
diff --git a/libavfilter/af_replaygain.c b/libavfilter/af_replaygain.c index 072ffa2aea..e3e2e921c4 100644 --- a/libavfilter/af_replaygain.c +++ b/libavfilter/af_replaygain.c @@ -326,25 +326,38 @@ typedef struct ReplayGainContext { float butter_hist_b[256]; } ReplayGainContext; -static int query_formats(AVFilterContext *ctx) +static int query_formats(const AVFilterContext *ctx, + AVFilterFormatsConfig **cfg_in, + AVFilterFormatsConfig **cfg_out) { - AVFilterFormats *formats = NULL; - AVFilterChannelLayouts *layout = NULL; + static const enum AVSampleFormat formats[] = { + AV_SAMPLE_FMT_FLT, + AV_SAMPLE_FMT_NONE, + }; + static const AVChannelLayout layouts[] = { + AV_CHANNEL_LAYOUT_STEREO, + { .nb_channels = 0 }, + }; + + AVFilterFormats *rates; + int i, ret; - if ((ret = ff_add_format (&formats, AV_SAMPLE_FMT_FLT )) < 0 || - (ret = ff_set_common_formats (ctx , formats )) < 0 || - (ret = ff_add_channel_layout (&layout , &(AVChannelLayout)AV_CHANNEL_LAYOUT_STEREO)) < 0 || - (ret = ff_set_common_channel_layouts (ctx , layout )) < 0) + ret = ff_set_common_formats_from_list2(ctx, cfg_in, cfg_out, formats); + if (ret < 0) + return ret; + + ret = ff_set_common_channel_layouts_from_list2(ctx, cfg_in, cfg_out, layouts); + if (ret < 0) return ret; - formats = NULL; + rates = NULL; for (i = 0; i < FF_ARRAY_ELEMS(freqinfos); i++) { - if ((ret = ff_add_format(&formats, freqinfos[i].sample_rate)) < 0) + if ((ret = ff_add_format(&rates, freqinfos[i].sample_rate)) < 0) return ret; } - return ff_set_common_samplerates(ctx, formats); + return ff_set_common_samplerates2(ctx, cfg_in, cfg_out, rates); } static int config_input(AVFilterLink *inlink) @@ -638,5 +651,5 @@ const AVFilter ff_af_replaygain = { .flags = AVFILTER_FLAG_METADATA_ONLY, FILTER_INPUTS(replaygain_inputs), FILTER_OUTPUTS(replaygain_outputs), - FILTER_QUERY_FUNC(query_formats), + FILTER_QUERY_FUNC2(query_formats), }; |