[FFmpeg-cvslog] lavf: Reimplement new seek API emulation

Michael Niedermayer git at videolan.org
Tue Feb 21 23:59:02 CET 2012


ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Sat Feb 18 00:16:58 2012 +0100| [92b5f71a7d30974250918b12e93c974b9b555d11] | committer: Michael Niedermayer

lavf: Reimplement new seek API emulation

This fixes seeking to before and after files with ffplay.

Signed-off-by: Michael Niedermayer <michaelni at gmx.at>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=92b5f71a7d30974250918b12e93c974b9b555d11
---

 libavformat/utils.c |   12 ++++++++++--
 1 files changed, 10 insertions(+), 2 deletions(-)

diff --git a/libavformat/utils.c b/libavformat/utils.c
index 155ba67..16a74f2 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -1819,8 +1819,16 @@ int avformat_seek_file(AVFormatContext *s, int stream_index, int64_t min_ts, int
     //Fallback to old API if new is not implemented but old is
     //Note the old has somewat different sematics
     AV_NOWARN_DEPRECATED(
-    if(s->iformat->read_seek || 1)
-        return av_seek_frame(s, stream_index, ts, flags | (ts - min_ts > (uint64_t)(max_ts - ts) ? AVSEEK_FLAG_BACKWARD : 0));
+    if (s->iformat->read_seek || 1) {
+        int dir = (ts - min_ts > (uint64_t)(max_ts - ts) ? AVSEEK_FLAG_BACKWARD : 0);
+        int ret = av_seek_frame(s, stream_index, ts, flags | dir);
+        if (ret<0 && ts != min_ts && max_ts != ts) {
+            ret = av_seek_frame(s, stream_index, dir ? max_ts : min_ts, flags | dir);
+            if (ret >= 0)
+                ret = av_seek_frame(s, stream_index, ts, flags | (dir^AVSEEK_FLAG_BACKWARD));
+        }
+        return ret;
+    }
     )
 
     // try some generic seek like seek_frame_generic() but with new ts semantics



More information about the ffmpeg-cvslog mailing list