[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