|
|
|
@@ -1138,7 +1138,20 @@ static void asf_build_simple_index(AVFormatContext *s, int stream_index) |
|
|
|
|
|
|
|
url_fseek(s->pb, asf->data_object_offset + asf->data_object_size, SEEK_SET); |
|
|
|
get_guid(s->pb, &g); |
|
|
|
if (!guidcmp(&g, &index_guid)) { |
|
|
|
|
|
|
|
/* the data object can be followed by other top-level objects, |
|
|
|
skip them until the simple index object is reached */ |
|
|
|
while (guidcmp(&g, &index_guid)) { |
|
|
|
int64_t gsize= get_le64(s->pb); |
|
|
|
if (gsize < 24 || url_feof(s->pb)) { |
|
|
|
url_fseek(s->pb, current_pos, SEEK_SET); |
|
|
|
return; |
|
|
|
} |
|
|
|
url_fseek(s->pb, gsize-24, SEEK_CUR); |
|
|
|
get_guid(s->pb, &g); |
|
|
|
} |
|
|
|
|
|
|
|
{ |
|
|
|
int64_t itime, last_pos=-1; |
|
|
|
int pct, ict; |
|
|
|
int64_t av_unused gsize= get_le64(s->pb); |
|
|
|
|