Struct VersionedFile

Source
pub struct VersionedFile { /* private fields */ }
Expand description

VersionedFile defines the main type for the crate, and implements an API for safely manipulating versioned files. The API is based on the async_std::File interface, but with some adjustments that are designed to make it both safer and more ergonomic. For example, len() is exposed directly rather than having to first fetch the file metadata. Another example, all calls to write will automatically flush() the file.

If a function is not fully documented, it is safe to assume that the function follows the same convensions/rules as its equivalent function for async_std::File.

Implementations§

Source§

impl VersionedFile

Source

pub async fn len(&mut self) -> Result<u64, Error>

len will return the size of the file, not including the versioned header.

Source

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

read_exact will read from the data portion of a VersionedFile. If there is an error, the contents of buf are unspecified, and the read offset will not be updated.

Source

pub async fn seek(&mut self, pos: SeekFrom) -> Result<u64, Error>

seek will seek to the provided offset within the file, ignoring the header.

Source

pub async fn set_len(&mut self, new_len: u64) -> Result<(), Error>

set_len will truncate the file so that it has the provided length, excluding the header. This operation can be used to make the file larger as well. This operation will put the cursor at the end of the file after the length has been set.

Source

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

write_all will write to the VersionedFile and then call flush(). Note that flush() is not the same as fsync().

If there is an error, the file cursor will not be updated.

Trait Implementations§

Source§

impl Debug for VersionedFile

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, 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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more