[FFmpeg-cvslog] avf:rmdec.c fill duration to AVFormatContext
William Yu
git at videolan.org
Tue Jul 17 16:55:13 CEST 2012
ffmpeg | branch: master | William Yu <genwillyu at gmail.com> | Fri Jul 13 17:16:01 2012 +0800| [6d4e0d1b7e5ef6b24be477df2e02e5f4766a7e54] | committer: Michael Niedermayer
avf:rmdec.c fill duration to AVFormatContext
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=6d4e0d1b7e5ef6b24be477df2e02e5f4766a7e54
---
libavformat/rmdec.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/libavformat/rmdec.c b/libavformat/rmdec.c
index d919a9a..76b3bdf 100644
--- a/libavformat/rmdec.c
+++ b/libavformat/rmdec.c
@@ -475,7 +475,8 @@ static int rm_read_header(AVFormatContext *s)
avio_rb32(pb); /* max packet size */
avio_rb32(pb); /* avg packet size */
avio_rb32(pb); /* nb packets */
- avio_rb32(pb); /* duration */
+ duration = avio_rb32(pb); /* duration */
+ s->duration = av_rescale(duration, AV_TIME_BASE, 1000);
avio_rb32(pb); /* preroll */
indx_off = avio_rb32(pb); /* index offset */
data_off = avio_rb32(pb); /* data offset */
@@ -499,6 +500,8 @@ static int rm_read_header(AVFormatContext *s)
duration = avio_rb32(pb); /* duration */
st->start_time = start_time;
st->duration = duration;
+ if(duration>0)
+ s->duration = AV_NOPTS_VALUE;
get_str8(pb, buf, sizeof(buf)); /* desc */
get_str8(pb, buf, sizeof(buf)); /* mimetype */
st->codec->codec_type = AVMEDIA_TYPE_DATA;
More information about the ffmpeg-cvslog
mailing list