bevy_ecs::schedule

Type Alias And

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

Source

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>
where A: Clone, B: Clone,

Source§

fn clone(&self) -> Self

Clone the combined system. The cloned instance must be .initialize()d before it can run.

1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl<Func, A, B> ReadOnlySystem for CombinatorSystem<Func, A, B>
where Func: Combine<A, B> + 'static, A: ReadOnlySystem, B: ReadOnlySystem,

SAFETY: Both systems are read-only, so any system created by combining them will only read from the world.

Source§

fn run_readonly( &mut self, input: SystemIn<'_, Self>, world: &World, ) -> Self::Out

Runs this system with the given input in the world. Read more
Source§

impl<A, B, Func> System for CombinatorSystem<Func, A, B>
where Func: Combine<A, B> + 'static, A: System, B: System,

Source§

type In = <Func as Combine<A, B>>::In

The system’s input.
Source§

type Out = <Func as Combine<A, B>>::Out

The system’s output.
Source§

fn name(&self) -> Cow<'static, str>

Returns the system’s name.
Source§

fn component_access(&self) -> &Access<ComponentId>

Returns the system’s component Access.
Source§

fn archetype_component_access(&self) -> &Access<ArchetypeComponentId>

Returns the system’s archetype component Access.
Source§

fn is_send(&self) -> bool

Returns true if the system is Send.
Source§

fn is_exclusive(&self) -> bool

Returns true if the system must be run exclusively.
Source§

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

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 more
Source§

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)

Applies any Deferred system parameters (or other system buffers) of this system to the world. Read more
Source§

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

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)

Initialize the system.
Source§

fn update_archetype_component_access(&mut self, world: UnsafeWorldCell<'_>)

Update the system’s archetype component Access. Read more
Source§

fn check_change_tick(&mut self, change_tick: Tick)

Checks any Ticks stored on this system and wraps their value if they get too old. Read more
Source§

fn default_system_sets(&self) -> Vec<InternedSystemSet>

Returns the system’s default system sets. Read more
Source§

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)

Overwrites the tick indicating the last time this system ran. Read more
Source§

fn type_id(&self) -> TypeId

Returns the TypeId of the underlying system type.
Source§

fn validate_param(&mut self, world: &World) -> bool

Safe version of System::validate_param_unsafe. that runs on exclusive, single-threaded world pointer.