Browse Source

vf_frei0r: make config_props work properly when called multiple times.

Do not leak the initialized filter instance.
tags/n2.0
Anton Khirnov 12 years ago
parent
commit
d371c3c2e2
1 changed files with 4 additions and 0 deletions
  1. +4
    -0
      libavfilter/vf_frei0r.c

+ 4
- 0
libavfilter/vf_frei0r.c View File

@@ -317,6 +317,8 @@ static int config_input_props(AVFilterLink *inlink)
AVFilterContext *ctx = inlink->dst;
Frei0rContext *s = ctx->priv;

if (s->destruct && s->instance)
s->destruct(s->instance);
if (!(s->instance = s->construct(inlink->w, inlink->h))) {
av_log(ctx, AV_LOG_ERROR, "Impossible to load frei0r instance");
return AVERROR(EINVAL);
@@ -451,6 +453,8 @@ static int source_config_props(AVFilterLink *outlink)
outlink->h = s->h;
outlink->time_base = s->time_base;

if (s->destruct && s->instance)
s->destruct(s->instance);
if (!(s->instance = s->construct(outlink->w, outlink->h))) {
av_log(ctx, AV_LOG_ERROR, "Impossible to load frei0r instance");
return AVERROR(EINVAL);


Loading…
Cancel
Save