aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/flacdec.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-04-15 23:53:31 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-04-15 23:53:31 +0200
commit6d8ccc7ac7e6c039529971c9d3d21cbae8da4865 (patch)
tree30986e2918d2964ed70b51e8d7563ec5b403a616 /libavformat/flacdec.c
parent5f4f9ee99f4e9ab980bb18475009c701ba47a74f (diff)
downloadffmpeg-6d8ccc7ac7e6c039529971c9d3d21cbae8da4865.tar.gz
avformat/flacdec/flac_read_timestamp: dont modify AVStream state
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/flacdec.c')
-rw-r--r--libavformat/flacdec.c20
1 files changed, 12 insertions, 8 deletions
diff --git a/libavformat/flacdec.c b/libavformat/flacdec.c
index f640fec50b..1caa7b0b75 100644
--- a/libavformat/flacdec.c
+++ b/libavformat/flacdec.c
@@ -167,17 +167,19 @@ static av_unused int64_t flac_read_timestamp(AVFormatContext *s, int stream_inde
{
AVPacket pkt, out_pkt;
AVStream *st = s->streams[stream_index];
+ AVCodecParserContext *parser;
int ret;
+ int64_t pts = AV_NOPTS_VALUE;
if (avio_seek(s->pb, *ppos, SEEK_SET) < 0)
return AV_NOPTS_VALUE;
av_init_packet(&pkt);
- st->parser = av_parser_init(st->codec->codec_id);
- if (!st->parser){
+ parser = av_parser_init(st->codec->codec_id);
+ if (!parser){
return AV_NOPTS_VALUE;
}
- st->parser->flags |= PARSER_FLAG_USE_CODEC_TS;
+ parser->flags |= PARSER_FLAG_USE_CODEC_TS;
for (;;){
ret = ff_raw_read_partial_packet(s, &pkt);
@@ -188,22 +190,24 @@ static av_unused int64_t flac_read_timestamp(AVFormatContext *s, int stream_inde
return AV_NOPTS_VALUE;
}
av_init_packet(&out_pkt);
- ret = av_parser_parse2(st->parser, st->codec,
+ ret = av_parser_parse2(parser, st->codec,
&out_pkt.data, &out_pkt.size, pkt.data, pkt.size,
pkt.pts, pkt.dts, *ppos);
if (out_pkt.size){
int size = out_pkt.size;
av_free_packet(&out_pkt);
- if (st->parser->pts != AV_NOPTS_VALUE){
+ if (parser->pts != AV_NOPTS_VALUE){
// seeking may not have started from beginning of a frame
// calculate frame start position from next frame backwards
- *ppos = st->parser->next_frame_offset - size;
- return st->parser->pts;
+ *ppos = parser->next_frame_offset - size;
+ pts = parser->pts;
+ break;
}
}
}
- return AV_NOPTS_VALUE;
+ av_parser_close(parser);
+ return pts;
}
AVInputFormat ff_flac_demuxer = {