diff options
author | Aurelien Jacobs <aurel@gnuage.org> | 2009-02-02 23:43:12 +0000 |
---|---|---|
committer | Aurelien Jacobs <aurel@gnuage.org> | 2009-02-02 23:43:12 +0000 |
commit | c0f1445864fd6fae3cbd9a9b5f62d6e3a0c2b2f5 (patch) | |
tree | 5df19cd1887899cd4de8f7475170525f1f34d0e4 | |
parent | 33abc1a73afe15255d399953810fdd9c7c453dd5 (diff) | |
download | ffmpeg-c0f1445864fd6fae3cbd9a9b5f62d6e3a0c2b2f5.tar.gz |
use new metadata API in aiff demuxer
Originally committed as revision 16966 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/aiff.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/libavformat/aiff.c b/libavformat/aiff.c index 6ddf633acf..d946f5b708 100644 --- a/libavformat/aiff.c +++ b/libavformat/aiff.c @@ -79,9 +79,10 @@ static int get_tag(ByteIOContext *pb, uint32_t * tag) } /* Metadata string read */ -static void get_meta(ByteIOContext *pb, char * str, int strsize, int size) +static void get_meta(AVFormatContext *s, const char *key, int size) { - int res = get_buffer(pb, (uint8_t*)str, FFMIN(strsize-1, size)); + uint8_t str[1024]; + int res = get_buffer(s->pb, str, FFMIN(sizeof(str)-1, size)); if (res < 0) return; @@ -90,7 +91,9 @@ static void get_meta(ByteIOContext *pb, char * str, int strsize, int size) size++; size -= res; if (size) - url_fskip(pb, size); + url_fskip(s->pb, size); + + av_metadata_set(&s->metadata, key, str); } /* Returns the number of sound data frames or negative on error */ @@ -351,16 +354,16 @@ static int aiff_read_header(AVFormatContext *s, version = get_be32(pb); break; case MKTAG('N', 'A', 'M', 'E'): /* Sample name chunk */ - get_meta(pb, s->title, sizeof(s->title), size); + get_meta(s, "title" , size); break; case MKTAG('A', 'U', 'T', 'H'): /* Author chunk */ - get_meta(pb, s->author, sizeof(s->author), size); + get_meta(s, "author" , size); break; case MKTAG('(', 'c', ')', ' '): /* Copyright chunk */ - get_meta(pb, s->copyright, sizeof(s->copyright), size); + get_meta(s, "copyright", size); break; case MKTAG('A', 'N', 'N', 'O'): /* Annotation chunk */ - get_meta(pb, s->comment, sizeof(s->comment), size); + get_meta(s, "comment" , size); break; case MKTAG('S', 'S', 'N', 'D'): /* Sampled sound chunk */ offset = get_be32(pb); /* Offset of sound data */ |