Skip to main content

NetEvent

Enum NetEvent 

Source
pub enum NetEvent {
Show 13 variants ExecutionStarted { net_name: Arc<str>, timestamp: u64, }, ExecutionCompleted { net_name: Arc<str>, timestamp: u64, }, TransitionEnabled { transition_name: Arc<str>, timestamp: u64, }, TransitionClockRestarted { transition_name: Arc<str>, timestamp: u64, }, TransitionStarted { transition_name: Arc<str>, timestamp: u64, }, TransitionCompleted { transition_name: Arc<str>, timestamp: u64, }, TransitionFailed { transition_name: Arc<str>, error: String, timestamp: u64, }, TransitionTimedOut { transition_name: Arc<str>, timestamp: u64, }, ActionTimedOut { transition_name: Arc<str>, timeout_ms: u64, timestamp: u64, },
#[non_exhaustive]
TokenAdded { place_name: Arc<str>, timestamp: u64, token: Option<Arc<dyn TokenPayload>>, },
#[non_exhaustive]
TokenRemoved { place_name: Arc<str>, timestamp: u64, token: Option<Arc<dyn TokenPayload>>, }, LogMessage { transition_name: Arc<str>, level: String, message: String, timestamp: u64, }, MarkingSnapshot { marking: HashMap<Arc<str>, usize>, timestamp: u64, },
}
Expand description

All observable events during Petri net execution.

13 event types as a discriminated union matching the TypeScript/Java implementations.

Variants§

§

ExecutionStarted

Net execution started.

Fields

§net_name: Arc<str>
§timestamp: u64
§

ExecutionCompleted

Net execution completed (no more enabled transitions, no in-flight actions).

Fields

§net_name: Arc<str>
§timestamp: u64
§

TransitionEnabled

Transition became enabled (all input/inhibitor/read conditions satisfied).

Fields

§transition_name: Arc<str>
§timestamp: u64
§

TransitionClockRestarted

Transition’s enabling clock restarted (input place tokens changed while enabled).

Fields

§transition_name: Arc<str>
§timestamp: u64
§

TransitionStarted

Transition started firing (tokens consumed, action dispatched).

Fields

§transition_name: Arc<str>
§timestamp: u64
§

TransitionCompleted

Transition completed successfully (outputs produced).

Fields

§transition_name: Arc<str>
§timestamp: u64
§

TransitionFailed

Transition action failed with error.

Fields

§transition_name: Arc<str>
§error: String
§timestamp: u64
§

TransitionTimedOut

Transition exceeded its timing deadline and was force-disabled.

Fields

§transition_name: Arc<str>
§timestamp: u64
§

ActionTimedOut

Transition action exceeded its action timeout.

Fields

§transition_name: Arc<str>
§timeout_ms: u64
§timestamp: u64
§

#[non_exhaustive]
TokenAdded

Token added to a place.

The optional token payload is populated only by event stores that opt in via EventStore::CAPTURES_TOKENS. Production stores (NoopEventStore, InMemoryEventStore) leave it None so the capture path is monomorphized out — preserving the zero-cost event recording invariant.

Marked #[non_exhaustive] so future fields (e.g. token identity, source-transition attribution) can be added without a breaking change; downstream matches must use { .., .. }.

Fields

This variant is marked as non-exhaustive
Non-exhaustive enum variants could have additional fields added in future. Therefore, non-exhaustive enum variants cannot be constructed in external crates and cannot be matched against.
§place_name: Arc<str>
§timestamp: u64
§

#[non_exhaustive]
TokenRemoved

Token removed from a place.

See TokenAdded for payload semantics and for the #[non_exhaustive] contract.

Fields

This variant is marked as non-exhaustive
Non-exhaustive enum variants could have additional fields added in future. Therefore, non-exhaustive enum variants cannot be constructed in external crates and cannot be matched against.
§place_name: Arc<str>
§timestamp: u64
§

LogMessage

Log message emitted by a transition action.

Fields

§transition_name: Arc<str>
§level: String
§message: String
§timestamp: u64
§

MarkingSnapshot

Snapshot of the current marking (token counts per place).

Fields

§marking: HashMap<Arc<str>, usize>
§timestamp: u64

Implementations§

Source§

impl NetEvent

Source

pub fn token_added(place_name: Arc<str>, timestamp: u64) -> Self

Constructs a TokenAdded event without a payload — the default for production event stores.

Source

pub fn token_added_with( place_name: Arc<str>, timestamp: u64, token: Arc<dyn TokenPayload>, ) -> Self

Constructs a TokenAdded event carrying a token payload — used by debug-aware event stores that set EventStore::CAPTURES_TOKENS = true.

Source

pub fn token_removed(place_name: Arc<str>, timestamp: u64) -> Self

Constructs a TokenRemoved event without a payload.

Source

pub fn token_removed_with( place_name: Arc<str>, timestamp: u64, token: Arc<dyn TokenPayload>, ) -> Self

Constructs a TokenRemoved event carrying a token payload. See token_added_with.

Source

pub fn timestamp(&self) -> u64

Returns the timestamp of this event.

Source

pub fn place_name(&self) -> Option<&str>

Returns the place name if this event is place-related.

Source

pub fn instance_prefix(&self) -> Option<&str>

Returns the derived instance prefix per MOD-041 for this event, computed from whichever of Self::transition_name or Self::place_name is populated. Returns None for events that don’t carry a node name (e.g. Self::ExecutionStarted, Self::MarkingSnapshot) or when the carried name is flat (no /).

Source

pub fn transition_name(&self) -> Option<&str>

Returns the transition name if this event is transition-related.

Source

pub fn is_failure(&self) -> bool

Returns true if this is a failure event.

Source

pub fn has_error_signal(&self) -> bool

Returns true if this event carries any error signal — superset of is_failure that additionally treats a LogMessage at level ERROR (case-insensitive) as an error. Used by the v2 archive writer to pre-compute the hasErrors flag so listing/sampling tools can filter archives without scanning their event bodies. (libpetri 1.7.0+)

Trait Implementations§

Source§

impl Clone for NetEvent

Source§

fn clone(&self) -> NetEvent

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for NetEvent

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