Commit 0643b4bf authored by Rodger Combs's avatar Rodger Combs Committed by Michael Niedermayer

lavf/brstm: expose the loop point when present

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 2c77ca45
...@@ -93,6 +93,7 @@ static int read_header(AVFormatContext *s) ...@@ -93,6 +93,7 @@ static int read_header(AVFormatContext *s)
uint32_t size, asize, start = 0; uint32_t size, asize, start = 0;
AVStream *st; AVStream *st;
int ret = AVERROR_EOF; int ret = AVERROR_EOF;
int loop = 0;
int bfstm = !strcmp("bfstm", s->iformat->name); int bfstm = !strcmp("bfstm", s->iformat->name);
st = avformat_new_stream(s, NULL); st = avformat_new_stream(s, NULL);
...@@ -195,7 +196,7 @@ static int read_header(AVFormatContext *s) ...@@ -195,7 +196,7 @@ static int read_header(AVFormatContext *s)
return AVERROR_PATCHWELCOME; return AVERROR_PATCHWELCOME;
} }
avio_skip(s->pb, 1); // loop flag loop = avio_r8(s->pb); // loop flag
st->codec->codec_id = codec; st->codec->codec_id = codec;
st->codec->channels = avio_r8(s->pb); st->codec->channels = avio_r8(s->pb);
if (!st->codec->channels) if (!st->codec->channels)
...@@ -209,7 +210,17 @@ static int read_header(AVFormatContext *s) ...@@ -209,7 +210,17 @@ static int read_header(AVFormatContext *s)
if (!bfstm) if (!bfstm)
avio_skip(s->pb, 2); // padding avio_skip(s->pb, 2); // padding
avio_skip(s->pb, 4); // loop start sample
if (loop) {
if (av_dict_set_int(&s->metadata, "loop_start",
av_rescale(read32(s), AV_TIME_BASE,
st->codec->sample_rate),
0) < 0)
return AVERROR(ENOMEM);
} else {
avio_skip(s->pb, 4);
}
st->start_time = 0; st->start_time = 0;
st->duration = read32(s); st->duration = read32(s);
avpriv_set_pts_info(st, 64, 1, st->codec->sample_rate); avpriv_set_pts_info(st, 64, 1, st->codec->sample_rate);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment