Struct olio::fs::ReadPos

source ·
pub struct ReadPos<P>where
    P: PosRead,
{ /* private fields */ }
Expand description

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

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

A fixed length is passed on construction and used solely to interpret SeekFrom::End. Reads are not constrained by this length. The length is 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 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 ReadPos.

Implementations§

New instance for PosRead and fixed length. The initial position is the start (index 0).

Return the length as provided on construction. This may differ from the inner PosRead length.

Return true if length is 0.

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

Return a new and independent ReadSlice by clone of the inner PosRead, for the range of byte offsets start..end, and positoned at start. This implementation panics if start is greater than end. Note that the end parameter is not checked against the length of self as passed on construction.

Trait Implementations§

Return a new, independent ReadPos by clone of the inner PosRead, with the same length as self, and at position 0.

Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
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. Read more
Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
Like read, except that it reads into a slice of buffers. Read more
🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
Read all bytes until EOF in this source, placing them into buf. Read more
Read all bytes until EOF in this source, appending them to buf. Read more
Read the exact number of bytes required to fill buf. Read more
🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
Creates a “by reference” adaptor for this instance of Read. Read more
Transforms this Read instance to an Iterator over its bytes. Read more
Creates an adapter which will chain this stream with another. Read more
Creates an adapter which will read at most limit bytes from it. Read more
Seek to an offset, in bytes, in a stream. Read more
Rewind to the beginning of a stream. Read more
🔬This is a nightly-only experimental API. (seek_stream_len)
Returns the length of this stream (in bytes). Read more
Returns the current seek position from the start of the stream. Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.