pub struct EntityFetcher<'w> { /* private fields */ }
Expand description
Provides a safe interface for non-structural access to the entities in a World
.
This cannot add or remove components, or spawn or despawn entities,
making it relatively safe to access in concert with other ECS data.
This type can be constructed via World::entities_and_commands
,
or DeferredWorld::entities_and_commands
.
Implementations§
Source§impl<'w> EntityFetcher<'w>
impl<'w> EntityFetcher<'w>
Sourcepub fn get<F: WorldEntityFetch>(
&self,
entities: F,
) -> Result<F::Ref<'_>, EntityDoesNotExistError>
pub fn get<F: WorldEntityFetch>( &self, entities: F, ) -> Result<F::Ref<'_>, EntityDoesNotExistError>
Returns EntityRef
s that expose read-only operations for the given
entities
, returning Err
if any of the given entities do not exist.
This function supports fetching a single entity or multiple entities:
- Pass an
Entity
to receive a singleEntityRef
. - Pass a slice of
Entity
s to receive aVec<EntityRef>
. - Pass an array of
Entity
s to receive an equally-sized array ofEntityRef
s. - Pass a reference to a
EntityHashSet
to receive anEntityHashMap<EntityRef>
.
§Errors
If any of the given entities
do not exist in the world, the first
Entity
found to be missing will return an EntityDoesNotExistError
.
§Examples
For examples, see World::entity
.
Sourcepub fn get_mut<F: WorldEntityFetch>(
&mut self,
entities: F,
) -> Result<F::DeferredMut<'_>, EntityMutableFetchError>
pub fn get_mut<F: WorldEntityFetch>( &mut self, entities: F, ) -> Result<F::DeferredMut<'_>, EntityMutableFetchError>
Returns EntityMut
s that expose read and write operations for the
given entities
, returning Err
if any of the given entities do not
exist.
This function supports fetching a single entity or multiple entities:
- Pass an
Entity
to receive a singleEntityMut
.- This reference type allows for structural changes to the entity, such as adding or removing components, or despawning the entity.
- Pass a slice of
Entity
s to receive aVec<EntityMut>
. - Pass an array of
Entity
s to receive an equally-sized array ofEntityMut
s. - Pass a reference to a
EntityHashSet
to receive anEntityHashMap<EntityMut>
.
§Errors
- Returns
EntityMutableFetchError::EntityDoesNotExist
if any of the givenentities
do not exist in the world.- Only the first entity found to be missing will be returned.
- Returns
EntityMutableFetchError::AliasedMutability
if the same entity is requested multiple times.
§Examples
For examples, see DeferredWorld::entity_mut
.
Auto Trait Implementations§
impl<'w> Freeze for EntityFetcher<'w>
impl<'w> !RefUnwindSafe for EntityFetcher<'w>
impl<'w> Send for EntityFetcher<'w>
impl<'w> Sync for EntityFetcher<'w>
impl<'w> Unpin for EntityFetcher<'w>
impl<'w> !UnwindSafe for EntityFetcher<'w>
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
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>
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>
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)
&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)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.