[FFmpeg-devel] [PATCH 1/3] avformat/aeadec: Export title

Andreas Rheinhardt andreas.rheinhardt at outlook.com
Mon Mar 18 02:52:38 EET 2024


Andreas Rheinhardt:
> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at outlook.com>
> ---
>  libavformat/aeadec.c | 15 ++++++++++++---
>  1 file changed, 12 insertions(+), 3 deletions(-)
> 
> diff --git a/libavformat/aeadec.c b/libavformat/aeadec.c
> index 4cb2da6639..20170a89b3 100644
> --- a/libavformat/aeadec.c
> +++ b/libavformat/aeadec.c
> @@ -23,6 +23,7 @@
>  #include "libavutil/channel_layout.h"
>  #include "libavutil/intreadwrite.h"
>  #include "avformat.h"
> +#include "avio_internal.h"
>  #include "demux.h"
>  #include "pcm.h"
>  
> @@ -59,12 +60,20 @@ static int aea_read_probe(const AVProbeData *p)
>  static int aea_read_header(AVFormatContext *s)
>  {
>      AVStream *st = avformat_new_stream(s, NULL);
> -    int channels;
> +    char title[256 + 1];
> +    int channels, ret;
>      if (!st)
>          return AVERROR(ENOMEM);
>  
> -    /* Parse the amount of channels and skip to pos 2048(0x800) */
> -    avio_skip(s->pb, 264);
> +    /* Read the title, parse the number of channels and skip to pos 2048(0x800) */
> +    avio_rl32(s->pb); // magic
> +    ret = ffio_read_size(s->pb, title, sizeof(title) - 1);
> +    if (ret < 0)
> +        return ret;
> +    title[sizeof(title) - 1] = '\0';
> +    if (title[0] != '\0')
> +        av_dict_set(&st->metadata, "title", title, 0);
> +    avio_rl32(s->pb); // Block count
>      channels = avio_r8(s->pb);
>      avio_skip(s->pb, 1783);
>  

Will apply this patchset tonight unless there are objections.

- Andreas



More information about the ffmpeg-devel mailing list