[FFmpeg-cvslog] avformat/argo_asf: use title metadata when muxing
Zane van Iperen
git at videolan.org
Fri Oct 15 16:57:22 EEST 2021
ffmpeg | branch: master | Zane van Iperen <zane at zanevaniperen.com> | Mon Oct 11 21:20:28 2021 +1000| [5d16660598dd9409c1028204cac3a966a939b719] | committer: Zane van Iperen
avformat/argo_asf: use title metadata when muxing
Signed-off-by: Zane van Iperen <zane at zanevaniperen.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=5d16660598dd9409c1028204cac3a966a939b719
---
libavformat/argo_asf.c | 16 ++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)
diff --git a/libavformat/argo_asf.c b/libavformat/argo_asf.c
index 740680ece1..2b3569ebc3 100644
--- a/libavformat/argo_asf.c
+++ b/libavformat/argo_asf.c
@@ -358,14 +358,22 @@ static int argo_asf_write_header(AVFormatContext *s)
.num_chunks = 1,
.chunk_offset = ASF_FILE_HEADER_SIZE
};
- const char *name = ctx->name, *end;
+ AVDictionaryEntry *t;
+ const char *name, *end;
size_t len;
/*
- * If the user specified a name, use it as is. Otherwise take the
- * basename and lop off the extension (if any).
+ * If the user specified a name, use it as is. Otherwise,
+ * try to use metadata (if present), then fall back to the
+ * filename (minus extension).
*/
- if (name || !(end = strrchr((name = av_basename(s->url)), '.'))) {
+ if (ctx->name) {
+ name = ctx->name;
+ len = strlen(ctx->name);
+ } else if ((t = av_dict_get(s->metadata, "title", NULL, 0))) {
+ name = t->value;
+ len = strlen(t->value);
+ } else if (!(end = strrchr((name = av_basename(s->url)), '.'))) {
len = strlen(name);
} else {
len = end - name;
More information about the ffmpeg-cvslog
mailing list