[FFmpeg-cvslog] doc/examples/transcode: stop using avfilter_graph_create_filter() incorrectly

Anton Khirnov git at videolan.org
Sat Sep 28 18:13:11 EEST 2024


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Wed Sep 25 12:18:31 2024 +0200| [d18d119b8fc09023668eaecc33f839ba06e7a1ec] | committer: Anton Khirnov

doc/examples/transcode: stop using avfilter_graph_create_filter() incorrectly

See previous commits for details.

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

 doc/examples/transcode.c | 24 ++++++++++++++++++------
 1 file changed, 18 insertions(+), 6 deletions(-)

diff --git a/doc/examples/transcode.c b/doc/examples/transcode.c
index cbe5088ef6..7d1e1826a3 100644
--- a/doc/examples/transcode.c
+++ b/doc/examples/transcode.c
@@ -283,10 +283,10 @@ static int init_filter(FilteringContext* fctx, AVCodecContext *dec_ctx,
             goto end;
         }
 
-        ret = avfilter_graph_create_filter(&buffersink_ctx, buffersink, "out",
-                NULL, NULL, filter_graph);
-        if (ret < 0) {
+        buffersink_ctx = avfilter_graph_alloc_filter(filter_graph, buffersink, "out");
+        if (!buffersink_ctx) {
             av_log(NULL, AV_LOG_ERROR, "Cannot create buffer sink\n");
+            ret = AVERROR(ENOMEM);
             goto end;
         }
 
@@ -297,6 +297,12 @@ static int init_filter(FilteringContext* fctx, AVCodecContext *dec_ctx,
             av_log(NULL, AV_LOG_ERROR, "Cannot set output pixel format\n");
             goto end;
         }
+
+        ret = avfilter_init_dict(buffersink_ctx, NULL);
+        if (ret < 0) {
+            av_log(NULL, AV_LOG_ERROR, "Cannot initialize buffer sink\n");
+            goto end;
+        }
     } else if (dec_ctx->codec_type == AVMEDIA_TYPE_AUDIO) {
         char buf[64];
         buffersrc = avfilter_get_by_name("abuffer");
@@ -322,10 +328,10 @@ static int init_filter(FilteringContext* fctx, AVCodecContext *dec_ctx,
             goto end;
         }
 
-        ret = avfilter_graph_create_filter(&buffersink_ctx, buffersink, "out",
-                NULL, NULL, filter_graph);
-        if (ret < 0) {
+        buffersink_ctx = avfilter_graph_alloc_filter(filter_graph, buffersink, "out");
+        if (!buffersink_ctx) {
             av_log(NULL, AV_LOG_ERROR, "Cannot create audio buffer sink\n");
+            ret = AVERROR(ENOMEM);
             goto end;
         }
 
@@ -352,6 +358,12 @@ static int init_filter(FilteringContext* fctx, AVCodecContext *dec_ctx,
             av_log(NULL, AV_LOG_ERROR, "Cannot set output sample rate\n");
             goto end;
         }
+
+        ret = avfilter_init_dict(buffersink_ctx, NULL);
+        if (ret < 0) {
+            av_log(NULL, AV_LOG_ERROR, "Cannot initialize audio buffer sink\n");
+            goto end;
+        }
     } else {
         ret = AVERROR_UNKNOWN;
         goto end;



More information about the ffmpeg-cvslog mailing list