summaryrefslogtreecommitdiff
path: root/libavfilter
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2013-07-10 13:10:07 +0000
committerPaul B Mahol <onemda@gmail.com>2013-07-10 13:16:24 +0000
commitbc95b9428950cd672162bcb2bb98fbecad52a5b3 (patch)
treead294f01ed396dd7b8dc3a1afbe363463d619e08 /libavfilter
parent564909093a318a6520a7bac7353ddea325e9f6fb (diff)
lavfi/aconvert: unbreak
Even if its deprecated, it should still work correctly. Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavfilter')
-rw-r--r--libavfilter/af_aconvert.c35
1 files changed, 21 insertions, 14 deletions
diff --git a/libavfilter/af_aconvert.c b/libavfilter/af_aconvert.c
index 8a9dc6f6aa..970e801152 100644
--- a/libavfilter/af_aconvert.c
+++ b/libavfilter/af_aconvert.c
@@ -25,42 +25,48 @@
* sample format and channel layout conversion audio filter
*/
-#include "libavutil/avstring.h"
#include "libavutil/channel_layout.h"
+#include "libavutil/opt.h"
#include "libswresample/swresample.h"
#include "avfilter.h"
#include "audio.h"
#include "internal.h"
typedef struct {
+ const AVClass *class;
enum AVSampleFormat out_sample_fmt;
int64_t out_chlayout;
struct SwrContext *swr;
+ char *format_str;
+ char *channel_layout_str;
} AConvertContext;
+#define OFFSET(x) offsetof(AConvertContext, x)
+#define A AV_OPT_FLAG_AUDIO_PARAM
+#define F AV_OPT_FLAG_FILTERING_PARAM
+static const AVOption aconvert_options[] = {
+ { "sample_fmt", "", OFFSET(format_str), AV_OPT_TYPE_STRING, .flags = A|F },
+ { "channel_layout", "", OFFSET(channel_layout_str), AV_OPT_TYPE_STRING, .flags = A|F },
+ { NULL },
+};
+
+AVFILTER_DEFINE_CLASS(aconvert);
+
static av_cold int init(AVFilterContext *ctx)
{
AConvertContext *aconvert = ctx->priv;
- char *arg, *ptr = NULL;
int ret = 0;
- char *args = av_strdup(NULL);
av_log(ctx, AV_LOG_WARNING, "This filter is deprecated, use aformat instead\n");
aconvert->out_sample_fmt = AV_SAMPLE_FMT_NONE;
aconvert->out_chlayout = 0;
- if ((arg = av_strtok(args, ":", &ptr)) && strcmp(arg, "auto")) {
- if ((ret = ff_parse_sample_format(&aconvert->out_sample_fmt, arg, ctx)) < 0)
- goto end;
- }
- if ((arg = av_strtok(NULL, ":", &ptr)) && strcmp(arg, "auto")) {
- if ((ret = ff_parse_channel_layout(&aconvert->out_chlayout, arg, ctx)) < 0)
- goto end;
- }
-
-end:
- av_freep(&args);
+ if (aconvert->format_str && strcmp(aconvert->format_str, "auto") &&
+ (ret = ff_parse_sample_format(&aconvert->out_sample_fmt, aconvert->format_str, ctx)) < 0)
+ return ret;
+ if (aconvert->channel_layout_str && strcmp(aconvert->channel_layout_str, "auto"))
+ return ff_parse_channel_layout(&aconvert->out_chlayout, aconvert->channel_layout_str, ctx);
return ret;
}
@@ -181,6 +187,7 @@ AVFilter avfilter_af_aconvert = {
.name = "aconvert",
.description = NULL_IF_CONFIG_SMALL("Convert the input audio to sample_fmt:channel_layout."),
.priv_size = sizeof(AConvertContext),
+ .priv_class = &aconvert_class,
.init = init,
.uninit = uninit,
.query_formats = query_formats,