summaryrefslogtreecommitdiff
path: root/libavfilter/avfilter.c
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2021-08-11 21:54:31 +0200
committerAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2021-08-22 16:13:25 +0200
commitf308f37441ec0d49166641843acd5302c1e26e6a (patch)
tree163308d8d314a883f385b96661048844c0b3b362 /libavfilter/avfilter.c
parentdff1709eb2dc6f3f8128abb4e2c764cc7c5fc92b (diff)
avfilter/avfilter: Allow to free non-static pads generically
This can be enabled/disabled on a per-pad basis by setting the AVFILTERPAD_FLAG_FREE_NAME flag; variants of ff_append_(in|out)pads that do this for you have been added and will be put to use in the following commits. Reviewed-by: Nicolas George <george@nsup.org> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
Diffstat (limited to 'libavfilter/avfilter.c')
-rw-r--r--libavfilter/avfilter.c21
1 files changed, 20 insertions, 1 deletions
diff --git a/libavfilter/avfilter.c b/libavfilter/avfilter.c
index 2681d04fc0..4b6a3d1e8f 100644
--- a/libavfilter/avfilter.c
+++ b/libavfilter/avfilter.c
@@ -123,8 +123,11 @@ static int append_pad(unsigned *count, AVFilterPad **pads,
*pads = newpads;
if (newlinks)
*links = newlinks;
- if (!newpads || !newlinks)
+ if (!newpads || !newlinks) {
+ if (newpad->flags & AVFILTERPAD_FLAG_FREE_NAME)
+ av_freep(&newpad->name);
return AVERROR(ENOMEM);
+ }
memcpy(*pads + idx, newpad, sizeof(AVFilterPad));
(*links)[idx] = NULL;
@@ -139,11 +142,23 @@ int ff_append_inpad(AVFilterContext *f, AVFilterPad *p)
return append_pad(&f->nb_inputs, &f->input_pads, &f->inputs, p);
}
+int ff_append_inpad_free_name(AVFilterContext *f, AVFilterPad *p)
+{
+ p->flags |= AVFILTERPAD_FLAG_FREE_NAME;
+ return ff_append_inpad(f, p);
+}
+
int ff_append_outpad(AVFilterContext *f, AVFilterPad *p)
{
return append_pad(&f->nb_outputs, &f->output_pads, &f->outputs, p);
}
+int ff_append_outpad_free_name(AVFilterContext *f, AVFilterPad *p)
+{
+ p->flags |= AVFILTERPAD_FLAG_FREE_NAME;
+ return ff_append_outpad(f, p);
+}
+
int avfilter_link(AVFilterContext *src, unsigned srcpad,
AVFilterContext *dst, unsigned dstpad)
{
@@ -754,9 +769,13 @@ void avfilter_free(AVFilterContext *filter)
for (i = 0; i < filter->nb_inputs; i++) {
free_link(filter->inputs[i]);
+ if (filter->input_pads[i].flags & AVFILTERPAD_FLAG_FREE_NAME)
+ av_freep(&filter->input_pads[i].name);
}
for (i = 0; i < filter->nb_outputs; i++) {
free_link(filter->outputs[i]);
+ if (filter->output_pads[i].flags & AVFILTERPAD_FLAG_FREE_NAME)
+ av_freep(&filter->output_pads[i].name);
}
if (filter->filter->priv_class)