pub struct EntityWorldMut<'w> { /* private fields */ }Expand description
A mutable reference to a particular Entity, and the entire world.
This is essentially a performance-optimized (Entity, &mut World) tuple,
which caches the EntityLocation to reduce duplicate lookups.
Since this type provides mutable access to the entire world, only one
EntityWorldMut can exist at a time for a given world.
See also EntityMut, which allows disjoint mutable access to multiple
entities at once.  Unlike EntityMut, this type allows adding and
removing components, and despawning the entity.
Implementations§
Source§impl<'w> EntityWorldMut<'w>
 
impl<'w> EntityWorldMut<'w>
Sourcepub fn with_children(
    &mut self,
    func: impl FnOnce(&mut RelatedSpawner<'_, ChildOf>),
) -> &mut EntityWorldMut<'w>
 
pub fn with_children( &mut self, func: impl FnOnce(&mut RelatedSpawner<'_, ChildOf>), ) -> &mut EntityWorldMut<'w>
Spawns children of this entity (with a ChildOf relationship) by taking a function that operates on a ChildSpawner.
See also with_related.
Sourcepub fn add_children(&mut self, children: &[Entity]) -> &mut EntityWorldMut<'w>
 
pub fn add_children(&mut self, children: &[Entity]) -> &mut EntityWorldMut<'w>
Adds the given children to this entity
See also add_related.
Sourcepub fn insert_children(
    &mut self,
    index: usize,
    children: &[Entity],
) -> &mut EntityWorldMut<'w>
 
pub fn insert_children( &mut self, index: usize, children: &[Entity], ) -> &mut EntityWorldMut<'w>
Insert children at specific index.
See also insert_related.
Sourcepub fn add_child(&mut self, child: Entity) -> &mut EntityWorldMut<'w>
 
pub fn add_child(&mut self, child: Entity) -> &mut EntityWorldMut<'w>
Adds the given child to this entity
See also add_related.
Sourcepub fn remove_children(
    &mut self,
    children: &[Entity],
) -> &mut EntityWorldMut<'w>
 
pub fn remove_children( &mut self, children: &[Entity], ) -> &mut EntityWorldMut<'w>
Removes the relationship between this entity and the given entities.
Sourcepub fn replace_children(
    &mut self,
    children: &[Entity],
) -> &mut EntityWorldMut<'w>
 
pub fn replace_children( &mut self, children: &[Entity], ) -> &mut EntityWorldMut<'w>
Replaces all the related children with a new set of children.
Sourcepub fn replace_children_with_difference(
    &mut self,
    entities_to_unrelate: &[Entity],
    entities_to_relate: &[Entity],
    newly_related_entities: &[Entity],
) -> &mut EntityWorldMut<'w>
 
pub fn replace_children_with_difference( &mut self, entities_to_unrelate: &[Entity], entities_to_relate: &[Entity], newly_related_entities: &[Entity], ) -> &mut EntityWorldMut<'w>
Replaces all the related children with a new set of children.
§Warning
Failing to maintain the functions invariants may lead to erratic engine behavior including random crashes.
Refer to Self::replace_related_with_difference for a list of these invariants.
§Panics
Panics when debug assertions are enabled if an invariant is is broken and the command is executed.
Sourcepub fn with_child(&mut self, bundle: impl Bundle) -> &mut EntityWorldMut<'w>
 
pub fn with_child(&mut self, bundle: impl Bundle) -> &mut EntityWorldMut<'w>
Spawns the passed bundle and adds it to this entity as a child.
For efficient spawning of multiple children, use with_children.
Sourcepub fn remove_parent(&mut self) -> &mut EntityWorldMut<'w>
 👎Deprecated since 0.16.0: Use entity_mut.remove::<ChildOf>()
pub fn remove_parent(&mut self) -> &mut EntityWorldMut<'w>
Removes the ChildOf component, if it exists.
Sourcepub fn set_parent(&mut self, parent: Entity) -> &mut EntityWorldMut<'w>
 👎Deprecated since 0.16.0: Use entity_mut.insert(ChildOf(entity))
pub fn set_parent(&mut self, parent: Entity) -> &mut EntityWorldMut<'w>
Inserts the ChildOf component with the given parent entity, if it exists.
Source§impl<'w> EntityWorldMut<'w>
 
impl<'w> EntityWorldMut<'w>
Sourcepub fn insert_reflect(
    &mut self,
    component: Box<dyn PartialReflect>,
) -> &mut EntityWorldMut<'w>
 
pub fn insert_reflect( &mut self, component: Box<dyn PartialReflect>, ) -> &mut EntityWorldMut<'w>
Adds the given boxed reflect component or bundle to the entity using the reflection data in
AppTypeRegistry.
This will overwrite any previous component(s) of the same type.
§Panics
- If the entity has been despawned while this EntityWorldMutis still alive.
- If AppTypeRegistrydoes not have the reflection data for the givenComponentorBundle.
- If the component or bundle data is invalid. See PartialReflect::applyfor further details.
- If AppTypeRegistryis not present in theWorld.
§Note
Prefer to use the typed EntityWorldMut::insert if possible. Adding a reflected component
is much slower.
Sourcepub fn insert_reflect_with_registry<T>(
    &mut self,
    component: Box<dyn PartialReflect>,
) -> &mut EntityWorldMut<'w>
 
pub fn insert_reflect_with_registry<T>( &mut self, component: Box<dyn PartialReflect>, ) -> &mut EntityWorldMut<'w>
Same as insert_reflect, but using
the T resource as type registry instead of AppTypeRegistry.
This will overwrite any previous component(s) of the same type.
§Panics
- If the entity has been despawned while this EntityWorldMutis still alive.
- If the given Resourcedoes not have the reflection data for the givenComponentorBundle.
- If the component or bundle data is invalid. See PartialReflect::applyfor further details.
- If the given Resourceis not present in theWorld.
Sourcepub fn remove_reflect(
    &mut self,
    component_type_path: Cow<'static, str>,
) -> &mut EntityWorldMut<'w>
 
pub fn remove_reflect( &mut self, component_type_path: Cow<'static, str>, ) -> &mut EntityWorldMut<'w>
Removes from the entity the component or bundle with the given type name registered in AppTypeRegistry.
If the type is a bundle, it will remove any components in that bundle regardless if the entity contains all the components.
Does nothing if the type is a component and the entity does not have a component of the same type,
if the type is a bundle and the entity does not contain any of the components in the bundle,
or if AppTypeRegistry does not contain the reflection data for the given component.
§Panics
- If the entity has been despawned while this EntityWorldMutis still alive.
- If AppTypeRegistryis not present in theWorld.
§Note
Prefer to use the typed EntityCommands::remove if possible. Removing a reflected component
is much slower.
Sourcepub fn remove_reflect_with_registry<T>(
    &mut self,
    component_type_path: Cow<'static, str>,
) -> &mut EntityWorldMut<'w>
 
pub fn remove_reflect_with_registry<T>( &mut self, component_type_path: Cow<'static, str>, ) -> &mut EntityWorldMut<'w>
Same as remove_reflect, but using
the T resource as type registry instead of AppTypeRegistry.
If the given type is a bundle, it will remove any components in that bundle regardless if the entity contains all the components.
Does nothing if the type is a component and the entity does not have a component of the same type,
if the type is a bundle and the entity does not contain any of the components in the bundle,
or if AppTypeRegistry does not contain the reflection data for the given component.
§Panics
- If the entity has been despawned while this EntityWorldMutis still alive.
- If AppTypeRegistryis not present in theWorld.
Source§impl<'w> EntityWorldMut<'w>
 
impl<'w> EntityWorldMut<'w>
Spawns a entity related to this entity (with the R relationship) by taking a bundle
Spawns entities related to this entity (with the R relationship) by taking a function that operates on a RelatedSpawner.
Relates the given entities to this entity with the relation R.
See add_one_related if you want relate only one entity.
Relates the given entities to this entity with the relation R, starting at this particular index.
If the related has duplicates, a related entity will take the index of its last occurrence in related.
If the indices go out of bounds, they will be clamped into bounds.
This will not re-order existing related entities unless they are in related.
§Example
use bevy_ecs::prelude::*;
let mut world = World::new();
let e0 = world.spawn_empty().id();
let e1 = world.spawn_empty().id();
let e2 = world.spawn_empty().id();
let e3 = world.spawn_empty().id();
let e4 = world.spawn_empty().id();
let mut main_entity = world.spawn_empty();
main_entity.add_related::<ChildOf>(&[e0, e1, e2, e2]);
main_entity.insert_related::<ChildOf>(1, &[e0, e3, e4, e4]);
let main_id = main_entity.id();
let relationship_source = main_entity.get::<Children>().unwrap().collection();
assert_eq!(relationship_source, &[e1, e0, e3, e2, e4]);Removes the relation R between this entity and the given entities.
Replaces all the related entities with a new set of entities.
Replaces all the related entities with a new set of entities.
This is a more efficient of Self::replace_related which doesn’t allocate.
The passed in arguments must adhere to these invariants:
- entities_to_unrelate: A slice of entities to remove from the relationship source. Entities need not be related to this entity, but must not appear in- entities_to_relate
- entities_to_relate: A slice of entities to relate to this entity. This must contain all entities that will remain related (i.e. not those in- entities_to_unrelate) plus the newly related entities.
- newly_related_entities: A subset of- entities_to_relatecontaining only entities not already related to this entity.
- Slices must not contain any duplicates
§Warning
Violating these invariants may lead to panics, crashes or unpredictable engine behavior.
§Panics
Panics when debug assertions are enabled and any invariants are broken.
Relates the given entity to this with the relation R.
See add_related if you want to relate more than one entity.
Despawns entities that relate to this one via the given RelationshipTarget.
This entity will not be despawned.
Sourcepub fn insert_recursive<S>(
    &mut self,
    bundle: impl Bundle + Clone,
) -> &mut EntityWorldMut<'w>where
    S: RelationshipTarget,
 
pub fn insert_recursive<S>(
    &mut self,
    bundle: impl Bundle + Clone,
) -> &mut EntityWorldMut<'w>where
    S: RelationshipTarget,
Inserts a component or bundle of components into the entity and all related entities,
traversing the relationship tracked in S in a breadth-first manner.
§Warning
This method should only be called on relationships that form a tree-like structure. Any cycles will cause this method to loop infinitely.
Sourcepub fn remove_recursive<S, B>(&mut self) -> &mut EntityWorldMut<'w>where
    S: RelationshipTarget,
    B: Bundle,
 
pub fn remove_recursive<S, B>(&mut self) -> &mut EntityWorldMut<'w>where
    S: RelationshipTarget,
    B: Bundle,
Removes a component or bundle of components of type B from the entity and all related entities,
traversing the relationship tracked in S in a breadth-first manner.
§Warning
This method should only be called on relationships that form a tree-like structure. Any cycles will cause this method to loop infinitely.
Source§impl<'w> EntityWorldMut<'w>
 
impl<'w> EntityWorldMut<'w>
Sourcepub fn into_readonly(self) -> EntityRef<'w>
 
pub fn into_readonly(self) -> EntityRef<'w>
Consumes self and returns read-only access to all of the entity’s
components, with the world 'w lifetime.
Sourcepub fn as_readonly(&self) -> EntityRef<'_>
 
pub fn as_readonly(&self) -> EntityRef<'_>
Gets read-only access to all of the entity’s components.
Sourcepub fn into_mutable(self) -> EntityMut<'w>
 
pub fn into_mutable(self) -> EntityMut<'w>
Consumes self and returns non-structural mutable access to all of the
entity’s components, with the world 'w lifetime.
Sourcepub fn as_mutable(&mut self) -> EntityMut<'_>
 
pub fn as_mutable(&mut self) -> EntityMut<'_>
Gets non-structural mutable access to all of the entity’s components.
Sourcepub fn location(&self) -> EntityLocation
 
pub fn location(&self) -> EntityLocation
Gets metadata indicating the location where the current entity is stored.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn archetype(&self) -> &Archetype
 
pub fn archetype(&self) -> &Archetype
Returns the archetype that the current entity belongs to.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn contains<T>(&self) -> boolwhere
    T: Component,
 
pub fn contains<T>(&self) -> boolwhere
    T: Component,
Returns true if the current entity has a component of type T.
Otherwise, this returns false.
§Notes
If you do not know the concrete type of a component, consider using
Self::contains_id or Self::contains_type_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn contains_id(&self, component_id: ComponentId) -> bool
 
pub fn contains_id(&self, component_id: ComponentId) -> bool
Returns true if the current entity has a component identified by component_id.
Otherwise, this returns false.
§Notes
- If you know the concrete type of the component, you should prefer Self::contains.
- If you know the component’s TypeIdbut not itsComponentId, consider usingSelf::contains_type_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn contains_type_id(&self, type_id: TypeId) -> bool
 
pub fn contains_type_id(&self, type_id: TypeId) -> bool
Returns true if the current entity has a component with the type identified by type_id.
Otherwise, this returns false.
§Notes
- If you know the concrete type of the component, you should prefer Self::contains.
- If you have a ComponentIdinstead of aTypeId, consider usingSelf::contains_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get<T>(&self) -> Option<&T>where
    T: Component,
 
pub fn get<T>(&self) -> Option<&T>where
    T: Component,
Gets access to the component of type T for the current entity.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn components<Q>(&self) -> <Q as QueryData>::Item<'_>where
    Q: ReadOnlyQueryData,
 
pub fn components<Q>(&self) -> <Q as QueryData>::Item<'_>where
    Q: ReadOnlyQueryData,
Returns read-only components for the current entity that match the query Q.
§Panics
If the entity does not have the components required by the query Q or if the entity
has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get_components<Q>(&self) -> Option<<Q as QueryData>::Item<'_>>where
    Q: ReadOnlyQueryData,
 
pub fn get_components<Q>(&self) -> Option<<Q as QueryData>::Item<'_>>where
    Q: ReadOnlyQueryData,
Returns read-only components for the current entity that match the query Q,
or None if the entity does not have the components required by the query Q.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn into_borrow<T>(self) -> Option<&'w T>where
    T: Component,
 
pub fn into_borrow<T>(self) -> Option<&'w T>where
    T: Component,
Consumes self and gets access to the component of type T with
the world 'w lifetime for the current entity.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn into_ref<T>(self) -> Option<Ref<'w, T>>where
    T: Component,
 
pub fn into_ref<T>(self) -> Option<Ref<'w, T>>where
    T: Component,
Consumes self and gets access to the component of type T
with the world 'w lifetime for the current entity,
including change detection information as a Ref.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get_mut<T>(&mut self) -> Option<Mut<'_, T>>
 
pub fn get_mut<T>(&mut self) -> Option<Mut<'_, T>>
Gets mutable access to the component of type T for the current entity.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn modify_component<T, R>(
    &mut self,
    f: impl FnOnce(&mut T) -> R,
) -> Option<R>where
    T: Component,
 
pub fn modify_component<T, R>(
    &mut self,
    f: impl FnOnce(&mut T) -> R,
) -> Option<R>where
    T: Component,
Temporarily removes a Component T from this Entity and runs the
provided closure on it, returning the result if T was available.
This will trigger the OnRemove and OnReplace component hooks without
causing an archetype move.
This is most useful with immutable components, where removal and reinsertion is the only way to modify a value.
If you do not need to ensure the above hooks are triggered, and your component
is mutable, prefer using get_mut.
§Examples
#[derive(Component, PartialEq, Eq, Debug)]
#[component(immutable)]
struct Foo(bool);
entity.modify_component(|foo: &mut Foo| {
    foo.0 = true;
});§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn modify_component_by_id<R>(
    &mut self,
    component_id: ComponentId,
    f: impl for<'a> FnOnce(MutUntyped<'a>) -> R,
) -> Option<R>
 
pub fn modify_component_by_id<R>( &mut self, component_id: ComponentId, f: impl for<'a> FnOnce(MutUntyped<'a>) -> R, ) -> Option<R>
Temporarily removes a Component T from this Entity and runs the
provided closure on it, returning the result if T was available.
This will trigger the OnRemove and OnReplace component hooks without
causing an archetype move.
This is most useful with immutable components, where removal and reinsertion is the only way to modify a value.
If you do not need to ensure the above hooks are triggered, and your component
is mutable, prefer using get_mut.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub unsafe fn get_mut_assume_mutable<T>(&mut self) -> Option<Mut<'_, T>>where
    T: Component,
 
pub unsafe fn get_mut_assume_mutable<T>(&mut self) -> Option<Mut<'_, T>>where
    T: Component,
Gets mutable access to the component of type T for the current entity.
Returns None if the entity does not have a component of type T.
§Safety
- Tmust be a mutable component
Sourcepub fn into_mut<T>(self) -> Option<Mut<'w, T>>
 
pub fn into_mut<T>(self) -> Option<Mut<'w, T>>
Consumes self and gets mutable access to the component of type T
with the world 'w lifetime for the current entity.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub unsafe fn into_mut_assume_mutable<T>(self) -> Option<Mut<'w, T>>where
    T: Component,
 
pub unsafe fn into_mut_assume_mutable<T>(self) -> Option<Mut<'w, T>>where
    T: Component,
Consumes self and gets mutable access to the component of type T
with the world 'w lifetime for the current entity.
Returns None if the entity does not have a component of type T.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
§Safety
- Tmust be a mutable component
Sourcepub fn resource<R>(&self) -> &Rwhere
    R: Resource,
 
pub fn resource<R>(&self) -> &Rwhere
    R: Resource,
Gets a reference to the resource of the given type
§Panics
Panics if the resource does not exist.
Use get_resource instead if you want to handle this case.
Sourcepub fn resource_mut<R>(&mut self) -> Mut<'_, R>where
    R: Resource,
 
pub fn resource_mut<R>(&mut self) -> Mut<'_, R>where
    R: Resource,
Gets a mutable reference to the resource of the given type
§Panics
Panics if the resource does not exist.
Use get_resource_mut instead if you want to handle this case.
If you want to instead insert a value if the resource does not exist,
use get_resource_or_insert_with.
Sourcepub fn get_resource<R>(&self) -> Option<&R>where
    R: Resource,
 
pub fn get_resource<R>(&self) -> Option<&R>where
    R: Resource,
Gets a reference to the resource of the given type if it exists
Sourcepub fn get_resource_mut<R>(&mut self) -> Option<Mut<'_, R>>where
    R: Resource,
 
pub fn get_resource_mut<R>(&mut self) -> Option<Mut<'_, R>>where
    R: Resource,
Gets a mutable reference to the resource of the given type if it exists
Sourcepub fn get_change_ticks<T>(&self) -> Option<ComponentTicks>where
    T: Component,
 
pub fn get_change_ticks<T>(&self) -> Option<ComponentTicks>where
    T: Component,
Retrieves the change ticks for the given component. This can be useful for implementing change detection in custom runtimes.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get_change_ticks_by_id(
    &self,
    component_id: ComponentId,
) -> Option<ComponentTicks>
 
pub fn get_change_ticks_by_id( &self, component_id: ComponentId, ) -> Option<ComponentTicks>
Retrieves the change ticks for the given ComponentId. This can be useful for implementing change
detection in custom runtimes.
You should prefer to use the typed API EntityWorldMut::get_change_ticks where possible and only
use this in cases where the actual component types are not known at
compile time.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get_by_id<F>(
    &self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Ref<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub fn get_by_id<F>(
    &self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Ref<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
Returns untyped read-only reference(s) to component(s) for the
current entity, based on the given ComponentIds.
You should prefer to use the typed API EntityWorldMut::get where
possible and only use this in cases where the actual component types
are not known at compile time.
Unlike EntityWorldMut::get, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
Returns EntityComponentError::MissingComponent if the entity does
not have a component.
§Examples
For examples on how to use this method, see EntityRef::get_by_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn into_borrow_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Ref<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub fn into_borrow_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Ref<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
Consumes self and returns untyped read-only reference(s) to
component(s) with lifetime 'w for the current entity, based on the
given ComponentIds.
You should prefer to use the typed API EntityWorldMut::into_borrow
where possible and only use this in cases where the actual component
types are not known at compile time.
Unlike EntityWorldMut::into_borrow, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
Returns EntityComponentError::MissingComponent if the entity does
not have a component.
§Examples
For examples on how to use this method, see EntityRef::get_by_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn get_mut_by_id<F>(
    &mut self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub fn get_mut_by_id<F>(
    &mut self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
Returns untyped mutable reference(s) to component(s) for
the current entity, based on the given ComponentIds.
You should prefer to use the typed API EntityWorldMut::get_mut where
possible and only use this in cases where the actual component types
are not known at compile time.
Unlike EntityWorldMut::get_mut, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
- Returns EntityComponentError::MissingComponentif the entity does not have a component.
- Returns EntityComponentError::AliasedMutabilityif a component is requested multiple times.
§Examples
For examples on how to use this method, see EntityMut::get_mut_by_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub unsafe fn get_mut_assume_mutable_by_id<F>(
    &mut self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub unsafe fn get_mut_assume_mutable_by_id<F>(
    &mut self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'_>, EntityComponentError>where
    F: DynamicComponentFetch,
Returns untyped mutable reference(s) to component(s) for
the current entity, based on the given ComponentIds.
Assumes the given ComponentIds refer to mutable components.
You should prefer to use the typed API EntityWorldMut::get_mut_assume_mutable where
possible and only use this in cases where the actual component types
are not known at compile time.
Unlike EntityWorldMut::get_mut_assume_mutable, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
- Returns EntityComponentError::MissingComponentif the entity does not have a component.
- Returns EntityComponentError::AliasedMutabilityif a component is requested multiple times.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
§Safety
It is the callers responsibility to ensure that
- the provided ComponentIds must refer to mutable components.
Sourcepub fn into_mut_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub fn into_mut_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
Consumes self and returns untyped mutable reference(s)
to component(s) with lifetime 'w for the current entity, based on the
given ComponentIds.
You should prefer to use the typed API EntityWorldMut::into_mut where
possible and only use this in cases where the actual component types
are not known at compile time.
Unlike EntityWorldMut::into_mut, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
- Returns EntityComponentError::MissingComponentif the entity does not have a component.
- Returns EntityComponentError::AliasedMutabilityif a component is requested multiple times.
§Examples
For examples on how to use this method, see EntityMut::get_mut_by_id.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub unsafe fn into_mut_assume_mutable_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
 
pub unsafe fn into_mut_assume_mutable_by_id<F>(
    self,
    component_ids: F,
) -> Result<<F as DynamicComponentFetch>::Mut<'w>, EntityComponentError>where
    F: DynamicComponentFetch,
Consumes self and returns untyped mutable reference(s)
to component(s) with lifetime 'w for the current entity, based on the
given ComponentIds.
Assumes the given ComponentIds refer to mutable components.
You should prefer to use the typed API EntityWorldMut::into_mut_assume_mutable where
possible and only use this in cases where the actual component types
are not known at compile time.
Unlike EntityWorldMut::into_mut_assume_mutable, this returns untyped reference(s) to
component(s), and it’s the job of the caller to ensure the correct
type(s) are dereferenced (if necessary).
§Errors
- Returns EntityComponentError::MissingComponentif the entity does not have a component.
- Returns EntityComponentError::AliasedMutabilityif a component is requested multiple times.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
§Safety
It is the callers responsibility to ensure that
- the provided ComponentIds must refer to mutable components.
Sourcepub fn insert<T>(&mut self, bundle: T) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn insert<T>(&mut self, bundle: T) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Sourcepub fn insert_with_relationship_hook_mode<T>(
    &mut self,
    bundle: T,
    relationship_hook_mode: RelationshipHookMode,
) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn insert_with_relationship_hook_mode<T>(
    &mut self,
    bundle: T,
    relationship_hook_mode: RelationshipHookMode,
) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Adds a Bundle of components to the entity.
Relationship components in the bundle will follow the configuration
in relationship_hook_mode.
This will overwrite any previous value(s) of the same component type.
§Warning
This can easily break the integrity of relationships. This is intended to be used for cloning and spawning code internals, not most user-facing scenarios.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn insert_if_new<T>(&mut self, bundle: T) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn insert_if_new<T>(&mut self, bundle: T) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Sourcepub unsafe fn insert_by_id(
    &mut self,
    component_id: ComponentId,
    component: OwningPtr<'_>,
) -> &mut EntityWorldMut<'w>
 
pub unsafe fn insert_by_id( &mut self, component_id: ComponentId, component: OwningPtr<'_>, ) -> &mut EntityWorldMut<'w>
Inserts a dynamic Component into the entity.
This will overwrite any previous value(s) of the same component type.
You should prefer to use the typed API EntityWorldMut::insert where possible.
§Safety
- ComponentIdmust be from the same world as- EntityWorldMut
- OwningPtrmust be a valid reference to the type represented by- ComponentId
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub unsafe fn insert_by_ids<'a, I>(
    &mut self,
    component_ids: &[ComponentId],
    iter_components: I,
) -> &mut EntityWorldMut<'w>
 
pub unsafe fn insert_by_ids<'a, I>( &mut self, component_ids: &[ComponentId], iter_components: I, ) -> &mut EntityWorldMut<'w>
Inserts a dynamic Bundle into the entity.
This will overwrite any previous value(s) of the same component type.
You should prefer to use the typed API EntityWorldMut::insert where possible.
If your Bundle only has one component, use the cached API EntityWorldMut::insert_by_id.
If possible, pass a sorted slice of ComponentId to maximize caching potential.
§Safety
- Each ComponentIdmust be from the same world asEntityWorldMut
- Each OwningPtrmust be a valid reference to the type represented byComponentId
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn take<T>(&mut self) -> Option<T>where
    T: Bundle + BundleFromComponents,
 
pub fn take<T>(&mut self) -> Option<T>where
    T: Bundle + BundleFromComponents,
Sourcepub fn remove<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn remove<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Removes any components in the Bundle from the entity.
See EntityCommands::remove for more details.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn remove_with_requires<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn remove_with_requires<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Sourcepub fn retain<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
 
pub fn retain<T>(&mut self) -> &mut EntityWorldMut<'w>where
    T: Bundle,
Removes any components except those in the Bundle (and its Required Components) from the entity.
See EntityCommands::retain for more details.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn remove_by_id(
    &mut self,
    component_id: ComponentId,
) -> &mut EntityWorldMut<'w>
 
pub fn remove_by_id( &mut self, component_id: ComponentId, ) -> &mut EntityWorldMut<'w>
Removes a dynamic Component from the entity if it exists.
You should prefer to use the typed API EntityWorldMut::remove where possible.
§Panics
Panics if the provided ComponentId does not exist in the World or if the
entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn remove_by_ids(
    &mut self,
    component_ids: &[ComponentId],
) -> &mut EntityWorldMut<'w>
 
pub fn remove_by_ids( &mut self, component_ids: &[ComponentId], ) -> &mut EntityWorldMut<'w>
Removes a dynamic bundle from the entity if it exists.
You should prefer to use the typed API EntityWorldMut::remove where possible.
§Panics
Panics if any of the provided ComponentIds do not exist in the World or if the
entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn clear(&mut self) -> &mut EntityWorldMut<'w>
 
pub fn clear(&mut self) -> &mut EntityWorldMut<'w>
Removes all components associated with the entity.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn despawn(self)
 
pub fn despawn(self)
Despawns the current entity.
See World::despawn for more details.
§Note
This will also despawn any Children entities, and any other RelationshipTarget that is configured
to despawn descendants. This results in “recursive despawn” behavior.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn despawn_recursive(self)
 👎Deprecated since 0.16.0: Use entity.despawn(), which now automatically despawns recursively.
pub fn despawn_recursive(self)
Despawns the provided entity and its descendants.
Sourcepub fn flush(self) -> Entity
 
pub fn flush(self) -> Entity
Ensures any commands triggered by the actions of Self are applied, equivalent to World::flush
Sourcepub fn world(&self) -> &World
 
pub fn world(&self) -> &World
Gets read-only access to the world that the current entity belongs to.
Sourcepub unsafe fn world_mut(&mut self) -> &mut World
 
pub unsafe fn world_mut(&mut self) -> &mut World
Returns this entity’s world.
See EntityWorldMut::world_scope or EntityWorldMut::into_world_mut for a safe alternative.
§Safety
Caller must not modify the world in a way that changes the current entity’s location
If the caller does do something that could change the location, self.update_location()
must be called before using any other methods on this EntityWorldMut.
Sourcepub fn into_world_mut(self) -> &'w mut World
 
pub fn into_world_mut(self) -> &'w mut World
Returns this entity’s World, consuming itself.
Sourcepub fn world_scope<U>(&mut self, f: impl FnOnce(&mut World) -> U) -> U
 
pub fn world_scope<U>(&mut self, f: impl FnOnce(&mut World) -> U) -> U
Gives mutable access to this entity’s World in a temporary scope.
This is a safe alternative to using EntityWorldMut::world_mut.
§Examples
#[derive(Resource, Default, Clone, Copy)]
struct R(u32);
// This closure gives us temporary access to the world.
let new_r = entity.world_scope(|world: &mut World| {
    // Mutate the world while we have access to it.
    let mut r = world.resource_mut::<R>();
    r.0 += 1;
    // Return a value from the world before giving it back to the `EntityWorldMut`.
    *r
});Sourcepub fn update_location(&mut self)
 
pub fn update_location(&mut self)
Updates the internal entity location to match the current location in the internal
World.
This is only required when using the unsafe function EntityWorldMut::world_mut,
which enables the location to change.
Sourcepub fn is_despawned(&self) -> bool
 
pub fn is_despawned(&self) -> bool
Returns if the entity has been despawned.
Normally it shouldn’t be needed to explicitly check if the entity has been despawned
between commands as this shouldn’t happen. However, for some special cases where it
is known that a hook or an observer might despawn the entity while a EntityWorldMut
reference is still held, this method can be used to check if the entity is still alive
to avoid panicking when calling further methods.
Sourcepub fn entry<'a, T>(&'a mut self) -> Entry<'w, 'a, T>where
    T: Component,
 
pub fn entry<'a, T>(&'a mut self) -> Entry<'w, 'a, T>where
    T: Component,
Gets an Entry into the world for this entity and component for in-place manipulation.
The type parameter specifies which component to get.
§Examples
#[derive(Component, Default, Clone, Copy, Debug, PartialEq)]
struct Comp(u32);
let mut entity = world.spawn_empty();
entity.entry().or_insert_with(|| Comp(4));
assert_eq!(world.query::<&Comp>().single(&world).unwrap().0, 4);
entity.entry::<Comp>().and_modify(|mut c| c.0 += 1);
assert_eq!(world.query::<&Comp>().single(&world).unwrap().0, 5);§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn trigger(&mut self, event: impl Event) -> &mut EntityWorldMut<'w>
 
pub fn trigger(&mut self, event: impl Event) -> &mut EntityWorldMut<'w>
Triggers the given event for this entity, which will run any observers watching for it.
§Panics
If the entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn observe<E, B, M>(
    &mut self,
    observer: impl IntoObserverSystem<E, B, M>,
) -> &mut EntityWorldMut<'w>
 
pub fn observe<E, B, M>( &mut self, observer: impl IntoObserverSystem<E, B, M>, ) -> &mut EntityWorldMut<'w>
Sourcepub fn clone_with(
    &mut self,
    target: Entity,
    config: impl FnOnce(&mut EntityClonerBuilder<'_>) + Send + Sync + 'static,
) -> &mut EntityWorldMut<'w>
 
pub fn clone_with( &mut self, target: Entity, config: impl FnOnce(&mut EntityClonerBuilder<'_>) + Send + Sync + 'static, ) -> &mut EntityWorldMut<'w>
Clones parts of an entity (components, observers, etc.) onto another entity,
configured through EntityClonerBuilder.
By default, the other entity will receive all the components of the original that implement
Clone or Reflect.
Configure through EntityClonerBuilder as follows:
world.entity_mut(entity).clone_with(target, |builder| {
    builder.deny::<ComponentB>();
});See EntityClonerBuilder for more options.
§Panics
- If this entity has been despawned while this EntityWorldMutis still alive.
- If the target entity does not exist.
Sourcepub fn clone_and_spawn(&mut self) -> Entity
 
pub fn clone_and_spawn(&mut self) -> Entity
Spawns a clone of this entity and returns the Entity of the clone.
The clone will receive all the components of the original that implement
Clone or Reflect.
To configure cloning behavior (such as only cloning certain components),
use EntityWorldMut::clone_and_spawn_with.
§Panics
If this entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn clone_and_spawn_with(
    &mut self,
    config: impl FnOnce(&mut EntityClonerBuilder<'_>) + Send + Sync + 'static,
) -> Entity
 
pub fn clone_and_spawn_with( &mut self, config: impl FnOnce(&mut EntityClonerBuilder<'_>) + Send + Sync + 'static, ) -> Entity
Spawns a clone of this entity and allows configuring cloning behavior
using EntityClonerBuilder, returning the Entity of the clone.
By default, the clone will receive all the components of the original that implement
Clone or Reflect.
Configure through EntityClonerBuilder as follows:
let entity_clone = world.entity_mut(entity).clone_and_spawn_with(|builder| {
    builder.deny::<ComponentB>();
});See EntityClonerBuilder for more options.
§Panics
If this entity has been despawned while this EntityWorldMut is still alive.
Sourcepub fn clone_components<B>(&mut self, target: Entity) -> &mut EntityWorldMut<'w>where
    B: Bundle,
 
pub fn clone_components<B>(&mut self, target: Entity) -> &mut EntityWorldMut<'w>where
    B: Bundle,
Sourcepub fn move_components<B>(&mut self, target: Entity) -> &mut EntityWorldMut<'w>where
    B: Bundle,
 
pub fn move_components<B>(&mut self, target: Entity) -> &mut EntityWorldMut<'w>where
    B: Bundle,
Clones the specified components of this entity and inserts them into another entity, then removes the components from this entity.
Components can only be cloned if they implement
Clone or Reflect.
§Panics
- If this entity has been despawned while this EntityWorldMutis still alive.
- If the target entity does not exist.
Sourcepub fn spawned_by(&self) -> MaybeLocation
 
pub fn spawned_by(&self) -> MaybeLocation
Returns the source code location from which this entity has last been spawned.
Trait Implementations§
Source§impl BuildChildrenTransformExt for EntityWorldMut<'_>
 
impl BuildChildrenTransformExt for EntityWorldMut<'_>
Source§fn set_parent_in_place(&mut self, parent: Entity) -> &mut EntityWorldMut<'_>
 
fn set_parent_in_place(&mut self, parent: Entity) -> &mut EntityWorldMut<'_>
GlobalTransform
by updating its Transform. Read moreSource§fn remove_parent_in_place(&mut self) -> &mut EntityWorldMut<'_>
 
fn remove_parent_in_place(&mut self) -> &mut EntityWorldMut<'_>
GlobalTransform
by updating its Transform to be equal to its current GlobalTransform. Read moreSource§impl<'a> From<&'a EntityWorldMut<'_>> for EntityRef<'a>
 
impl<'a> From<&'a EntityWorldMut<'_>> for EntityRef<'a>
Source§fn from(entity: &'a EntityWorldMut<'_>) -> EntityRef<'a>
 
fn from(entity: &'a EntityWorldMut<'_>) -> EntityRef<'a>
Source§impl<'a> From<&'a mut EntityWorldMut<'_>> for EntityMut<'a>
 
impl<'a> From<&'a mut EntityWorldMut<'_>> for EntityMut<'a>
Source§fn from(entity: &'a mut EntityWorldMut<'_>) -> EntityMut<'a>
 
fn from(entity: &'a mut EntityWorldMut<'_>) -> EntityMut<'a>
Source§impl<'w> From<EntityWorldMut<'w>> for EntityMut<'w>
 
impl<'w> From<EntityWorldMut<'w>> for EntityMut<'w>
Source§fn from(entity: EntityWorldMut<'w>) -> EntityMut<'w>
 
fn from(entity: EntityWorldMut<'w>) -> EntityMut<'w>
Source§impl<'w> From<EntityWorldMut<'w>> for EntityRef<'w>
 
impl<'w> From<EntityWorldMut<'w>> for EntityRef<'w>
Source§fn from(entity: EntityWorldMut<'w>) -> EntityRef<'w>
 
fn from(entity: EntityWorldMut<'w>) -> EntityRef<'w>
Auto Trait Implementations§
impl<'w> Freeze for EntityWorldMut<'w>
impl<'w> !RefUnwindSafe for EntityWorldMut<'w>
impl<'w> Send for EntityWorldMut<'w>
impl<'w> Sync for EntityWorldMut<'w>
impl<'w> Unpin for EntityWorldMut<'w>
impl<'w> !UnwindSafe for EntityWorldMut<'w>
Blanket Implementations§
Source§impl<T, U> AsBindGroupShaderType<U> for T
 
impl<T, U> AsBindGroupShaderType<U> for T
Source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
 
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T ShaderType for self. When used in AsBindGroup
derives, it is safe to assume that all images in self exist.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.Source§impl<T> DowncastSend for T
 
impl<T> DowncastSend for T
Source§impl<S> FromSample<S> for S
 
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
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>
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