Browse Source

Make avfilter_destroy() code less convoluted, introducing a temporary

variable link.

Originally committed as revision 25217 to svn://svn.ffmpeg.org/ffmpeg/trunk
tags/n0.8
Stefano Sabatini 14 years ago
parent
commit
b1a05b820e
1 changed files with 13 additions and 12 deletions
  1. +13
    -12
      libavfilter/avfilter.c

+ 13
- 12
libavfilter/avfilter.c View File

@@ -526,27 +526,28 @@ int avfilter_open(AVFilterContext **filter_ctx, AVFilter *filter, const char *in
void avfilter_destroy(AVFilterContext *filter) void avfilter_destroy(AVFilterContext *filter)
{ {
int i; int i;
AVFilterLink *link;


if (filter->filter->uninit) if (filter->filter->uninit)
filter->filter->uninit(filter); filter->filter->uninit(filter);


for (i = 0; i < filter->input_count; i++) { for (i = 0; i < filter->input_count; i++) {
if (filter->inputs[i]) {
if (filter->inputs[i]->src)
filter->inputs[i]->src->outputs[filter->inputs[i]->srcpad] = NULL;
avfilter_formats_unref(&filter->inputs[i]->in_formats);
avfilter_formats_unref(&filter->inputs[i]->out_formats);
if ((link = filter->inputs[i])) {
if (link->src)
link->src->outputs[link->srcpad] = NULL;
avfilter_formats_unref(&link->in_formats);
avfilter_formats_unref(&link->out_formats);
} }
av_freep(&filter->inputs[i]);
av_freep(&link);
} }
for (i = 0; i < filter->output_count; i++) { for (i = 0; i < filter->output_count; i++) {
if (filter->outputs[i]) {
if (filter->outputs[i]->dst)
filter->outputs[i]->dst->inputs[filter->outputs[i]->dstpad] = NULL;
avfilter_formats_unref(&filter->outputs[i]->in_formats);
avfilter_formats_unref(&filter->outputs[i]->out_formats);
if ((link = filter->outputs[i])) {
if (link->dst)
link->dst->inputs[link->dstpad] = NULL;
avfilter_formats_unref(&link->in_formats);
avfilter_formats_unref(&link->out_formats);
} }
av_freep(&filter->outputs[i]);
av_freep(&link);
} }


av_freep(&filter->name); av_freep(&filter->name);


Loading…
Cancel
Save