pub struct Single<'w, 's, D, F = ()>where
D: QueryData,
F: QueryFilter,{ /* private fields */ }
Expand description
System parameter that provides access to single entity’s components, much like Query::single
/Query::single_mut
.
This SystemParam
fails validation if zero or more than one matching entity exists.
This will cause the system to be skipped, according to the rules laid out in SystemParamValidationError
.
Use Option<Single<D, F>>
instead if zero or one matching entities can exist.
See Query
for more details.
§Example
#[derive(Component)]
struct Boss {
health: f32
};
fn hurt_boss(mut boss: Single<&mut Boss>) {
boss.health -= 4.0;
}
Note that because Single
implements Deref
and DerefMut
, methods and fields like health
can be accessed directly.
You can also access the underlying data manually, by calling .deref
/.deref_mut
, or by using the *
operator.
Implementations§
Source§impl<'w, 's, D, F> Single<'w, 's, D, F>where
D: QueryData,
F: QueryFilter,
impl<'w, 's, D, F> Single<'w, 's, D, F>where
D: QueryData,
F: QueryFilter,
Sourcepub fn into_inner(self) -> <D as QueryData>::Item<'w, 's>
pub fn into_inner(self) -> <D as QueryData>::Item<'w, 's>
Returns the inner item with ownership.
Trait Implementations§
Source§impl<'a, 'b, D, F> SystemParam for Single<'a, 'b, D, F>where
D: QueryData + 'static,
F: QueryFilter + 'static,
impl<'a, 'b, D, F> SystemParam for Single<'a, 'b, D, F>where
D: QueryData + 'static,
F: QueryFilter + 'static,
Source§type State = QueryState<D, F>
type State = QueryState<D, F>
Used to store data which persists across invocations of a system.
Source§type Item<'w, 's> = Single<'w, 's, D, F>
type Item<'w, 's> = Single<'w, 's, D, F>
The item type returned when constructing this system param.
The value of this associated type should be
Self
, instantiated with new lifetimes. Read moreSource§fn init_state(world: &mut World) -> <Single<'a, 'b, D, F> as SystemParam>::State
fn init_state(world: &mut World) -> <Single<'a, 'b, D, F> as SystemParam>::State
Creates a new instance of this param’s
State
.Source§fn init_access(
state: &<Single<'a, 'b, D, F> as SystemParam>::State,
system_meta: &mut SystemMeta,
component_access_set: &mut FilteredAccessSet,
world: &mut World,
)
fn init_access( state: &<Single<'a, 'b, D, F> as SystemParam>::State, system_meta: &mut SystemMeta, component_access_set: &mut FilteredAccessSet, world: &mut World, )
Registers any
World
access used by this SystemParam
Source§unsafe fn get_param<'w, 's>(
state: &'s mut <Single<'a, 'b, D, F> as SystemParam>::State,
system_meta: &SystemMeta,
world: UnsafeWorldCell<'w>,
change_tick: Tick,
) -> <Single<'a, 'b, D, F> as SystemParam>::Item<'w, 's>
unsafe fn get_param<'w, 's>( state: &'s mut <Single<'a, 'b, D, F> as SystemParam>::State, system_meta: &SystemMeta, world: UnsafeWorldCell<'w>, change_tick: Tick, ) -> <Single<'a, 'b, D, F> as SystemParam>::Item<'w, 's>
Creates a parameter to be passed into a
SystemParamFunction
. Read moreSource§unsafe fn validate_param(
state: &mut <Single<'a, 'b, D, F> as SystemParam>::State,
system_meta: &SystemMeta,
world: UnsafeWorldCell<'_>,
) -> Result<(), SystemParamValidationError>
unsafe fn validate_param( state: &mut <Single<'a, 'b, D, F> as SystemParam>::State, system_meta: &SystemMeta, world: UnsafeWorldCell<'_>, ) -> Result<(), SystemParamValidationError>
Source§fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
Applies any deferred mutations stored in this
SystemParam
’s state.
This is used to apply Commands
during ApplyDeferred
.Source§fn queue(
state: &mut Self::State,
system_meta: &SystemMeta,
world: DeferredWorld<'_>,
)
fn queue( state: &mut Self::State, system_meta: &SystemMeta, world: DeferredWorld<'_>, )
Queues any deferred mutations to be applied at the next
ApplyDeferred
.impl<'a, 'b, D, F> ReadOnlySystemParam for Single<'a, 'b, D, F>where
D: ReadOnlyQueryData + 'static,
F: QueryFilter + 'static,
Auto Trait Implementations§
impl<'w, 's, D, F> Freeze for Single<'w, 's, D, F>
impl<'w, 's, D, F> RefUnwindSafe for Single<'w, 's, D, F>
impl<'w, 's, D, F> Send for Single<'w, 's, D, F>
impl<'w, 's, D, F> Sync for Single<'w, 's, D, F>
impl<'w, 's, D, F> Unpin for Single<'w, 's, D, F>
impl<'w, 's, D, F> UnwindSafe for Single<'w, 's, D, F>
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
Mutably borrows from an owned value. Read more
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
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> ⓘ
Converts
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> ⓘ
Converts
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 moreSource§impl<T> IntoResult<T> for T
impl<T> IntoResult<T> for T
Source§fn into_result(self) -> Result<T, RunSystemError>
fn into_result(self) -> Result<T, RunSystemError>
Converts this type into the system output type.