summaryrefslogtreecommitdiff
path: root/libavfilter/asrc_anoisesrc.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2020-06-06 15:49:13 +0200
committerPaul B Mahol <onemda@gmail.com>2020-06-06 15:53:07 +0200
commit1c32d7dfcf0394a332d5ddee2a210d4eb5bd540c (patch)
tree17ec636b8f9a6977ca3caf72ceee5db0b5baa6bc /libavfilter/asrc_anoisesrc.c
parent49d37b4b618b20669bbd7081e6af2aecf9c09745 (diff)
avfilter/asrc_anoisesrc: switch to activate
Allows to set EOF timestamp.
Diffstat (limited to 'libavfilter/asrc_anoisesrc.c')
-rw-r--r--libavfilter/asrc_anoisesrc.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/libavfilter/asrc_anoisesrc.c b/libavfilter/asrc_anoisesrc.c
index ebcc446ae1..7aa878707d 100644
--- a/libavfilter/asrc_anoisesrc.c
+++ b/libavfilter/asrc_anoisesrc.c
@@ -21,6 +21,7 @@
#include "libavutil/opt.h"
#include "audio.h"
#include "avfilter.h"
+#include "filters.h"
#include "internal.h"
#include "libavutil/lfg.h"
#include "libavutil/random_seed.h"
@@ -198,16 +199,20 @@ static av_cold int config_props(AVFilterLink *outlink)
return 0;
}
-static int request_frame(AVFilterLink *outlink)
+static int activate(AVFilterContext *ctx)
{
- AVFilterContext *ctx = outlink->src;
+ AVFilterLink *outlink = ctx->outputs[0];
ANoiseSrcContext *s = ctx->priv;
AVFrame *frame;
int nb_samples, i;
double *dst;
+ if (!ff_outlink_frame_wanted(outlink))
+ return FFERROR_NOT_READY;
+
if (!s->infinite && s->duration <= 0) {
- return AVERROR_EOF;
+ ff_outlink_set_status(outlink, AVERROR_EOF, s->pts);
+ return 0;
} else if (!s->infinite && s->duration < s->nb_samples) {
nb_samples = s->duration;
} else {
@@ -236,7 +241,6 @@ static const AVFilterPad anoisesrc_outputs[] = {
{
.name = "default",
.type = AVMEDIA_TYPE_AUDIO,
- .request_frame = request_frame,
.config_props = config_props,
},
{ NULL }
@@ -248,6 +252,7 @@ AVFilter ff_asrc_anoisesrc = {
.query_formats = query_formats,
.priv_size = sizeof(ANoiseSrcContext),
.inputs = NULL,
+ .activate = activate,
.outputs = anoisesrc_outputs,
.priv_class = &anoisesrc_class,
};