changeset 4584:da9b09dd57b8 libavformat

use new metadata API in mov muxer
author aurel
date Thu, 26 Feb 2009 13:06:49 +0000
parents 8d5d5bcf76c9
children f777070fd15b
files movenc.c
diffstat 1 files changed, 61 insertions(+), 57 deletions(-) [+]
line wrap: on
line diff
--- a/movenc.c	Thu Feb 26 13:00:13 2009 +0000
+++ b/movenc.c	Thu Feb 26 13:06:49 2009 +0000
@@ -1230,23 +1230,25 @@
     return size;
 }
 
-/* iTunes year */
-static int mov_write_day_tag(ByteIOContext *pb, int year, int long_style)
+static int mov_write_string_metadata(AVFormatContext *s, ByteIOContext *pb,
+                                     const char *name, const char *tag,
+                                     int long_style)
 {
-    if(year){
-        char year_str[5];
-        snprintf(year_str, sizeof(year_str), "%04d", year);
-        return mov_write_string_tag(pb, "\251day", year_str, long_style);
-    }else
+    AVMetadataTag *t;
+
+    if (!(t = av_metadata_get(s->metadata, tag, NULL, 0)))
         return 0;
+
+    return mov_write_string_tag(pb, name, t->value, long_style);
 }
 
 /* iTunes track number */
 static int mov_write_trkn_tag(ByteIOContext *pb, MOVContext *mov,
                               AVFormatContext *s)
 {
-    int size = 0;
-    if (s->track) {
+    AVMetadataTag *t = av_metadata_get(s->metadata, "track", NULL, 0);
+    int size = 0, track = t ? atoi(t->value) : 0;
+    if (track) {
         int64_t pos = url_ftell(pb);
         put_be32(pb, 0); /* size */
         put_tag(pb, "trkn");
@@ -1257,7 +1259,7 @@
             put_be32(pb, 0);        // 8 bytes empty
             put_be32(pb, 0);
             put_be16(pb, 0);        // empty
-            put_be16(pb, s->track); // track number
+            put_be16(pb, track);    // track number
             put_be16(pb, 0);        // total track number
             put_be16(pb, 0);        // empty
             updateSize(pb, pos);
@@ -1274,15 +1276,15 @@
     int64_t pos = url_ftell(pb);
     put_be32(pb, 0); /* size */
     put_tag(pb, "ilst");
-    mov_write_string_tag(pb, "\251nam", s->title         , 1);
-    mov_write_string_tag(pb, "\251ART", s->author        , 1);
-    mov_write_string_tag(pb, "\251wrt", s->author        , 1);
-    mov_write_string_tag(pb, "\251alb", s->album         , 1);
-    mov_write_day_tag(pb, s->year ,1);
+    mov_write_string_metadata(s, pb, "\251nam", "title"    , 1);
+    mov_write_string_metadata(s, pb, "\251ART", "author"   , 1);
+    mov_write_string_metadata(s, pb, "\251wrt", "author"   , 1);
+    mov_write_string_metadata(s, pb, "\251alb", "album"    , 1);
+    mov_write_string_metadata(s, pb, "\251day", "year"     , 1);
     mov_write_string_tag(pb, "\251too", LIBAVFORMAT_IDENT, 1);
-    mov_write_string_tag(pb, "\251cmt", s->comment       , 1);
-    mov_write_string_tag(pb, "\251gen", s->genre         , 1);
-    mov_write_string_tag(pb, "\251cpy", s->copyright     , 1);
+    mov_write_string_metadata(s, pb, "\251cmt", "comment"  , 1);
+    mov_write_string_metadata(s, pb, "\251gen", "genre"    , 1);
+    mov_write_string_metadata(s, pb, "\251cpy", "copyright", 1);
     mov_write_trkn_tag(pb, mov, s);
     return updateSize(pb, pos);
 }
@@ -1293,9 +1295,6 @@
 {
     int size = 0;
 
-    // only save meta tag if required
-    if (s->title[0] || s->author[0] || s->album[0] || s->year ||
-        s->comment[0] || s->genre[0] || s->track) {
         int64_t pos = url_ftell(pb);
         put_be32(pb, 0); /* size */
         put_tag(pb, "meta");
@@ -1303,7 +1302,6 @@
         mov_write_itunes_hdlr_tag(pb, mov, s);
         mov_write_ilst_tag(pb, mov, s);
         size = updateSize(pb, pos);
-    }
     return size;
 }
 
@@ -1338,18 +1336,20 @@
                                   const char *tag, const char *str)
 {
     int64_t pos = url_ftell(pb);
-    if (!utf8len(str))
+    AVMetadataTag *t = av_metadata_get(s->metadata, str, NULL, 0);
+    if (!t || !utf8len(t->value))
         return 0;
     put_be32(pb, 0);   /* size */
     put_tag (pb, tag); /* type */
     put_be32(pb, 0);   /* version + flags */
     if (!strcmp(tag, "yrrc"))
-        put_be16(pb, s->year);
+        put_be16(pb, atoi(t->value));
     else {
         put_be16(pb, language_code("eng")); /* language */
-        ascii_to_wc(pb, str);
-        if (!strcmp(tag, "albm") && s->year)
-            put_byte(pb, s->year);
+        ascii_to_wc(pb, t->value);
+        if (!strcmp(tag, "albm") &&
+            (t = av_metadata_get(s->metadata, "year", NULL, 0)))
+            put_byte(pb, atoi(t->value));
     }
     return updateSize(pb, pos);
 }
@@ -1357,44 +1357,46 @@
 static int mov_write_udta_tag(ByteIOContext *pb, MOVContext *mov,
                               AVFormatContext *s)
 {
-    int i;
-    int bitexact = 0;
+    ByteIOContext *pb_buf;
+    int i, ret, size;
+    uint8_t *buf;
 
     for (i = 0; i < s->nb_streams; i++)
         if (mov->tracks[i].enc->flags & CODEC_FLAG_BITEXACT) {
-            bitexact = 1;
-            break;
+            return 0;
         }
 
-    if (!bitexact && (s->title[0] || s->author[0] || s->album[0] || s->year ||
-                      s->comment[0] || s->genre[0]  || s->track)) {
-        int64_t pos = url_ftell(pb);
-
-        put_be32(pb, 0); /* size */
-        put_tag(pb, "udta");
+    ret = url_open_dyn_buf(&pb_buf);
+    if(ret < 0)
+        return ret;
 
         if (mov->mode & MODE_3GP) {
-            mov_write_3gp_udta_tag(pb, s, "titl", s->title);
-            mov_write_3gp_udta_tag(pb, s, "auth", s->author);
-            mov_write_3gp_udta_tag(pb, s, "gnre", s->genre);
-            mov_write_3gp_udta_tag(pb, s, "dscp", s->comment);
-            mov_write_3gp_udta_tag(pb, s, "albm", s->album);
-            mov_write_3gp_udta_tag(pb, s, "cprt", s->copyright);
-            mov_write_3gp_udta_tag(pb, s, "yrrc", "nil");
+            mov_write_3gp_udta_tag(pb_buf, s, "titl", "title");
+            mov_write_3gp_udta_tag(pb_buf, s, "auth", "author");
+            mov_write_3gp_udta_tag(pb_buf, s, "gnre", "genre");
+            mov_write_3gp_udta_tag(pb_buf, s, "dscp", "comment");
+            mov_write_3gp_udta_tag(pb_buf, s, "albm", "album");
+            mov_write_3gp_udta_tag(pb_buf, s, "cprt", "copyright");
+            mov_write_3gp_udta_tag(pb_buf, s, "yrrc", "year");
         } else if (mov->mode == MODE_MOV) { // the title field breaks gtkpod with mp4 and my suspicion is that stuff is not valid in mp4
-            mov_write_string_tag(pb, "\251nam", s->title         , 0);
-            mov_write_string_tag(pb, "\251aut", s->author        , 0);
-            mov_write_string_tag(pb, "\251alb", s->album         , 0);
-            mov_write_day_tag(pb, s->year, 0);
-            mov_write_string_tag(pb, "\251enc", LIBAVFORMAT_IDENT, 0);
-            mov_write_string_tag(pb, "\251des", s->comment       , 0);
-            mov_write_string_tag(pb, "\251gen", s->genre         , 0);
-            mov_write_string_tag(pb, "\251cpy", s->copyright     , 0);
+            mov_write_string_metadata(s, pb_buf, "\251nam", "title"      , 0);
+            mov_write_string_metadata(s, pb_buf, "\251aut", "author"     , 0);
+            mov_write_string_metadata(s, pb_buf, "\251alb", "album"      , 0);
+            mov_write_string_metadata(s, pb_buf, "\251day", "year"       , 0);
+            mov_write_string_tag(pb_buf, "\251enc", LIBAVFORMAT_IDENT, 0);
+            mov_write_string_metadata(s, pb_buf, "\251des", "comment"    , 0);
+            mov_write_string_metadata(s, pb_buf, "\251gen", "genre"      , 0);
+            mov_write_string_metadata(s, pb_buf, "\251cpy", "copyright"  , 0);
         } else {
             /* iTunes meta data */
-            mov_write_meta_tag(pb, mov, s);
+            mov_write_meta_tag(pb_buf, mov, s);
         }
-        return updateSize(pb, pos);
+
+    if ((size = url_close_dyn_buf(pb_buf, &buf)) > 0) {
+        put_be32(pb, size+8);
+        put_tag(pb, "udta");
+        put_buffer(pb, buf, size);
+        av_free(buf);
     }
 
     return 0;
@@ -1415,9 +1417,10 @@
 
 static int mov_write_uuidusmt_tag(ByteIOContext *pb, AVFormatContext *s)
 {
+    AVMetadataTag *title = av_metadata_get(s->metadata, "title", NULL, 0);
     int64_t pos, pos2;
 
-    if (s->title[0]) {
+    if (title) {
         pos = url_ftell(pb);
         put_be32(pb, 0); /* size placeholder*/
         put_tag(pb, "uuid");
@@ -1439,7 +1442,7 @@
         put_be16(pb, 0x021C);               /* data */
 
         mov_write_psp_udta_tag(pb, LIBAVCODEC_IDENT,      "eng", 0x04);
-        mov_write_psp_udta_tag(pb, s->title,              "eng", 0x01);
+        mov_write_psp_udta_tag(pb, title->value,          "eng", 0x01);
 //        snprintf(dt,32,"%04d/%02d/%02d %02d:%02d:%02d",t_st->tm_year+1900,t_st->tm_mon+1,t_st->tm_mday,t_st->tm_hour,t_st->tm_min,t_st->tm_sec);
         mov_write_psp_udta_tag(pb, "2006/04/01 11:11:11", "und", 0x03);
 
@@ -1645,9 +1648,10 @@
     for(i=0; i<s->nb_streams; i++){
         AVStream *st= s->streams[i];
         MOVTrack *track= &mov->tracks[i];
+        AVMetadataTag *lang = av_metadata_get(st->metadata, "language", NULL,0);
 
         track->enc = st->codec;
-        track->language = ff_mov_iso639_to_lang(st->language, mov->mode != MODE_MOV);
+        track->language = ff_mov_iso639_to_lang(lang?lang->value:"und", mov->mode!=MODE_MOV);
         track->mode = mov->mode;
         track->tag = mov_find_codec_tag(s, track);
         if (!track->tag) {