[FFmpeg-devel] [PATCH 07/24] ffmpeg: move freeing the output file to ffmpeg_mux.c
Anton Khirnov
anton at khirnov.net
Mon Dec 13 17:20:25 EET 2021
---
fftools/ffmpeg.c | 14 ++------------
fftools/ffmpeg.h | 1 +
fftools/ffmpeg_mux.c | 17 +++++++++++++++++
3 files changed, 20 insertions(+), 12 deletions(-)
diff --git a/fftools/ffmpeg.c b/fftools/ffmpeg.c
index 1fb10869b4..86f7b11654 100644
--- a/fftools/ffmpeg.c
+++ b/fftools/ffmpeg.c
@@ -567,19 +567,9 @@ static void ffmpeg_cleanup(int ret)
av_freep(&subtitle_out);
/* close files */
- for (i = 0; i < nb_output_files; i++) {
- OutputFile *of = output_files[i];
- AVFormatContext *s;
- if (!of)
- continue;
- s = of->ctx;
- if (s && s->oformat && !(s->oformat->flags & AVFMT_NOFILE))
- avio_closep(&s->pb);
- avformat_free_context(s);
- av_dict_free(&of->opts);
+ for (i = 0; i < nb_output_files; i++)
+ of_close(&output_files[i]);
- av_freep(&output_files[i]);
- }
for (i = 0; i < nb_output_streams; i++) {
OutputStream *ost = output_streams[i];
diff --git a/fftools/ffmpeg.h b/fftools/ffmpeg.h
index 91c313d8ef..288e0f2981 100644
--- a/fftools/ffmpeg.h
+++ b/fftools/ffmpeg.h
@@ -687,6 +687,7 @@ int hwaccel_decode_init(AVCodecContext *avctx);
/* open the muxer when all the streams are initialized */
int of_check_init(OutputFile *of);
int of_write_trailer(OutputFile *of);
+void of_close(OutputFile **pof);
void of_write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost,
int unqueue);
diff --git a/fftools/ffmpeg_mux.c b/fftools/ffmpeg_mux.c
index fec8537506..9787fe7f78 100644
--- a/fftools/ffmpeg_mux.c
+++ b/fftools/ffmpeg_mux.c
@@ -312,3 +312,20 @@ int of_write_trailer(OutputFile *of)
return 0;
}
+
+void of_close(OutputFile **pof)
+{
+ OutputFile *of = *pof;
+ AVFormatContext *s;
+
+ if (!of)
+ return;
+
+ s = of->ctx;
+ if (s && s->oformat && !(s->oformat->flags & AVFMT_NOFILE))
+ avio_closep(&s->pb);
+ avformat_free_context(s);
+ av_dict_free(&of->opts);
+
+ av_freep(pof);
+}
--
2.33.0
More information about the ffmpeg-devel
mailing list