[FFmpeg-soc] [soc]: r2029 - in libavfilter: avfiltergraph.c avfiltergraph.h

vitor subversion at mplayerhq.hu
Mon Mar 24 20:19:38 CET 2008


Author: vitor
Date: Mon Mar 24 20:19:38 2008
New Revision: 2029

Log:
Split graph_load_from_dest() to have a version independent of avfilter_vf_graph

Modified:
   libavfilter/avfiltergraph.c
   libavfilter/avfiltergraph.h

Modified: libavfilter/avfiltergraph.c
==============================================================================
--- libavfilter/avfiltergraph.c	(original)
+++ libavfilter/avfiltergraph.c	Mon Mar 24 20:19:38 2008
@@ -488,11 +488,10 @@ int avfilter_graph_config_formats(AVFilt
     return 0;
 }
 
-static int graph_load_from_desc(AVFilterContext *ctx, AVFilterGraphDesc *desc)
+static int graph_load_from_desc2(AVFilterContext *ctx, AVFilterGraphDesc *desc)
 {
     AVFilterGraphDescFilter *curfilt;
     AVFilterGraphDescLink   *curlink;
-    AVFilterGraphDescExport *curpad;
     AVFilterContext *filt, *filtb;
 
     AVFilter *filterdef;
@@ -533,6 +532,22 @@ static int graph_load_from_desc(AVFilter
         }
     }
 
+    return 0;
+
+fail:
+    uninit(ctx);
+    return -1;
+}
+
+static int graph_load_from_desc(AVFilterContext *ctx, AVFilterGraphDesc *desc)
+{
+    AVFilterGraphDescExport *curpad;
+    char tmp[20];
+    AVFilterContext *filt;
+
+    if (graph_load_from_desc2(ctx, desc) < 0)
+        goto fail;
+
     /* export all input pads */
     for(curpad = desc->inputs; curpad; curpad = curpad->next) {
         snprintf(tmp, 20, "%d", curpad->filter);
@@ -560,6 +575,49 @@ fail:
     return -1;
 }
 
+int graph_load_from_desc3(AVFilterContext *ctx, AVFilterGraphDesc *desc, AVFilterContext *in, int inpad, AVFilterContext *out, int outpad)
+{
+    AVFilterGraphDescExport *curpad;
+    char tmp[20];
+    AVFilterContext *filt;
+
+    if (graph_load_from_desc2(ctx, desc) < 0)
+        goto fail;
+
+    /* export all input pads */
+    for(curpad = desc->inputs; curpad; curpad = curpad->next) {
+        snprintf(tmp, 20, "%d", curpad->filter);
+        if(!(filt = avfilter_graph_get_filter(ctx, tmp))) {
+            av_log(ctx, AV_LOG_ERROR, "filter owning exported pad does not exist\n");
+            goto fail;
+        }
+        if(avfilter_link(in, inpad, filt, curpad->pad)) {
+            av_log(ctx, AV_LOG_ERROR, "cannot create link between source and destination filters\n");
+            goto fail;
+        }
+    }
+
+    /* export all output pads */
+    for(curpad = desc->outputs; curpad; curpad = curpad->next) {
+        snprintf(tmp, 20, "%d", curpad->filter);
+        if(!(filt = avfilter_graph_get_filter(ctx, tmp))) {
+            av_log(ctx, AV_LOG_ERROR, "filter owning exported pad does not exist\n");
+            goto fail;
+        }
+
+        if(avfilter_link(filt, curpad->pad, out, outpad)) {
+            av_log(ctx, AV_LOG_ERROR, "cannot create link between source and destination filters\n");
+            goto fail;
+        }
+    }
+
+    return 0;
+
+fail:
+    uninit(ctx);
+    return -1;
+}
+
 static int init(AVFilterContext *ctx, const char *args, void *opaque)
 {
     GraphContext *gctx = ctx->priv;

Modified: libavfilter/avfiltergraph.h
==============================================================================
--- libavfilter/avfiltergraph.h	(original)
+++ libavfilter/avfiltergraph.h	Mon Mar 24 20:19:38 2008
@@ -119,4 +119,9 @@ int avfilter_graph_config_formats(AVFilt
  */
 int avfilter_graph_config_links(AVFilterContext *graphctx);
 
+
+int graph_load_from_desc3(AVFilterContext *ctx, AVFilterGraphDesc *desc,
+                          AVFilterContext *in, int inpad,
+                          AVFilterContext *out, int outpad);
+
 #endif  /* FFMPEG_AVFILTERGRAPH_H */



More information about the FFmpeg-soc mailing list