diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-04-15 23:53:31 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-04-15 23:53:31 +0200 |
commit | 6d8ccc7ac7e6c039529971c9d3d21cbae8da4865 (patch) | |
tree | 30986e2918d2964ed70b51e8d7563ec5b403a616 /libavformat/flacdec.c | |
parent | 5f4f9ee99f4e9ab980bb18475009c701ba47a74f (diff) | |
download | ffmpeg-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.c | 20 |
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 = { |