pub type And<A, B> = CombinatorSystem<AndMarker, A, B>;
Expand description
Combines the outputs of two systems using the &&
operator.
Aliased Type§
struct And<A, B> { /* private fields */ }
Implementations
Source§impl<Func, A, B> CombinatorSystem<Func, A, B>
impl<Func, A, B> CombinatorSystem<Func, A, B>
Sourcepub const fn new(a: A, b: B, name: Cow<'static, str>) -> Self
pub const fn new(a: A, b: B, name: Cow<'static, str>) -> Self
Creates a new system that combines two inner systems.
The returned system will only be usable if Func
implements Combine<A, B>
.
Trait Implementations
Source§impl<Func, A, B> Clone for CombinatorSystem<Func, A, B>
impl<Func, A, B> Clone for CombinatorSystem<Func, A, B>
Source§impl<Func, A, B> ReadOnlySystem for CombinatorSystem<Func, A, B>
SAFETY: Both systems are read-only, so any system created by combining them will only read from the world.
impl<Func, A, B> ReadOnlySystem for CombinatorSystem<Func, A, B>
SAFETY: Both systems are read-only, so any system created by combining them will only read from the world.
Source§impl<A, B, Func> System for CombinatorSystem<Func, A, B>
impl<A, B, Func> System for CombinatorSystem<Func, A, B>
Source§fn component_access(&self) -> &Access<ComponentId>
fn component_access(&self) -> &Access<ComponentId>
Returns the system’s component
Access
.Source§fn archetype_component_access(&self) -> &Access<ArchetypeComponentId>
fn archetype_component_access(&self) -> &Access<ArchetypeComponentId>
Returns the system’s archetype component
Access
.Source§fn is_exclusive(&self) -> bool
fn is_exclusive(&self) -> bool
Returns true if the system must be run exclusively.
Source§fn has_deferred(&self) -> bool
fn has_deferred(&self) -> bool
Returns true if system has deferred buffers.
Source§unsafe fn run_unsafe(
&mut self,
input: SystemIn<'_, Self>,
world: UnsafeWorldCell<'_>,
) -> Self::Out
unsafe fn run_unsafe( &mut self, input: SystemIn<'_, Self>, world: UnsafeWorldCell<'_>, ) -> Self::Out
Runs the system with the given input in the world. Unlike
System::run
, this function
can be called in parallel with other systems and may break Rust’s aliasing rules
if used incorrectly, making it unsafe to call. Read moreSource§fn run(&mut self, input: SystemIn<'_, Self>, world: &mut World) -> Self::Out
fn run(&mut self, input: SystemIn<'_, Self>, world: &mut World) -> Self::Out
Runs the system with the given input in the world. Read more
Source§fn apply_deferred(&mut self, world: &mut World)
fn apply_deferred(&mut self, world: &mut World)
Source§fn queue_deferred(&mut self, world: DeferredWorld<'_>)
fn queue_deferred(&mut self, world: DeferredWorld<'_>)
Enqueues any
Deferred
system parameters (or other system buffers)
of this system into the world’s command buffer.Source§unsafe fn validate_param_unsafe(&mut self, world: UnsafeWorldCell<'_>) -> bool
unsafe fn validate_param_unsafe(&mut self, world: UnsafeWorldCell<'_>) -> bool
Validates that all parameters can be acquired and that system can run without panic.
Built-in executors use this to prevent invalid systems from running. Read more
Source§fn initialize(&mut self, world: &mut World)
fn initialize(&mut self, world: &mut World)
Initialize the system.
Source§fn update_archetype_component_access(&mut self, world: UnsafeWorldCell<'_>)
fn update_archetype_component_access(&mut self, world: UnsafeWorldCell<'_>)
Source§fn check_change_tick(&mut self, change_tick: Tick)
fn check_change_tick(&mut self, change_tick: Tick)
Source§fn default_system_sets(&self) -> Vec<InternedSystemSet>
fn default_system_sets(&self) -> Vec<InternedSystemSet>
Returns the system’s default system sets. Read more
Source§fn get_last_run(&self) -> Tick
fn get_last_run(&self) -> Tick
Gets the tick indicating the last time this system ran.
Source§fn set_last_run(&mut self, last_run: Tick)
fn set_last_run(&mut self, last_run: Tick)
Overwrites the tick indicating the last time this system ran. Read more
Source§fn validate_param(&mut self, world: &World) -> bool
fn validate_param(&mut self, world: &World) -> bool
Safe version of
System::validate_param_unsafe
.
that runs on exclusive, single-threaded world
pointer.