Skip to main content

AppendFrameOutcome

Struct AppendFrameOutcome 

Source
#[non_exhaustive]
pub struct AppendFrameOutcome { pub stream_id: String, pub frame_count: u64, pub summary_version: Option<u64>, }
Expand description

Outcome of an append_frame() call.

RFC-012 §R7.2.1: moved from ff_sdk::task::AppendFrameOutcome to ff_core::backend::AppendFrameOutcome so it is nameable by the EngineBackend::append_frame trait return. ff_sdk::task retains a pub use shim preserving the ff_sdk::task::AppendFrameOutcome path through 0.4.x.

Derive set matches the FailOutcome precedent (Clone, Debug, PartialEq, Eq). Not #[non_exhaustive]: construction is internal to the backend today (parser in ff-backend-valkey), and no external constructors are anticipated (consumer-shape evidence per §R7.2.1 / MN3).

stream_id: String is a stable shape commitment — a future typed StreamId newtype would be its own breaking change (§R7.5.6 / MD2).

RFC-015 §9 made this type #[non_exhaustive] so the new summary_version: Option<u64> field (populated only for StreamMode::DurableSummary appends) can land additively and future per-mode outcome fields can follow. Construct via Self::new + the chainable setters; cross-crate consumers cannot use struct-literal construction.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§stream_id: String

Valkey Stream entry ID assigned to this frame (e.g. 1234567890-0).

§frame_count: u64

Total frame count in the stream after this append.

§summary_version: Option<u64>

Rolling summary version after the delta applied, populated only for StreamMode::DurableSummary appends (RFC-015 §3.3 step 6). None for StreamMode::Durable / StreamMode::BestEffortLive appends — callers that need “total deltas applied” read this field.

Implementations§

Source§

impl AppendFrameOutcome

Source

pub fn new(stream_id: impl Into<String>, frame_count: u64) -> Self

Build an outcome with the mandatory stream_id / frame_count fields. summary_version defaults to None — call Self::with_summary_version for StreamMode::DurableSummary appends.

Source

pub fn with_summary_version(self, version: u64) -> Self

Attach a rolling summary version (RFC-015 §9).

Trait Implementations§

Source§

impl Clone for AppendFrameOutcome

Source§

fn clone(&self) -> AppendFrameOutcome

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for AppendFrameOutcome

Source§

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

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

impl Default for AppendFrameOutcome

Source§

fn default() -> AppendFrameOutcome

Returns the “default value” for a type. Read more
Source§

impl PartialEq for AppendFrameOutcome

Source§

fn eq(&self, other: &AppendFrameOutcome) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for AppendFrameOutcome

Source§

impl StructuralPartialEq for AppendFrameOutcome

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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.