# HG changeset patch # User benoit # Date 1197883726 0 # Node ID f717dd23fc239f07b63ce24eba8698f90a7e0b9f # Parent 24ad70087e67c2a3085d5b9ec30f8a3c1f29b687 Enable av_read_pause(), av_read_play() and the ASF demuxer's av_read_seek() to use the protocol-native functionality if available. Patch by Bj«Órn Axelsson: bjorn point axelsson at intinor dot se Original thread: [FFmpeg-devel] [PATCH][4/4] Enable use of the extended API Date: Thu Nov 22 16:01:06 CET 2007 diff -r 24ad70087e67 -r f717dd23fc23 asf.c --- a/asf.c Sun Dec 16 18:51:00 2007 +0000 +++ b/asf.c Mon Dec 17 09:28:46 2007 +0000 @@ -1049,6 +1049,14 @@ if (asf->packet_size <= 0) return -1; + /* Try using the protocol's read_seek if available */ + if(s->pb && s->pb->read_seek) { + int ret = av_url_read_fseek(s->pb, stream_index, pts, flags); + if(ret >= 0) + asf_reset_header(s); + return ret; + } + if (!asf->index_read) asf_build_simple_index(s, stream_index); diff -r 24ad70087e67 -r f717dd23fc23 utils.c --- a/utils.c Sun Dec 16 18:51:00 2007 +0000 +++ b/utils.c Mon Dec 17 09:28:46 2007 +0000 @@ -2030,16 +2030,20 @@ int av_read_play(AVFormatContext *s) { - if (!s->iformat->read_play) - return AVERROR(ENOSYS); - return s->iformat->read_play(s); + if (s->iformat->read_play) + return s->iformat->read_play(s); + if (s->pb && s->pb->read_play) + return av_url_read_fplay(s->pb); + return AVERROR(ENOSYS); } int av_read_pause(AVFormatContext *s) { - if (!s->iformat->read_pause) - return AVERROR(ENOSYS); - return s->iformat->read_pause(s); + if (s->iformat->read_pause) + return s->iformat->read_pause(s); + if (s->pb && s->pb->read_pause) + return av_url_read_fpause(s->pb); + return AVERROR(ENOSYS); } void av_close_input_file(AVFormatContext *s)