[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