summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libmpdemux/demux_mov.c24
-rw-r--r--libmpdemux/demuxer.c3
2 files changed, 27 insertions, 0 deletions
diff --git a/libmpdemux/demux_mov.c b/libmpdemux/demux_mov.c
index e1ce553bd1..43f3f0b61c 100644
--- a/libmpdemux/demux_mov.c
+++ b/libmpdemux/demux_mov.c
@@ -500,6 +500,30 @@ skip_chunk:
return 0;
}
+void demux_close_mov(demuxer_t *demuxer) {
+ mov_priv_t* priv = demuxer->priv;
+ int i;
+ if (!priv)
+ return;
+ for (i = 0; i < MOV_MAX_TRACKS; i++) {
+ mov_track_t *track = priv->tracks[i];
+ if (track) {
+ free(track->tkdata);
+ free(track->stdata);
+ free(track->stream_header);
+ free(track->samples);
+ free(track->chunks);
+ free(track->chunkmap);
+ free(track->durmap);
+ free(track->keyframes);
+ free(track->editlist);
+ free(track->desc);
+ free(track);
+ }
+ }
+ free(priv);
+}
+
static void lschunks(demuxer_t* demuxer,int level,off_t endpos,mov_track_t* trak){
mov_priv_t* priv=demuxer->priv;
// printf("lschunks (level=%d,endpos=%x)\n", level, endpos);
diff --git a/libmpdemux/demuxer.c b/libmpdemux/demuxer.c
index 9df04214d5..7007949e90 100644
--- a/libmpdemux/demuxer.c
+++ b/libmpdemux/demuxer.c
@@ -161,6 +161,7 @@ extern void demux_close_aac(demuxer_t* demuxer);
#ifdef USE_WIN32DLL
extern void demux_close_avs(demuxer_t* demuxer);
#endif
+extern void demux_close_mov(demuxer_t* demuxer);
#ifdef USE_TV
@@ -258,6 +259,8 @@ void free_demuxer(demuxer_t *demuxer){
case DEMUXER_TYPE_AVS:
demux_close_avs(demuxer); break;
#endif
+ case DEMUXER_TYPE_MOV:
+ demux_close_mov(demuxer); break;
}
// free streams:
for(i = 0; i < MAX_A_STREAMS; i++)