olio::fs

Struct ReadSlice

Source
pub struct ReadSlice<P>
where P: PosRead,
{ /* private fields */ }
Expand description

Re-implements Read and Seek over PosRead using only positioned reads, and by maintaining instance independent start, end, and position.

PosRead is implemented for any Borrow<File> so this can own via ReadSlice<File> or use a shared reference, as in ReadSlice<&File> or ReadSlice<Arc<File>>.

As compared with ReadPos, ReadSlice adds a general start offset, and limits access to the start..end range. Seeks are relative, so a seek to SeekFrom::Start(0) is always the first byte of the slice.

Fixed start and end offsets are passed on construction and used to constrain reads and interpret SeekFrom::Start and SeekFrom::End. These offsets are neither checked against nor updated from the inner PosRead (for example via file metadata) and could deviate if concurrent writes or truncation is possible. Reads beyond end or the end of the inner PosRead will return 0 length. Seeking past the end is allowed by the platforms for File, and is also allowed for ReadSlice.

Implementations§

Source§

impl<P> ReadSlice<P>
where P: PosRead,

Source

pub fn new(pos_read: P, start: u64, end: u64) -> Self

New instance by PosRead instance, fixed start and end offsets. The initial position is at the start (relative offset 0).

Source

pub fn len(&self) -> u64

Return the total size of the slice in bytes. This is based on the start and end offsets as constructed and can differ from the inner PosRead length.

Source

pub fn is_empty(&self) -> bool

Return true if length is 0.

Source

pub fn tell(&self) -> u64

Return the current instance position, relative to the slice. This is a convenience shorthand for seek(SeekFrom::Current(0)), is infallable, and does not require a mutable reference.

Source§

impl<P> ReadSlice<P>
where P: PosRead + Clone,

Source

pub fn subslice(&self, start: u64, end: u64) -> ReadSlice<P>

Return a new and independent ReadSlice by clone of the inner PosRead, for the range of byte offsets start..end which are relative to, and must be fully contained by self. This implementation panics on overflow, if start..end is not fully contained, or if start is greater-than end.

Source§

impl<P> ReadSlice<P>
where P: PosRead + Borrow<File>,

Source

pub fn mem_map(&self) -> Result<Mmap, Error>

Return a new read-only memory map handle Mmap for the complete region of the underlying File, from start to end.

This requires the mmap feature.

Trait Implementations§

Source§

impl<P> Clone for ReadSlice<P>
where P: PosRead + Clone,

Source§

fn clone(&self) -> Self

Return a new, independent ReadSlice by clone of the inner PosRead, with the same start and end as self, and positioned at start.

1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<P> Debug for ReadSlice<P>
where P: PosRead + Debug,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<P> PosRead for ReadSlice<P>
where P: PosRead,

Source§

fn pread(&self, buf: &mut [u8], offset: u64) -> Result<usize>

Read bytes, starting at the specified offset, into the specified buffer and return the number of bytes read. The offset is from the start of the underlying file or file range. Reads beyond the end of available bytes will return 0 length. The position of the underlying file pointer (aka cursor) is not used. It is platform dependent whether the underlying file pointer is modified by this operation.
Source§

impl<P> Read for ReadSlice<P>
where P: PosRead,

Source§

fn read(&mut self, buf: &mut [u8]) -> Result<usize>

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
1.36.0 · Source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
Source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · Source§

fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>

Reads all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · Source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Reads all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · Source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

Reads the exact number of bytes required to fill buf. Read more
Source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
Source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Reads the exact number of bytes required to fill cursor. Read more
1.0.0 · Source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · Source§

fn bytes(self) -> Bytes<Self>
where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · Source§

fn chain<R>(self, next: R) -> Chain<Self, R>
where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · Source§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more
Source§

impl<P> Seek for ReadSlice<P>
where P: PosRead,

Source§

fn seek(&mut self, from: SeekFrom) -> Result<u64>

Seek to an offset, in bytes, in a stream. In this implementation, seeks are relative to the fixed start offset so a seek to SeekFrom::Start(0) is always the first byte of the slice.

1.55.0 · Source§

fn rewind(&mut self) -> Result<(), Error>

Rewind to the beginning of a stream. Read more
Source§

fn stream_len(&mut self) -> Result<u64, Error>

🔬This is a nightly-only experimental API. (seek_stream_len)
Returns the length of this stream (in bytes). Read more
1.51.0 · Source§

fn stream_position(&mut self) -> Result<u64, Error>

Returns the current seek position from the start of the stream. Read more
1.80.0 · Source§

fn seek_relative(&mut self, offset: i64) -> Result<(), Error>

Seeks relative to the current position. Read more

Auto Trait Implementations§

§

impl<P> Freeze for ReadSlice<P>
where P: Freeze,

§

impl<P> RefUnwindSafe for ReadSlice<P>
where P: RefUnwindSafe,

§

impl<P> Send for ReadSlice<P>
where P: Send,

§

impl<P> Sync for ReadSlice<P>
where P: Sync,

§

impl<P> Unpin for ReadSlice<P>
where P: Unpin,

§

impl<P> UnwindSafe for ReadSlice<P>
where P: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.