aviobuf: Partial support for reading in read/write contexts

So far, aviocontexts are used either in pure-read or pure-write
mode - full read/write mode doesn't work well (and implementing it
is a much larger, not totally trivial change).

This patch allows using avio_read and ffio_read_partial on
read/write aviocontexts, where the read operations are passed
through directly unbuffered, while writes are buffered as usual.

This is enough to support the operations needed by packet based
data transfer like in udp/rtp, where aviocontext is the only
public API for hooking up custom IO.

Signed-off-by: Martin Storsjö <martin@martin.st>
pull/8/head
Martin Storsjö 12 years ago
parent 3048fae63c
commit a0b7e28907
  1. 9
      libavformat/aviobuf.c

@ -452,7 +452,7 @@ int avio_read(AVIOContext *s, unsigned char *buf, int size)
len = s->buf_end - s->buf_ptr; len = s->buf_end - s->buf_ptr;
if (len > size) if (len > size)
len = size; len = size;
if (len == 0) { if (len == 0 || s->write_flag) {
if(size > s->buffer_size && !s->update_checksum){ if(size > s->buffer_size && !s->update_checksum){
if(s->read_packet) if(s->read_packet)
len = s->read_packet(s->opaque, buf, size); len = s->read_packet(s->opaque, buf, size);
@ -497,6 +497,13 @@ int ffio_read_partial(AVIOContext *s, unsigned char *buf, int size)
if (size < 0) if (size < 0)
return -1; return -1;
if (s->read_packet && s->write_flag) {
len = s->read_packet(s->opaque, buf, size);
if (len > 0)
s->pos += len;
return len;
}
len = s->buf_end - s->buf_ptr; len = s->buf_end - s->buf_ptr;
if (len == 0) { if (len == 0) {
fill_buffer(s); fill_buffer(s);

Loading…
Cancel
Save