[FFmpeg-cvslog] libavformat: Add a function for freeing an AVFormatContext
Martin Storsjö
git
Sun Feb 6 21:08:54 CET 2011
ffmpeg | branch: master | Martin Storsj? <martin at martin.st> | Fri Feb 4 12:04:16 2011 +0200| [4ed68fdfdc19705a09c99b93ec4a54167837a52a] | committer: Michael Niedermayer
libavformat: Add a function for freeing an AVFormatContext
This function is useful for freeing data structures allocated by
muxers, which currently have to be freed manually by the caller.
Signed-off-by: Ronald S. Bultje <rsbultje at gmail.com>
(cherry picked from commit f124b087eea442b65d809582527dfb5092a3463c)
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4ed68fdfdc19705a09c99b93ec4a54167837a52a
---
libavformat/avformat.h | 10 ++++++++--
libavformat/utils.c | 11 ++++++++---
libavformat/version.h | 2 +-
3 files changed, 17 insertions(+), 6 deletions(-)
diff --git a/libavformat/avformat.h b/libavformat/avformat.h
index 82991c1..6215ca5 100644
--- a/libavformat/avformat.h
+++ b/libavformat/avformat.h
@@ -1074,8 +1074,8 @@ attribute_deprecated AVFormatContext *av_alloc_format_context(void);
/**
* Allocate an AVFormatContext.
- * Can be freed with av_free() but do not forget to free everything you
- * explicitly allocated as well!
+ * avformat_free_context() can be used to free the context and everything
+ * allocated by the framework within it.
*/
AVFormatContext *avformat_alloc_context(void);
@@ -1232,6 +1232,12 @@ void av_close_input_stream(AVFormatContext *s);
void av_close_input_file(AVFormatContext *s);
/**
+ * Free an AVFormatContext and all its streams.
+ * @param s context to free
+ */
+void avformat_free_context(AVFormatContext *s);
+
+/**
* Add a new stream to a media file.
*
* Can only be called in the read_header() function. If the flag
diff --git a/libavformat/utils.c b/libavformat/utils.c
index 6a5c0f0..d12bbc2 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -2556,12 +2556,17 @@ int av_read_pause(AVFormatContext *s)
void av_close_input_stream(AVFormatContext *s)
{
- int i;
- AVStream *st;
-
flush_packet_queue(s);
if (s->iformat->read_close)
s->iformat->read_close(s);
+ avformat_free_context(s);
+}
+
+void avformat_free_context(AVFormatContext *s)
+{
+ int i;
+ AVStream *st;
+
for(i=0;i<s->nb_streams;i++) {
/* free all data in a stream component */
st = s->streams[i];
diff --git a/libavformat/version.h b/libavformat/version.h
index 4b95221..27f52e0 100644
--- a/libavformat/version.h
+++ b/libavformat/version.h
@@ -24,7 +24,7 @@
#include "libavutil/avutil.h"
#define LIBAVFORMAT_VERSION_MAJOR 52
-#define LIBAVFORMAT_VERSION_MINOR 95
+#define LIBAVFORMAT_VERSION_MINOR 96
#define LIBAVFORMAT_VERSION_MICRO 0
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
More information about the ffmpeg-cvslog
mailing list