# HG changeset patch # User michael # Date 1237045906 0 # Node ID 87fbbc835a174bfbe57df77bd7d6203eb1c16ba4 # Parent f153437e1ac0953c2d0d7a42b6f2e83e32814636 add avformat_seek_file() diff -r f153437e1ac0 -r 87fbbc835a17 utils.c --- a/utils.c Fri Mar 13 22:26:45 2009 +0000 +++ b/utils.c Sat Mar 14 15:51:46 2009 +0000 @@ -1584,6 +1584,28 @@ return av_seek_frame_generic(s, stream_index, timestamp, flags); } +int avformat_seek_file(AVFormatContext *s, int stream_index, int64_t min_ts, int64_t ts, int64_t max_ts, int flags) +{ + if(min_ts > ts || max_ts < ts) + return -1; + + av_read_frame_flush(s); + + if (s->iformat->read_seek2) + return s->iformat->read_seek2(s, stream_index, min_ts, ts, max_ts, flags); + + if(s->iformat->read_timestamp){ + //try to seek via read_timestamp() + } + + //Fallback to old API if new is not implemented but old is + //Note the old has somewat different sematics + if(s->iformat->read_seek || 1) + return av_seek_frame(s, stream_index, ts, ts - min_ts > (uint64_t)(max_ts - ts) ? AVSEEK_FLAG_BACKWARD : 0); + + // try some generic seek like av_seek_frame_generic() but with new ts semantics +} + /*******************************************************/ /**