[FFmpeg-cvslog] lavfi/alphamerge: raise filter_frame() error.

Clément Bœsch git at videolan.org
Wed Mar 13 19:11:11 CET 2013


ffmpeg | branch: master | Clément Bœsch <ubitux at gmail.com> | Wed Mar 13 09:56:58 2013 +0100| [f32fee570aa4c2d2bae5bc673f34b26eade4e382] | committer: Clément Bœsch

lavfi/alphamerge: raise filter_frame() error.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=f32fee570aa4c2d2bae5bc673f34b26eade4e382
---

 libavfilter/vf_alphamerge.c |    9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/libavfilter/vf_alphamerge.c b/libavfilter/vf_alphamerge.c
index 0727f7b..644c7f4 100644
--- a/libavfilter/vf_alphamerge.c
+++ b/libavfilter/vf_alphamerge.c
@@ -131,12 +131,13 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf)
     AVFilterContext *ctx = inlink->dst;
     AlphaMergeContext *merge = ctx->priv;
 
+    int ret = 0;
     int is_alpha = (inlink == ctx->inputs[1]);
     struct FFBufQueue *queue =
         (is_alpha ? &merge->queue_alpha : &merge->queue_main);
     ff_bufqueue_add(ctx, queue, buf);
 
-    while (1) {
+    do {
         AVFrame *main_buf, *alpha_buf;
 
         if (!ff_bufqueue_peek(&merge->queue_main, 0) ||
@@ -147,10 +148,10 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf)
 
         merge->frame_requested = 0;
         draw_frame(ctx, main_buf, alpha_buf);
-        ff_filter_frame(ctx->outputs[0], main_buf);
+        ret = ff_filter_frame(ctx->outputs[0], main_buf);
         av_frame_free(&alpha_buf);
-    }
-    return 0;
+    } while (ret >= 0);
+    return ret;
 }
 
 static int request_frame(AVFilterLink *outlink)



More information about the ffmpeg-cvslog mailing list