Struct sea_streamer_file::FileSource

source ·
pub struct FileSource { /* private fields */ }
Expand description

FileSource treats files as a live stream of bytes. It will read til the end, and will resume reading when the file grows. It relies on notify::RecommendedWatcher, which is the OS’s native notify mechanism. The async API allows you to request how many bytes you need, and it will wait for those bytes to come in a non-blocking fashion.

If the file is removed from the file system, the stream ends.

Implementations§

source§

impl FileSource

source

pub async fn new(file_id: FileId, read_from: ReadFrom) -> Result<Self, FileErr>

source

pub fn offset(&self) -> u64

Offset in the file that has been read up to (i.e. by the user, not by the OS).

source

pub fn file_size(&self) -> u64

Known size of the current file. This is not always up to date, the file may have grown larger but not yet known.

source

pub async fn stream_bytes(&mut self) -> Result<Bytes, FileErr>

Stream bytes from file. If there is no bytes, it will wait until there are, like tail -f.

If there are some bytes in the buffer, it yields immediately.

source

pub async fn seek(&mut self, to: SeqPos) -> Result<u64, FileErr>

Seek the file stream to a different position. SeqNo is regarded as byte offset. Returns the file offset after sought.

Warning: This future must not be canceled.

source

pub async fn drain(self) -> ByteBuffer

Drain all bytes and end the stream

Trait Implementations§

source§

impl ByteSource for FileSource

source§

fn request_bytes(&mut self, size: usize) -> Self::Future<'_>

Stream N bytes from file. If there is not enough bytes, it will wait until there are, like tail -f.

If there are enough bytes in the buffer, it yields immediately.

§

type Future<'a> = FileSourceFuture<'a>

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, 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>,

§

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>,

§

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.