When we don't adjust the Period start time, we don't need to
parse the earliest_presentation_time from the sidx boxes either.
Signed-off-by: Martin Storsjö <martin@martin.st>
int timescale;
char codec_str[30];
int64_t sidx_start, sidx_length;
int timescale;
char codec_str[30];
int64_t sidx_start, sidx_length;
- int64_t earliest_presentation;
- uint32_t earliest_presentation_timescale;
if (size < 8)
break;
if (tag == MKBETAG('s', 'i', 'd', 'x')) {
if (size < 8)
break;
if (tag == MKBETAG('s', 'i', 'd', 'x')) {
- int version, track_id;
- uint32_t timescale;
- int64_t earliest_presentation;
- version = avio_r8(f);
- avio_rb24(f); /* flags */
- track_id = avio_rb32(f);
- timescale = avio_rb32(f);
- earliest_presentation = version ? avio_rb64(f) : avio_rb32(f);
for (i = start_index; i < tracks->nb_tracks; i++) {
struct Track *track = tracks->tracks[i];
if (!track->sidx_start) {
for (i = start_index; i < tracks->nb_tracks; i++) {
struct Track *track = tracks->tracks[i];
if (!track->sidx_start) {
} else if (pos == track->sidx_start + track->sidx_length) {
track->sidx_length = pos + size - track->sidx_start;
}
} else if (pos == track->sidx_start + track->sidx_length) {
track->sidx_length = pos + size - track->sidx_start;
}
- if (track->track_id == track_id) {
- track->earliest_presentation = earliest_presentation;
- track->earliest_presentation_timescale = timescale;
- }
}
}
if (avio_seek(f, pos + size, SEEK_SET) != pos + size)
}
}
if (avio_seek(f, pos + size, SEEK_SET) != pos + size)