[FFmpeg-devel] [PATCH 8/9] fftools/ffmpeg_mux: deduplicate uniniting EncStats
Anton Khirnov
anton at khirnov.net
Thu Dec 14 21:31:37 EET 2023
---
fftools/ffmpeg_mux.c | 21 ++++++++++-----------
1 file changed, 10 insertions(+), 11 deletions(-)
diff --git a/fftools/ffmpeg_mux.c b/fftools/ffmpeg_mux.c
index 88ce3cd60c..357f34172f 100644
--- a/fftools/ffmpeg_mux.c
+++ b/fftools/ffmpeg_mux.c
@@ -773,6 +773,13 @@ int of_write_trailer(OutputFile *of)
return mux_result;
}
+static void enc_stats_uninit(EncStats *es)
+{
+ for (int i = 0; i < es->nb_components; i++)
+ av_freep(&es->components[i].str);
+ av_freep(&es->components);
+}
+
static void ost_free(OutputStream **post)
{
OutputStream *ost = *post;
@@ -818,17 +825,9 @@ static void ost_free(OutputStream **post)
av_freep(&ost->enc_ctx->stats_in);
avcodec_free_context(&ost->enc_ctx);
- for (int i = 0; i < ost->enc_stats_pre.nb_components; i++)
- av_freep(&ost->enc_stats_pre.components[i].str);
- av_freep(&ost->enc_stats_pre.components);
-
- for (int i = 0; i < ost->enc_stats_post.nb_components; i++)
- av_freep(&ost->enc_stats_post.components[i].str);
- av_freep(&ost->enc_stats_post.components);
-
- for (int i = 0; i < ms->stats.nb_components; i++)
- av_freep(&ms->stats.components[i].str);
- av_freep(&ms->stats.components);
+ enc_stats_uninit(&ost->enc_stats_pre);
+ enc_stats_uninit(&ost->enc_stats_post);
+ enc_stats_uninit(&ms->stats);
av_freep(post);
}
--
2.42.0
More information about the ffmpeg-devel
mailing list