Commit 2bfe619b authored by ods15's avatar ods15

Original Commit: r25 | ods15 | 2006-09-22 14:06:04 +0300 (Fri, 22 Sep 2006) | 2 lines

add proper uninit/free to all vorbis encoder context

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@6436 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent b28b3078
...@@ -560,6 +560,39 @@ static int vorbis_encode_frame(AVCodecContext * avccontext, unsigned char * pack ...@@ -560,6 +560,39 @@ static int vorbis_encode_frame(AVCodecContext * avccontext, unsigned char * pack
static int vorbis_encode_close(AVCodecContext * avccontext) static int vorbis_encode_close(AVCodecContext * avccontext)
{ {
venc_context_t * venc = avccontext->priv_data; venc_context_t * venc = avccontext->priv_data;
int i;
if (venc->codebooks) for (i = 0; i < venc->ncodebooks; i++) {
av_freep(&venc->codebooks[i].entries);
av_freep(&venc->codebooks[i].quantlist);
av_freep(&venc->codebooks[i].dimentions);
}
av_freep(&venc->codebooks);
if (venc->floors) for (i = 0; i < venc->nfloors; i++) {
int j;
av_freep(&venc->floors[i].classes);
if (venc->floors[i].classes)
for (j = 0; j < venc->floors[i].nclasses; j++)
av_freep(&venc->floors[i].classes[j].books);
av_freep(&venc->floors[i].partition_to_class);
av_freep(&venc->floors[i].list);
}
av_freep(&venc->floors);
if (venc->residues) for (i = 0; i < venc->nresidues; i++) {
av_freep(&venc->residues[i].books);
}
av_freep(&venc->residues);
if (venc->mappings) for (i = 0; i < venc->nmappings; i++) {
av_freep(&venc->mappings[i].mux);
av_freep(&venc->mappings[i].floor);
av_freep(&venc->mappings[i].residue);
}
av_freep(&venc->mappings);
av_freep(&venc->modes);
av_freep(&avccontext->coded_frame); av_freep(&avccontext->coded_frame);
av_freep(&avccontext->extradata); av_freep(&avccontext->extradata);
......
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