summaryrefslogtreecommitdiff
path: root/libavformat/avidec.c
diff options
context:
space:
mode:
authorAnton Khirnov <wyskas@gmail.com>2010-02-06 12:32:44 +0000
committerJai Menon <jmenon86@gmail.com>2010-02-06 12:32:44 +0000
commit04d2540c4ba1ffbd82385cb75b141cc69eb0eb79 (patch)
tree426d046faabcf07809dd5ee9980995beb3ccd9ac /libavformat/avidec.c
parent86a4f011e678a15db4167358c0caad0247e15a7a (diff)
Add AVI metadata conversion table.
Patch by Anton Khirnov (gmail{wyskas}). Originally committed as revision 21653 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/avidec.c')
-rw-r--r--libavformat/avidec.c42
1 files changed, 18 insertions, 24 deletions
diff --git a/libavformat/avidec.c b/libavformat/avidec.c
index ea253aae76..d56dcd2154 100644
--- a/libavformat/avidec.c
+++ b/libavformat/avidec.c
@@ -227,10 +227,10 @@ static void clean_index(AVFormatContext *s){
}
}
-static int avi_read_tag(AVFormatContext *s, AVStream *st, const char *key, unsigned int size)
+static int avi_read_tag(AVFormatContext *s, AVStream *st, uint32_t tag, uint32_t size)
{
ByteIOContext *pb = s->pb;
- char *value;
+ char key[5] = {0}, *value;
size += (size & 1);
@@ -242,6 +242,8 @@ static int avi_read_tag(AVFormatContext *s, AVStream *st, const char *key, unsig
get_buffer(pb, value, size);
value[size]=0;
+ AV_WL32(key, tag);
+
if(st)
return av_metadata_set2(&st->metadata, key, value,
AV_METADATA_DONT_STRDUP_VAL);
@@ -250,6 +252,15 @@ static int avi_read_tag(AVFormatContext *s, AVStream *st, const char *key, unsig
AV_METADATA_DONT_STRDUP_VAL);
}
+static void avi_read_info(AVFormatContext *s, uint64_t end)
+{
+ while (url_ftell(s->pb) < end) {
+ uint32_t tag = get_le32(s->pb);
+ uint32_t size = get_le32(s->pb);
+ avi_read_tag(s, NULL, tag, size);
+ }
+}
+
static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
{
AVIContext *avi = s->priv_data;
@@ -301,6 +312,9 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
dprintf(NULL, "movi end=%"PRIx64"\n", avi->movi_end);
goto end_of_header;
}
+ else if (tag1 == MKTAG('I', 'N', 'F', 'O'))
+ avi_read_info(s, list_end);
+
break;
case MKTAG('d', 'm', 'l', 'h'):
avi->is_odml = 1;
@@ -606,30 +620,9 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
}
url_fseek(pb, size, SEEK_CUR);
break;
- case MKTAG('I', 'N', 'A', 'M'):
- avi_read_tag(s, NULL, "Title", size);
- break;
- case MKTAG('I', 'A', 'R', 'T'):
- avi_read_tag(s, NULL, "Artist", size);
- break;
- case MKTAG('I', 'C', 'O', 'P'):
- avi_read_tag(s, NULL, "Copyright", size);
- break;
- case MKTAG('I', 'C', 'M', 'T'):
- avi_read_tag(s, NULL, "Comment", size);
- break;
- case MKTAG('I', 'G', 'N', 'R'):
- avi_read_tag(s, NULL, "Genre", size);
- break;
- case MKTAG('I', 'P', 'R', 'D'):
- avi_read_tag(s, NULL, "Album", size);
- break;
- case MKTAG('I', 'P', 'R', 'T'):
- avi_read_tag(s, NULL, "Track", size);
- break;
case MKTAG('s', 't', 'r', 'n'):
if(s->nb_streams){
- avi_read_tag(s, s->streams[s->nb_streams-1], "Title", size);
+ avi_read_tag(s, s->streams[s->nb_streams-1], tag, size);
break;
}
default:
@@ -1190,4 +1183,5 @@ AVInputFormat avi_demuxer = {
avi_read_packet,
avi_read_close,
avi_read_seek,
+ .metadata_conv = ff_avi_metadata_conv,
};