Mercurial > libavformat.hg
changeset 1087:8ffbf9385972 libavformat
fix pcm_s24be demuxing, simplify
author | bcoudurier |
---|---|
date | Mon, 15 May 2006 12:38:33 +0000 |
parents | 4c7e75e255f8 |
children | e7fd91082489 |
files | aiff.c |
diffstat | 1 files changed, 3 insertions(+), 20 deletions(-) [+] |
line wrap: on
line diff
--- a/aiff.c Sun May 14 14:21:06 2006 +0000 +++ b/aiff.c Mon May 15 12:38:33 2006 +0000 @@ -399,37 +399,20 @@ static int aiff_read_packet(AVFormatContext *s, AVPacket *pkt) { - offset_t pos; - int res, size; + AVStream *st = s->streams[0]; + int res; /* End of stream may be reached */ if (url_feof(&s->pb)) return AVERROR_IO; - /* Need to know if reached the end sound data */ - size = MAX_SIZE; - if (s->file_size) { - pos = url_ftell (&s->pb) - s->file_size; - if (pos >= s->file_size) - size = 0; - else if (pos + MAX_SIZE >= s->file_size) - size = s->file_size - pos; - } - /* Now for that packet */ - res = av_get_packet (&s->pb, pkt, MAX_SIZE); + res = av_get_packet(&s->pb, pkt, (MAX_SIZE / st->codec->block_align) * st->codec->block_align); if (res < 0) return res; /* Only one stream in an AIFF file */ pkt->stream_index = 0; - - /* Finaly fix the read to a block */ - if (size <= res) - pkt->size = size - (size % s->streams[0]->codec->block_align); - else - pkt->size = res - (res % s->streams[0]->codec->block_align); - return 0; }