Merge commit '3fb29588a27a711132106b924e27b53789a58dcb'

* commit '3fb29588a27a711132106b924e27b53789a58dcb':
  vf_drawtext: don't leak the expressions.
  vf_crop: make config_props work properly when called multiple times.
  vf_setdar: make config_props work properly when called multiple times.

Conflicts:
	libavfilter/vf_aspect.c
	libavfilter/vf_drawtext.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
Michael Niedermayer 2013-05-17 11:28:15 +02:00
commit 71fcb6072e
3 changed files with 28 additions and 17 deletions

View File

@ -37,7 +37,8 @@
typedef struct { typedef struct {
const AVClass *class; const AVClass *class;
AVRational aspect; AVRational dar;
AVRational sar;
int max; int max;
#if FF_API_OLD_FILTER_OPTS #if FF_API_OLD_FILTER_OPTS
float aspect_den; float aspect_den;
@ -61,16 +62,17 @@ static av_cold int init(AVFilterContext *ctx)
av_log(ctx, AV_LOG_ERROR, "Unable to parse ratio numerator \"%s\"\n", s->ratio_str); av_log(ctx, AV_LOG_ERROR, "Unable to parse ratio numerator \"%s\"\n", s->ratio_str);
return AVERROR(EINVAL); return AVERROR(EINVAL);
} }
s->aspect = av_d2q(num / s->aspect_den, s->max); s->sar = s->dar = av_d2q(num / s->aspect_den, s->max);
} else } else
#endif #endif
if (s->ratio_str) { if (s->ratio_str) {
ret = av_parse_ratio(&s->aspect, s->ratio_str, s->max, 0, ctx); ret = av_parse_ratio(&s->sar, s->ratio_str, s->max, 0, ctx);
if (ret < 0 || s->aspect.num < 0 || s->aspect.den <= 0) { if (ret < 0 || s->sar.num < 0 || s->sar.den <= 0) {
av_log(ctx, AV_LOG_ERROR, av_log(ctx, AV_LOG_ERROR,
"Invalid string '%s' for aspect ratio\n", s->ratio_str); "Invalid string '%s' for aspect ratio\n", s->ratio_str);
return AVERROR(EINVAL); return AVERROR(EINVAL);
} }
s->dar = s->sar;
} }
return 0; return 0;
} }
@ -79,7 +81,7 @@ static int filter_frame(AVFilterLink *link, AVFrame *frame)
{ {
AspectContext *s = link->dst->priv; AspectContext *s = link->dst->priv;
frame->sample_aspect_ratio = s->aspect; frame->sample_aspect_ratio = s->sar;
return ff_filter_frame(link->dst->outputs[0], frame); return ff_filter_frame(link->dst->outputs[0], frame);
} }
@ -100,14 +102,16 @@ static inline void compute_dar(AVRational *dar, AVRational sar, int w, int h)
static int setdar_config_props(AVFilterLink *inlink) static int setdar_config_props(AVFilterLink *inlink)
{ {
AspectContext *s = inlink->dst->priv; AspectContext *s = inlink->dst->priv;
AVRational dar = s->aspect, old_dar; AVRational dar;
AVRational old_dar;
AVRational old_sar = inlink->sample_aspect_ratio; AVRational old_sar = inlink->sample_aspect_ratio;
if (s->aspect.num && s->aspect.den) { if (s->dar.num && s->dar.den) {
av_reduce(&s->aspect.num, &s->aspect.den, av_reduce(&s->sar.num, &s->sar.den,
s->aspect.num * inlink->h, s->dar.num * inlink->h,
s->aspect.den * inlink->w, INT_MAX); s->dar.den * inlink->w, INT_MAX);
inlink->sample_aspect_ratio = s->aspect; inlink->sample_aspect_ratio = s->sar;
dar = s->dar;
} else { } else {
inlink->sample_aspect_ratio = (AVRational){ 1, 1 }; inlink->sample_aspect_ratio = (AVRational){ 1, 1 };
dar = (AVRational){ inlink->w, inlink->h }; dar = (AVRational){ inlink->w, inlink->h };
@ -175,10 +179,10 @@ static int setsar_config_props(AVFilterLink *inlink)
AVRational old_sar = inlink->sample_aspect_ratio; AVRational old_sar = inlink->sample_aspect_ratio;
AVRational old_dar, dar; AVRational old_dar, dar;
inlink->sample_aspect_ratio = s->aspect; inlink->sample_aspect_ratio = s->sar;
compute_dar(&old_dar, old_sar, inlink->w, inlink->h); compute_dar(&old_dar, old_sar, inlink->w, inlink->h);
compute_dar(&dar, s->aspect, inlink->w, inlink->h); compute_dar(&dar, s->sar, inlink->w, inlink->h);
av_log(inlink->dst, AV_LOG_VERBOSE, "w:%d h:%d sar:%d/%d dar:%d/%d -> sar:%d/%d dar:%d/%d\n", av_log(inlink->dst, AV_LOG_VERBOSE, "w:%d h:%d sar:%d/%d dar:%d/%d -> sar:%d/%d dar:%d/%d\n",
inlink->w, inlink->h, old_sar.num, old_sar.den, old_dar.num, old_dar.den, inlink->w, inlink->h, old_sar.num, old_sar.den, old_dar.num, old_dar.den,
inlink->sample_aspect_ratio.num, inlink->sample_aspect_ratio.den, dar.num, dar.den); inlink->sample_aspect_ratio.num, inlink->sample_aspect_ratio.den, dar.num, dar.den);

View File

@ -204,6 +204,9 @@ static int config_input(AVFilterLink *link)
s->w &= ~((1 << s->hsub) - 1); s->w &= ~((1 << s->hsub) - 1);
s->h &= ~((1 << s->vsub) - 1); s->h &= ~((1 << s->vsub) - 1);
av_expr_free(s->x_pexpr);
av_expr_free(s->y_pexpr);
s->x_pexpr = s->y_pexpr = NULL;
if ((ret = av_expr_parse(&s->x_pexpr, s->x_expr, var_names, if ((ret = av_expr_parse(&s->x_pexpr, s->x_expr, var_names,
NULL, NULL, NULL, NULL, 0, ctx)) < 0 || NULL, NULL, NULL, NULL, 0, ctx)) < 0 ||
(ret = av_expr_parse(&s->y_pexpr, s->y_expr, var_names, (ret = av_expr_parse(&s->y_pexpr, s->y_expr, var_names,

View File

@ -534,10 +534,10 @@ static av_cold void uninit(AVFilterContext *ctx)
{ {
DrawTextContext *s = ctx->priv; DrawTextContext *s = ctx->priv;
av_expr_free(s->x_pexpr); s->x_pexpr = NULL; av_expr_free(s->x_pexpr);
av_expr_free(s->y_pexpr); s->y_pexpr = NULL; av_expr_free(s->y_pexpr);
av_expr_free(s->draw_pexpr); s->draw_pexpr = NULL; av_expr_free(s->draw_pexpr);
s->x_pexpr = s->y_pexpr = s->draw_pexpr = NULL;
av_freep(&s->positions); av_freep(&s->positions);
s->nb_positions = 0; s->nb_positions = 0;
@ -580,6 +580,10 @@ static int config_input(AVFilterLink *inlink)
av_lfg_init(&s->prng, av_get_random_seed()); av_lfg_init(&s->prng, av_get_random_seed());
av_expr_free(s->x_pexpr);
av_expr_free(s->y_pexpr);
av_expr_free(s->draw_pexpr);
s->x_pexpr = s->y_pexpr = s->draw_pexpr = NULL;
if ((ret = av_expr_parse(&s->x_pexpr, s->x_expr, var_names, if ((ret = av_expr_parse(&s->x_pexpr, s->x_expr, var_names,
NULL, NULL, fun2_names, fun2, 0, ctx)) < 0 || NULL, NULL, fun2_names, fun2, 0, ctx)) < 0 ||
(ret = av_expr_parse(&s->y_pexpr, s->y_expr, var_names, (ret = av_expr_parse(&s->y_pexpr, s->y_expr, var_names,