# HG changeset patch # User michael # Date 1111702074 0 # Node ID 0ab9b73317482b361831ff19ff22fa8b937a0897 # Parent ff85dfd591767f524680c9f8a1e2f4bd57479a68 bypass internal buffer for "large" packets diff -r ff85dfd59176 -r 0ab9b7331748 aviobuf.c --- a/aviobuf.c Thu Mar 24 21:27:54 2005 +0000 +++ b/aviobuf.c Thu Mar 24 22:07:54 2005 +0000 @@ -333,10 +333,28 @@ if (len > size) len = size; if (len == 0) { - fill_buffer(s); - len = s->buf_end - s->buf_ptr; - if (len == 0) - break; + if(size > s->buffer_size && !s->update_checksum){ + len = s->read_packet(s->opaque, buf, size); + if (len <= 0) { + /* do not modify buffer if EOF reached so that a seek back can + be done without rereading data */ + s->eof_reached = 1; + if(len<0) + s->error= len; + break; + } else { + s->pos += len; + size -= len; + buf += len; + s->buf_ptr = s->buffer; + s->buf_end = s->buffer/* + len*/; + } + }else{ + fill_buffer(s); + len = s->buf_end - s->buf_ptr; + if (len == 0) + break; + } } else { memcpy(buf, s->buf_ptr, len); buf += len;