Commit 88cfb804 authored by Vitor Sessak's avatar Vitor Sessak

avfilter_formats_unref() should remove the given reference, not the last

reference.

Commited in SoC by Bobby Bingham

Originally committed as revision 11892 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 39135465
......@@ -109,8 +109,23 @@ void avfilter_formats_ref(AVFilterFormats *f, AVFilterFormats **ref)
f->refs[f->refcount-1] = ref;
}
static int find_ref_index(AVFilterFormats *f, AVFilterFormats **ref)
{
int i;
for(i = 0; i < (*ref)->refcount; i ++)
if((*ref)->refs[i] == ref)
return i;
return -1;
}
void avfilter_formats_unref(AVFilterFormats **ref)
{
int idx;
if((idx = find_ref_index(*ref, ref)) >= 0)
memmove((*ref)->refs + idx, (*ref)->refs + idx+1,
sizeof(AVFilterFormats**) * ((*ref)->refcount-idx-1));
if(!--(*ref)->refcount) {
av_free((*ref)->formats);
av_free((*ref)->refs);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment