From 433aeb62402ad307d3b43d8cb33cb199ace68772 Mon Sep 17 00:00:00 2001 From: Baptiste Coudurier Date: Fri, 21 Mar 2008 13:43:19 +0000 Subject: [PATCH] support fragments when non streamable Originally committed as revision 12542 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/mov.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/libavformat/mov.c b/libavformat/mov.c index d34de5c..7c549ed 100644 --- a/libavformat/mov.c +++ b/libavformat/mov.c @@ -1727,7 +1727,7 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt) AVIndexEntry *sample = 0; int64_t best_dts = INT64_MAX; int i; - + retry: for (i = 0; i < s->nb_streams; i++) { AVStream *st = s->streams[i]; MOVStreamContext *msc = st->priv_data; @@ -1747,8 +1747,15 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt) } } } - if (!sample) - return -1; + if (!sample) { + mov->found_mdat = 0; + if (!url_is_streamed(s->pb) || + mov_read_default(mov, s->pb, (MOV_atom_t){ 0, 0, INT64_MAX }) < 0 || + url_feof(s->pb)) + return -1; + dprintf(s, "read fragments, offset 0x%llx\n", url_ftell(s->pb)); + goto retry; + } /* must be done just before reading, to avoid infinite loop on sample */ sc->current_sample++; if (url_fseek(sc->pb, sample->pos, SEEK_SET) != sample->pos) { -- 2.7.4