[FFmpeg-devel] [PATCH 02/15] lavfi/asetnsamples: raise filter_frame() error.
Clément Bœsch
ubitux at gmail.com
Wed Mar 13 10:10:55 CET 2013
---
libavfilter/af_asetnsamples.c | 14 +++++++++-----
1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/libavfilter/af_asetnsamples.c b/libavfilter/af_asetnsamples.c
index f995ce9..08e5279 100644
--- a/libavfilter/af_asetnsamples.c
+++ b/libavfilter/af_asetnsamples.c
@@ -94,7 +94,7 @@ static int push_samples(AVFilterLink *outlink)
{
ASNSContext *asns = outlink->src->priv;
AVFrame *outsamples = NULL;
- int nb_out_samples, nb_pad_samples;
+ int ret, nb_out_samples, nb_pad_samples;
if (asns->pad) {
nb_out_samples = av_audio_fifo_size(asns->fifo) ? asns->nb_out_samples : 0;
@@ -125,7 +125,9 @@ static int push_samples(AVFilterLink *outlink)
if (asns->next_out_pts != AV_NOPTS_VALUE)
asns->next_out_pts += nb_out_samples;
- ff_filter_frame(outlink, outsamples);
+ ret = ff_filter_frame(outlink, outsamples);
+ if (ret < 0)
+ return ret;
asns->req_fullfilled = 1;
return nb_out_samples;
}
@@ -168,9 +170,11 @@ static int request_frame(AVFilterLink *outlink)
ret = ff_request_frame(inlink);
} while (!asns->req_fullfilled && ret >= 0);
- if (ret == AVERROR_EOF)
- while (push_samples(outlink))
- ;
+ if (ret == AVERROR_EOF) {
+ do {
+ ret = push_samples(outlink);
+ } while (ret > 0);
+ }
return ret;
}
--
1.8.1.5
More information about the ffmpeg-devel
mailing list