Skip to main content

ComposedRuntime

Struct ComposedRuntime 

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

Runtime wrapper for composed protocol execution.

Implementations§

Source§

impl ComposedRuntime

Source

pub fn new(config: ProtocolMachineConfig, budget: MemoryBudget) -> Self

Create an empty composed runtime.

Source

pub fn admit_bundle( &mut self, bundle: ProtocolBundle, ) -> Result<(), CompositionError>

Admit a protocol bundle after certificate + budget checks.

§Errors

Returns a CompositionError when proof or budget checks fail.

Source

pub fn load_bundle_session( &mut self, bundle_idx: usize, ) -> Result<usize, CompositionError>

Load one session instance from an admitted bundle index.

§Errors

Returns a CompositionError when index is invalid or ProtocolMachine loading fails.

Source

pub fn load_bundle_sessions( &mut self, bundle_idx: usize, sessions: usize, ) -> Result<Vec<usize>, CompositionError>

Load sessions instances from a bundle index.

§Errors

Returns a CompositionError when any session load fails.

Source

pub fn run( &mut self, handler: &dyn EffectHandler, max_steps: usize, ) -> Result<(), CompositionError>

Run the composed runtime.

§Errors

Returns ProtocolMachine-layer errors as composition errors.

Source

pub fn memory_usage(&self) -> &MemoryUsage

Access current memory usage snapshot.

Source

pub fn bundles(&self) -> &[ProtocolBundle]

Access admitted bundles.

Source

pub fn seed_bundle_membership<I, S>( &mut self, bundle_idx: usize, members: I, ) -> Result<(), CompositionError>
where I: IntoIterator<Item = S>, S: Into<String>,

Seed the active membership set for one admitted reconfiguration-enabled bundle.

§Errors

Returns a CompositionError when the bundle index is invalid, reconfiguration is disabled, or the membership set is empty.

Source

pub fn reconfigure_bundle<I, S>( &mut self, bundle_idx: usize, next_members: I, ) -> Result<ReconfigurationEvent, CompositionError>
where I: IntoIterator<Item = S>, S: Into<String>,

Apply one deterministic reconfiguration transition to an admitted bundle.

§Errors

Returns a CompositionError when the bundle index is invalid, the bundle does not admit reconfiguration, the transition violates required overlap, or the new membership set is empty.

Source

pub fn bundle_members(&self, bundle_idx: usize) -> Option<&BTreeSet<String>>

The canonical sorted active member set for one bundle, if configured.

Source

pub fn bundle_reconfiguration_history( &self, bundle_idx: usize, ) -> Option<&[ReconfigurationEvent]>

The deterministic reconfiguration history for one bundle, if configured.

Source

pub fn execute_reconfiguration_plan( &mut self, bundle_idx: usize, plan: &ReconfigurationPlan, ) -> Result<ReconfigurationPlanExecution, CompositionError>

Execute one deterministic multi-step reconfiguration plan atomically.

§Errors

Returns a CompositionError when any plan step is invalid or violates the admitted policy.

Source

pub fn bundle_reconfiguration_plan_executions( &self, bundle_idx: usize, ) -> Option<&[ReconfigurationPlanExecution]>

The deterministic reconfiguration plan executions for one bundle, if configured.

Source

pub fn execute_runtime_upgrade( &mut self, bundle_idx: usize, request: &RuntimeUpgradeRequest, ) -> Result<RuntimeUpgradeExecution, CompositionError>

Execute one deterministic runtime-upgrade request as a specialized reconfiguration.

§Errors

Returns a CompositionError when compatibility checks or any plan step fails.

Source

pub fn bundle_runtime_upgrade_executions( &self, bundle_idx: usize, ) -> Option<&[RuntimeUpgradeExecution]>

Deterministic runtime-upgrade executions for one bundle, if configured.

Source

pub fn bundle_reconfiguration_snapshot( &self, bundle_idx: usize, ) -> Option<ReconfigurationRuntimeSnapshot>

Export a deterministic snapshot of the reconfiguration state for one bundle.

Source

pub fn restore_bundle_reconfiguration_snapshot( &mut self, bundle_idx: usize, snapshot: ReconfigurationRuntimeSnapshot, ) -> Result<(), CompositionError>

Restore a previously exported reconfiguration snapshot for one admitted bundle.

§Errors

Returns a CompositionError when the snapshot is inconsistent with the admitted policy.

Source

pub fn machine(&self) -> &ProtocolMachine

Access underlying ProtocolMachine.

Trait Implementations§

Source§

impl Debug for ComposedRuntime

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

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
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<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
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<Src, Dst> LosslessTryInto<Dst> for Src
where Dst: LosslessTryFrom<Src>,

Source§

fn lossless_try_into(self) -> Option<Dst>

Performs the conversion.
Source§

impl<Src, Dst> LossyInto<Dst> for Src
where Dst: LossyFrom<Src>,

Source§

fn lossy_into(self) -> Dst

Performs the conversion.
Source§

impl<T> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> StrictAs for T

Source§

fn strict_as<Dst>(self) -> Dst
where T: StrictCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> StrictCastFrom<Src> for Dst
where Src: StrictCast<Dst>,

Source§

fn strict_cast_from(src: Src) -> Dst

Casts the value.
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> UnwrappedAs for T

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.