From 176aee8282c7d53b658de07ddf5bc4b0b3e5a7fc Mon Sep 17 00:00:00 2001 From: Aurelien Jacobs Date: Tue, 6 Jan 2009 00:09:23 +0000 Subject: [PATCH] Add a metadata compatibility layer, so that when a user application set metadata using old API, it is automatically converted to new API before muxing. Originally committed as revision 16447 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/metadata.c | 37 +++++++++++++++++++++++++++++++++++++ libavformat/metadata.h | 4 ++++ libavformat/utils.c | 4 ++++ 3 files changed, 45 insertions(+) diff --git a/libavformat/metadata.c b/libavformat/metadata.c index fec80d9..8a25782 100644 --- a/libavformat/metadata.c +++ b/libavformat/metadata.c @@ -73,3 +73,40 @@ int av_metadata_set(AVMetadata **pm, AVMetadataTag elem) return 0; } + +#if LIBAVFORMAT_VERSION_MAJOR < 53 +#define FILL_METADATA(s, key, value) { \ + if (value && *value && \ + !av_metadata_get(s->metadata, #key, NULL, AV_METADATA_IGNORE_CASE)) \ + av_metadata_set(&s->metadata, (const AVMetadataTag){#key, value}); \ + } +#define FILL_METADATA_STR(s, key) FILL_METADATA(s, key, s->key) +#define FILL_METADATA_INT(s, key) { \ + char number[10]; \ + snprintf(number, sizeof(number), "%d", s->key); \ + FILL_METADATA(s, key, number) } + +void ff_metadata_sync_compat(AVFormatContext *ctx) +{ + int i; + + FILL_METADATA_STR(ctx, title); + FILL_METADATA_STR(ctx, author); + FILL_METADATA_STR(ctx, copyright); + FILL_METADATA_STR(ctx, comment); + FILL_METADATA_STR(ctx, album); + FILL_METADATA_INT(ctx, year); + FILL_METADATA_INT(ctx, track); + FILL_METADATA_STR(ctx, genre); + for (i=0; inb_chapters; i++) + FILL_METADATA_STR(ctx->chapters[i], title); + for (i=0; inb_programs; i++) { + FILL_METADATA_STR(ctx->programs[i], name); + FILL_METADATA_STR(ctx->programs[i], provider_name); + } + for (i=0; inb_streams; i++) { + FILL_METADATA_STR(ctx->streams[i], language); + FILL_METADATA_STR(ctx->streams[i], filename); + } +} +#endif diff --git a/libavformat/metadata.h b/libavformat/metadata.h index 515b6cd..2826ecc 100644 --- a/libavformat/metadata.h +++ b/libavformat/metadata.h @@ -35,4 +35,8 @@ struct AVMetadata{ AVMetadataTag *elems; }; +#if LIBAVFORMAT_VERSION_MAJOR < 53 +void ff_metadata_sync_compat(AVFormatContext *s); +#endif + #endif /* AVFORMAT_METADATA_H */ diff --git a/libavformat/utils.c b/libavformat/utils.c index 68cb0da..e3fdd7f 100644 --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -2501,6 +2501,10 @@ int av_write_header(AVFormatContext *s) return AVERROR(ENOMEM); } +#if LIBAVFORMAT_VERSION_MAJOR < 53 + ff_metadata_sync_compat(s); +#endif + if(s->oformat->write_header){ ret = s->oformat->write_header(s); if (ret < 0) -- 2.7.4