Struct batch_system::fsm::FsmState [−][src]
Fields
status: AtomicUsize
data: AtomicPtr<N>
state_cnt: Arc<AtomicUsize>
Implementations
impl<N: Fsm> FsmState<N>
[src][−]
pub fn new(data: Box<N>, state_cnt: Arc<AtomicUsize>) -> FsmState<N>
[src]
pub fn take_fsm(&self) -> Option<Box<N>>
[src][−]
Take the fsm if it’s IDLE.
pub fn notify<S: FsmScheduler<Fsm = N>>(
&self,
scheduler: &S,
mailbox: Cow<'_, BasicMailbox<N>>
)
[src][−]
&self,
scheduler: &S,
mailbox: Cow<'_, BasicMailbox<N>>
)
Notify fsm via a FsmScheduler
.
pub fn release(&self, fsm: Box<N>)
[src][−]
Put the owner back to the state.
It’s not required that all messages should be consumed before releasing a fsm. However, a fsm is guaranteed to be notified only when new messages arrives after it’s released.
pub fn clear(&self)
[src][−]
Clear the fsm.
Trait Implementations
Auto Trait Implementations
impl<N> RefUnwindSafe for FsmState<N>
impl<N> Send for FsmState<N>
impl<N> Sync for FsmState<N>
impl<N> Unpin for FsmState<N>
impl<N> UnwindSafe for FsmState<N> where
N: RefUnwindSafe,
N: RefUnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src][+]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src][+]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src][+]
T: ?Sized,
impl<T> From<T> for T
[src][+]
impl<T> Instrument for T
[src][+]
impl<T, U> Into<U> for T where
U: From<T>,
[src][+]
U: From<T>,
impl<T> Pointable for T
[src][+]
impl<T> Same<T> for T
[src]
type Output = T
Should always be Self
impl<T> Sealed<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> SendSyncUnwindSafe for T where
T: Send + Sync + UnwindSafe + ?Sized,
[src]
T: Send + Sync + UnwindSafe + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src][+]
U: Into<T>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src][+]
U: TryFrom<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
[src][+]
V: MultiLane<T>,