summaryrefslogtreecommitdiff
path: root/libavcodec/vorbis_enc.c
diff options
context:
space:
mode:
authorOded Shimon <ods15@ods15.dyndns.org>2006-10-02 05:56:01 +0000
committerOded Shimon <ods15@ods15.dyndns.org>2006-10-02 05:56:01 +0000
commitae9b187ab2595e2d4de4af3e17103353b741f8a4 (patch)
treeb5a917d30ab9cab53a2fa78e07fab063189888a1 /libavcodec/vorbis_enc.c
parentfb5eba8c2d1746603aea94b2fb4339cef42e3c3e (diff)
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 Originally committed as revision 6436 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/vorbis_enc.c')
-rw-r--r--libavcodec/vorbis_enc.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/libavcodec/vorbis_enc.c b/libavcodec/vorbis_enc.c
index 5501041356..528edc69fd 100644
--- a/libavcodec/vorbis_enc.c
+++ b/libavcodec/vorbis_enc.c
@@ -560,6 +560,39 @@ static int vorbis_encode_frame(AVCodecContext * avccontext, unsigned char * pack
static int vorbis_encode_close(AVCodecContext * avccontext)
{
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->extradata);