pub struct CuRuntime<CT, CB, P, M, const NBCL: usize>where
P: CopperListTuple,
M: CuMonitor,{
pub clock: RobotClock,
pub tasks: CT,
pub bridges: CB,
pub resources: ResourceManager,
pub monitor: M,
pub execution_probe: Arc<RuntimeExecutionProbe>,
pub copperlists_manager: CopperListsManager<P, NBCL>,
pub keyframes_manager: KeyFramesManager,
pub runtime_config: RuntimeConfig,
}Expand description
This is the main structure that will be injected as a member of the Application struct. CT is the tuple of all the tasks in order of execution. CL is the type of the copper list, representing the input/output messages for all the tasks.
Fields§
§clock: RobotClockThe base clock the runtime will be using to record time.
tasks: CTThe tuple of all the tasks in order of execution.
bridges: CBTuple of all instantiated bridges.
resources: ResourceManagerResource registry kept alive for tasks borrowing shared handles.
monitor: MThe runtime monitoring.
execution_probe: Arc<RuntimeExecutionProbe>Runtime-side execution progress probe for watchdog/diagnostic monitors.
This probe is written from the generated execution plan before each component step. Monitors consume it asynchronously (typically from watchdog threads) to report the last known component/step/culist when the runtime appears stalled.
copperlists_manager: CopperListsManager<P, NBCL>The logger for the copper lists (messages between tasks)
keyframes_manager: KeyFramesManagerThe logger for the state of the tasks (frozen tasks)
runtime_config: RuntimeConfigThe runtime configuration controlling the behavior of the run loop
Implementations§
Source§impl<CT, CB, P, M, const NBCL: usize> CuRuntime<CT, CB, P, M, NBCL>
Helper methods injected for simulation-only builds.
impl<CT, CB, P, M, const NBCL: usize> CuRuntime<CT, CB, P, M, NBCL>
Helper methods injected for simulation-only builds.
pub fn set_forced_keyframe_timestamp(&mut self, ts: CuDuration)
Sourcepub fn lock_keyframe(&mut self, keyframe: &KeyFrame)
pub fn lock_keyframe(&mut self, keyframe: &KeyFrame)
Reuse a recorded keyframe verbatim (used during deterministic replay).
Source§impl<CT, CB, P, M, const NBCL: usize> CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> CuRuntime<CT, CB, P, M, NBCL>
Sourcepub fn record_execution_marker(&self, marker: ExecutionMarker)
pub fn record_execution_marker(&self, marker: ExecutionMarker)
Records runtime execution progress in the shared probe.
This is intentionally lightweight and does not call monitor callbacks.
pub fn new( clock: RobotClock, config: &CuConfig, mission: Option<&str>, resources_instanciator: impl Fn(&CuConfig) -> Result<ResourceManager, CuError>, tasks_instanciator: impl for<'c> Fn(Vec<Option<&'c ComponentConfig>>, &mut ResourceManager) -> Result<CT, CuError>, monitor_instanciator: impl Fn(&CuConfig) -> M, bridges_instanciator: impl Fn(&CuConfig, &mut ResourceManager) -> Result<CB, CuError>, copperlists_logger: impl WriteStream<CopperList<P>> + 'static, keyframes_logger: impl WriteStream<KeyFrame> + 'static, ) -> Result<CuRuntime<CT, CB, P, M, NBCL>, CuError>
pub fn new_with_resources( clock: RobotClock, config: &CuConfig, mission: Option<&str>, resources: ResourceManager, tasks_instanciator: impl for<'c> Fn(Vec<Option<&'c ComponentConfig>>, &mut ResourceManager) -> Result<CT, CuError>, monitor_instanciator: impl Fn(&CuConfig) -> M, bridges_instanciator: impl Fn(&CuConfig, &mut ResourceManager) -> Result<CB, CuError>, copperlists_logger: impl WriteStream<CopperList<P>> + 'static, keyframes_logger: impl WriteStream<KeyFrame> + 'static, ) -> Result<CuRuntime<CT, CB, P, M, NBCL>, CuError>
Trait Implementations§
Source§impl<CT, CB, P, M, const NBCL: usize> ClockProvider for CuRuntime<CT, CB, P, M, NBCL>
To be able to share the clock we make the runtime a clock provider.
impl<CT, CB, P, M, const NBCL: usize> ClockProvider for CuRuntime<CT, CB, P, M, NBCL>
To be able to share the clock we make the runtime a clock provider.
fn get_clock(&self) -> RobotClock
Auto Trait Implementations§
impl<CT, CB, P, M, const NBCL: usize> Freeze for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> !RefUnwindSafe for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> Send for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> Sync for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> Unpin for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> UnsafeUnpin for CuRuntime<CT, CB, P, M, NBCL>
impl<CT, CB, P, M, const NBCL: usize> !UnwindSafe for CuRuntime<CT, CB, P, M, NBCL>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more