summaryrefslogtreecommitdiff
path: root/libavformat/oggdec.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2017-02-28 15:16:23 +0100
committerMichael Niedermayer <michael@niedermayer.cc>2017-03-02 03:12:25 +0100
commitfb6fa48fce3a09a30403326973f03f0343c6e24a (patch)
treeed490c803fbe94b2a2ea29785cd0260a5ea6bf78 /libavformat/oggdec.c
parent3250d4b39ccf70a9517a708fb6738070ebe83d6a (diff)
downloadffmpeg-fb6fa48fce3a09a30403326973f03f0343c6e24a.tar.gz
avformat/oggdec: Factor free_stream out
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavformat/oggdec.c')
-rw-r--r--libavformat/oggdec.c23
1 files changed, 16 insertions, 7 deletions
diff --git a/libavformat/oggdec.c b/libavformat/oggdec.c
index 64a88261e3..98cd0f55c7 100644
--- a/libavformat/oggdec.c
+++ b/libavformat/oggdec.c
@@ -63,6 +63,21 @@ static int64_t ogg_calc_pts(AVFormatContext *s, int idx, int64_t *dts);
static int ogg_new_stream(AVFormatContext *s, uint32_t serial);
static int ogg_restore(AVFormatContext *s);
+static void free_stream(AVFormatContext *s, int i)
+{
+ struct ogg *ogg = s->priv_data;
+ struct ogg_stream *stream = &ogg->streams[i];
+
+ av_freep(&stream->buf);
+ if (stream->codec &&
+ stream->codec->cleanup) {
+ stream->codec->cleanup(s, i);
+ }
+
+ av_freep(&stream->private);
+ av_freep(&stream->new_metadata);
+}
+
//FIXME We could avoid some structure duplication
static int ogg_save(AVFormatContext *s)
{
@@ -662,13 +677,7 @@ static int ogg_read_close(AVFormatContext *s)
int i;
for (i = 0; i < ogg->nstreams; i++) {
- av_freep(&ogg->streams[i].buf);
- if (ogg->streams[i].codec &&
- ogg->streams[i].codec->cleanup) {
- ogg->streams[i].codec->cleanup(s, i);
- }
- av_freep(&ogg->streams[i].private);
- av_freep(&ogg->streams[i].new_metadata);
+ free_stream(s, i);
}
ogg->nstreams = 0;