]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
support forward seeking in non seekable streams
authormichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Tue, 26 Sep 2006 17:09:03 +0000 (17:09 +0000)
committermichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Tue, 26 Sep 2006 17:09:03 +0000 (17:09 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@6340 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavformat/aviobuf.c

index ef72c195c13246b151918f9fc300c505e250a498..dced0d2df9352bf475e4eb72d1a3aaee7527e9f2 100644 (file)
@@ -22,6 +22,8 @@
 
 #define IO_BUFFER_SIZE 32768
 
+static void fill_buffer(ByteIOContext *s);
+
 int init_put_byte(ByteIOContext *s,
                   unsigned char *buffer,
                   int buffer_size,
@@ -122,6 +124,11 @@ offset_t url_fseek(ByteIOContext *s, offset_t offset, int whence)
         offset1 >= 0 && offset1 < (s->buf_end - s->buffer)) {
         /* can do the seek inside the buffer */
         s->buf_ptr = s->buffer + offset1;
+    } else if(s->is_streamed && !s->write_flag &&
+              offset1 >= 0 && offset1 < (s->buf_end - s->buffer) + (1<<16)){
+        while(s->pos < offset && !s->eof_reached)
+            fill_buffer(s);
+        s->buf_ptr = s->buf_end + offset - s->pos;
     } else {
 #ifdef CONFIG_MUXERS
         if (s->write_flag) {