[soc]: r2029 - in libavfilter: avfiltergraph.c avfiltergraph.h
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 */
participants (1)
-
vitor