Skip to main content

FlatReader

Struct FlatReader 

Source
pub struct FlatReader<T: FlatStruct> { /* private fields */ }
Expand description

Reads FlatStruct samples directly from SHM slots.

Implementations§

Source§

impl<T: FlatStruct> FlatReader<T>

Source

pub fn new(alloc: Arc<InMemorySlotAllocator>, reader_index: u8) -> Self

Creates a reader over an allocator.

Source

pub fn type_hash(&self) -> [u8; 16]

Returns the type hash — for discovery matching.

Source

pub fn read(&self) -> Result<Option<T>, SlotError>

Spec §9.1 read_flat. Returns the newest unread sample. Automatically sets this reader’s bit in reader_mask.

Spec §6.1 type-hash cross-validation: before reading a slot, T::TYPE_HASH is checked against the hash stored on the SlotBackend. On mismatch: no slots are dereferenced, Err(SlotError::SampleTooLarge) with a schema-drift indication.

§Errors
  • SampleTooLarge on TYPE_HASH mismatch (Spec §6.1).
  • Wire/layout errors or slot-lock poison as usual.
Source

pub fn read_ref(&self) -> Result<Option<FlatSampleRef<T>>, SlotError>

Spec §9.2/§9.3 read_flat (reference variant). Returns the newest unread sample wrapped in a FlatSampleRef whose Drop sets this reader’s bit — i.e. the delivered slot stays un-recyclable for the lifetime of the returned reference (zero-copy lifetime binding), and is released when the reference drops. All other scanned slots are marked read immediately, as in Self::read.

§Errors

As Self::read.

Source

pub fn read_blocking(&self, timeout: Duration) -> Result<Option<T>, SlotError>

Spec §4.2 event-driven read. Returns the newest unread sample, blocking on the allocator’s notify (NO busy-poll) until one arrives or timeout elapses (then Ok(None)). The writer’s commit_slot bumps the notify generation, waking this reader.

§Errors

As Self::read.

Auto Trait Implementations§

§

impl<T> !Freeze for FlatReader<T>

§

impl<T> RefUnwindSafe for FlatReader<T>

§

impl<T> Send for FlatReader<T>

§

impl<T> Sync for FlatReader<T>

§

impl<T> Unpin for FlatReader<T>

§

impl<T> UnsafeUnpin for FlatReader<T>

§

impl<T> UnwindSafe for FlatReader<T>

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

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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V