Mercurial > libavformat.hg
changeset 4708:87fbbc835a17 libavformat
add avformat_seek_file()
author | michael |
---|---|
date | Sat, 14 Mar 2009 15:51:46 +0000 |
parents | f153437e1ac0 |
children | 2f7b32083fb0 |
files | utils.c |
diffstat | 1 files changed, 22 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- 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 +} + /*******************************************************/ /**