pub struct Multireader<R: Seek> { /* private fields */ }Expand description
Structure that provides seeking and reading in a sequence of underlying readables.
Note: all readers except for the last one MUST have constant size so that we can rely on offsets for indexing across them. This will be true for the case of reading logrotated files.
§Usage
Create a Multireader from a collection of items. Items are required to implement Seek, and must additionally support Read
and BufRead to provide such functionality on resulting aggregate.
let inner_items = vec![Cursor::new(vec![1, 2, 3]), Cursor::new(vec![4, 5])];
// we get result here because Multireader performs seek
// (fallible operation) under the hood to determine sizes
let mut reader = Multireader::new(inner_items)?;
reader.read_to_end(&mut buf)?;
assert_eq!(buf, vec![1, 2, 3, 4, 5]);Multireader allows seeking inside multiple underlying items as if you only had one big buffer.
reader.seek(SeekFrom::Start(3))?;
assert_eq!(reader.get_global_offset(), 3);
// you can get index of current item as well as offset into it
assert_eq!(reader.get_current_item_index(), 1);
assert_eq!(reader.get_local_offset(), 0);Implementations§
Source§impl<R: Seek> Multireader<R>
impl<R: Seek> Multireader<R>
Sourcepub fn new(items: Vec<R>) -> Result<Self>
pub fn new(items: Vec<R>) -> Result<Self>
Create a Multireader from a nonempty collection of readers.
This function returns io::Result because it will use seek to determine sizes which can fail.
Sourcepub fn get_global_offset(&self) -> u64
pub fn get_global_offset(&self) -> u64
Offset amoung all underlying items.
Sourcepub fn get_local_offset(&self) -> u64
pub fn get_local_offset(&self) -> u64
Offset inside current item.
Sourcepub fn get_current_item_index(&self) -> usize
pub fn get_current_item_index(&self) -> usize
index of an item that is currently read.
Sourcepub fn into_inner(self) -> Vec<R>
pub fn into_inner(self) -> Vec<R>
Destroy the struct and return underlying readers.
Sourcepub fn get_total_size(&mut self) -> Result<u64>
pub fn get_total_size(&mut self) -> Result<u64>
Get total size of underlying items.
Computes total size of underlying items. This method requires mut ref and returns io::Result because we need to seek inside last item to determine its size at the moment of call.
Sourcepub fn seek_current_item(&mut self, pos: SeekFrom) -> Result<u64>
pub fn seek_current_item(&mut self, pos: SeekFrom) -> Result<u64>
Seek current underlying reader properly updating any internal state.
Returns current local offset after seek.
Sourcepub fn seek_to_item_start(&mut self, item_index: usize) -> Result<u64>
pub fn seek_to_item_start(&mut self, item_index: usize) -> Result<u64>
Perform seek to 0 offset in item identified by item_index.
Sourcepub fn seek_by_local_index(
&mut self,
item_index: usize,
pos: SeekFrom,
) -> Result<u64>
pub fn seek_by_local_index( &mut self, item_index: usize, pos: SeekFrom, ) -> Result<u64>
Seek globally by providing local pos inside item at index item_index.
Provided pos must be inside indexed item. Returns current local offset.
Sourcepub fn get_current_item_size(&self) -> Option<u64>
pub fn get_current_item_size(&self) -> Option<u64>
Returns item size of item. If it is last, returns None instead.
To determine size of last item, use get_last_item_size.
Sourcepub fn get_bytes_before_current_item(&self) -> u64
pub fn get_bytes_before_current_item(&self) -> u64
Computes global offset from which current item starts.
Sourcepub fn get_last_item_size(&mut self) -> Result<u64>
pub fn get_last_item_size(&mut self) -> Result<u64>
Computes last item size.
Last file in this reader may still be written into, so this number may soon become invalid.
Trait Implementations§
Source§impl<R: BufRead + Seek> BufRead for Multireader<R>
impl<R: BufRead + Seek> BufRead for Multireader<R>
Source§fn fill_buf(&mut self) -> Result<&[u8]>
fn fill_buf(&mut self) -> Result<&[u8]>
Read methods, if empty. Read moreSource§fn consume(&mut self, amt: usize)
fn consume(&mut self, amt: usize)
amount of additional bytes from the internal buffer as having been read.
Subsequent calls to read only return bytes that have not been marked as read. Read moreSource§fn has_data_left(&mut self) -> Result<bool, Error>
fn has_data_left(&mut self) -> Result<bool, Error>
buf_read_has_data_left)read. Read more1.83.0 · Source§fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
byte or EOF is reached. Read more1.0.0 · Source§fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
0xA byte) is reached, and append
them to the provided String buffer. Read moreSource§impl<R: Read + Seek> Read for Multireader<R>
impl<R: Read + Seek> Read for Multireader<R>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
read, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
can_vector)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
buf. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
buf. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
buf. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
read_buf)Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
read_buf)cursor. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Read. Read moreSource§impl<R: Seek> Seek for Multireader<R>
impl<R: Seek> Seek for Multireader<R>
Source§fn seek(&mut self, pos: SeekFrom) -> Result<u64>
fn seek(&mut self, pos: SeekFrom) -> Result<u64>
1.55.0 · Source§fn rewind(&mut self) -> Result<(), Error>
fn rewind(&mut self) -> Result<(), Error>
Source§fn stream_len(&mut self) -> Result<u64, Error>
fn stream_len(&mut self) -> Result<u64, Error>
seek_stream_len)