[FFmpeg-devel] [PATCH 1/4] avformat/avidec: Don't reimplement ff_free_stream()
Andreas Rheinhardt
andreas.rheinhardt at gmail.com
Sat Apr 4 11:26:24 EEST 2020
Andreas Rheinhardt:
> Using ff_free_stream() makes the code more readable, more future-proof
> (the old code freed AVCodecContexts and AVCodecParameters and its
> substructures manually, so that there is a chance that there would be a
> memleak for some time if new substructures were added) and reduces
> code size.
>
> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
> ---
> libavformat/avidec.c | 17 ++---------------
> 1 file changed, 2 insertions(+), 15 deletions(-)
>
> diff --git a/libavformat/avidec.c b/libavformat/avidec.c
> index 00c3978b2d..ae343e732a 100644
> --- a/libavformat/avidec.c
> +++ b/libavformat/avidec.c
> @@ -600,21 +600,8 @@ static int avi_read_header(AVFormatContext *s)
> goto fail;
>
> ast = s->streams[0]->priv_data;
> - av_freep(&s->streams[0]->codecpar->extradata);
> - av_freep(&s->streams[0]->codecpar);
> -#if FF_API_LAVF_AVCTX
> -FF_DISABLE_DEPRECATION_WARNINGS
> - av_freep(&s->streams[0]->codec);
> -FF_ENABLE_DEPRECATION_WARNINGS
> -#endif
> - if (s->streams[0]->info)
> - av_freep(&s->streams[0]->info->duration_error);
> - av_freep(&s->streams[0]->info);
> - if (s->streams[0]->internal)
> - av_freep(&s->streams[0]->internal->avctx);
> - av_freep(&s->streams[0]->internal);
> - av_freep(&s->streams[0]);
> - s->nb_streams = 0;
> + st->priv_data = NULL;
> + ff_free_stream(s, st);
> if (CONFIG_DV_DEMUXER) {
> avi->dv_demux = avpriv_dv_init_demux(s);
> if (!avi->dv_demux)
>
Any comments on this patchset? If there are no objections, I'll apply it
tomorrow.
- Andreas
More information about the ffmpeg-devel
mailing list