pub struct FilteredResourcesMut<'w, 's> { /* private fields */ }Expand description
Provides mutable access to a set of Resources defined by the contained Access.
Use FilteredResources if you only need read-only access to resources.
To be useful as a SystemParam,
this must be configured using a FilteredResourcesMutParamBuilder
to build the system using a SystemParamBuilder.
§Examples
// Use `FilteredResourcesMutParamBuilder` to declare access to resources.
let system = (FilteredResourcesMutParamBuilder::new(|builder| {
    builder.add_write::<B>().add_read::<C>().add_write::<D>();
}),)
    .build_state(&mut world)
    .build_system(resource_system);
world.init_resource::<A>();
world.init_resource::<C>();
world.init_resource::<D>();
fn resource_system(mut res: FilteredResourcesMut) {
    // The resource exists, but we have no access, so we can't read it or write it.
    assert!(res.get::<A>().is_err());
    assert!(res.get_mut::<A>().is_err());
    // The resource doesn't exist, so we can't read it or write it.
    assert!(res.get::<B>().is_err());
    assert!(res.get_mut::<B>().is_err());
    // The resource exists and we have read access, so we can read it but not write it.
    let c = res.get::<C>().unwrap();
    assert!(res.get_mut::<C>().is_err());
    // The resource exists and we have write access, so we can read it or write it.
    let d = res.get::<D>().unwrap();
    let d = res.get_mut::<D>().unwrap();
    // The type parameter can be left out if it can be determined from use.
    let c: Ref<C> = res.get().unwrap();
}This can be used alongside ordinary Res and ResMut parameters if they do not conflict.
let system = (
    FilteredResourcesMutParamBuilder::new(|builder| {
        builder.add_read::<A>().add_write::<B>();
    }),
    ParamBuilder,
    ParamBuilder,
)
    .build_state(&mut world)
    .build_system(resource_system);
// Read access to A does not conflict with read access to A or write access to C.
// Write access to B does not conflict with access to A or C.
fn resource_system(mut filtered: FilteredResourcesMut, res_a: Res<A>, res_mut_c: ResMut<C>) {
    let res_a_2: Ref<A> = filtered.get::<A>().unwrap();
    let res_mut_b: Mut<B> = filtered.get_mut::<B>().unwrap();
}But it will conflict if it tries to read the same resource that another parameter writes, or write the same resource that another parameter reads.
let system = (
    FilteredResourcesMutParamBuilder::new(|builder| {
        builder.add_write::<A>();
    }),
    ParamBuilder,
)
    .build_state(&mut world)
    .build_system(invalid_resource_system);
// Read access to A conflicts with write access to A.
fn invalid_resource_system(filtered: FilteredResourcesMut, res_a: Res<A>) { }Implementations§
Source§impl<'w, 's> FilteredResourcesMut<'w, 's>
 
impl<'w, 's> FilteredResourcesMut<'w, 's>
Sourcepub fn as_readonly(&self) -> FilteredResources<'_, 's>
 
pub fn as_readonly(&self) -> FilteredResources<'_, 's>
Gets read-only access to all of the resources this FilteredResourcesMut can access.
Sourcepub fn reborrow(&mut self) -> FilteredResourcesMut<'_, 's>
 
pub fn reborrow(&mut self) -> FilteredResourcesMut<'_, 's>
Returns a new instance with a shorter lifetime.
This is useful if you have &mut FilteredResourcesMut, but you need FilteredResourcesMut.
Sourcepub fn access(&self) -> &Access<ComponentId>
 
pub fn access(&self) -> &Access<ComponentId>
Returns a reference to the underlying Access.
Sourcepub fn has_read<R>(&self) -> boolwhere
    R: Resource,
 
pub fn has_read<R>(&self) -> boolwhere
    R: Resource,
Returns true if the FilteredResources has read access to the given resource.
Note that Self::get() may still return Err if the resource does not exist.
Sourcepub fn has_write<R>(&self) -> boolwhere
    R: Resource,
 
pub fn has_write<R>(&self) -> boolwhere
    R: Resource,
Returns true if the FilteredResources has write access to the given resource.
Note that Self::get_mut() may still return Err if the resource does not exist.
Sourcepub fn get<R>(&self) -> Result<Ref<'_, R>, ResourceFetchError>where
    R: Resource,
 
pub fn get<R>(&self) -> Result<Ref<'_, R>, ResourceFetchError>where
    R: Resource,
Gets a reference to the resource of the given type if it exists and the FilteredResources has access to it.
Sourcepub fn get_by_id(
    &self,
    component_id: ComponentId,
) -> Result<Ptr<'_>, ResourceFetchError>
 
pub fn get_by_id( &self, component_id: ComponentId, ) -> Result<Ptr<'_>, ResourceFetchError>
Gets a pointer to the resource with the given ComponentId if it exists and the FilteredResources has access to it.
Sourcepub fn get_mut<R>(&mut self) -> Result<Mut<'_, R>, ResourceFetchError>where
    R: Resource,
 
pub fn get_mut<R>(&mut self) -> Result<Mut<'_, R>, ResourceFetchError>where
    R: Resource,
Gets a mutable reference to the resource of the given type if it exists and the FilteredResources has access to it.
Sourcepub fn get_mut_by_id(
    &mut self,
    component_id: ComponentId,
) -> Result<MutUntyped<'_>, ResourceFetchError>
 
pub fn get_mut_by_id( &mut self, component_id: ComponentId, ) -> Result<MutUntyped<'_>, ResourceFetchError>
Gets a mutable pointer to the resource with the given ComponentId if it exists and the FilteredResources has access to it.
Sourcepub fn into_mut<R>(self) -> Result<Mut<'w, R>, ResourceFetchError>where
    R: Resource,
 
pub fn into_mut<R>(self) -> Result<Mut<'w, R>, ResourceFetchError>where
    R: Resource,
Consumes self and gets mutable access to resource of the given type with the world 'w lifetime if it exists and the FilteredResources has access to it.
Sourcepub fn into_mut_by_id(
    self,
    component_id: ComponentId,
) -> Result<MutUntyped<'w>, ResourceFetchError>
 
pub fn into_mut_by_id( self, component_id: ComponentId, ) -> Result<MutUntyped<'w>, ResourceFetchError>
Consumes self and gets mutable access to resource with the given ComponentId with the world 'w lifetime if it exists and the FilteredResources has access to it.
Trait Implementations§
Source§impl<'w, 's> From<&'w FilteredResourcesMut<'_, 's>> for FilteredResources<'w, 's>
 
impl<'w, 's> From<&'w FilteredResourcesMut<'_, 's>> for FilteredResources<'w, 's>
Source§fn from(
    resources: &'w FilteredResourcesMut<'_, 's>,
) -> FilteredResources<'w, 's>
 
fn from( resources: &'w FilteredResourcesMut<'_, 's>, ) -> FilteredResources<'w, 's>
Source§impl<'w> From<&'w mut World> for FilteredResourcesMut<'w, 'static>
 
impl<'w> From<&'w mut World> for FilteredResourcesMut<'w, 'static>
Source§fn from(value: &'w mut World) -> FilteredResourcesMut<'w, 'static>
 
fn from(value: &'w mut World) -> FilteredResourcesMut<'w, 'static>
Source§impl<'w, 's> From<FilteredResourcesMut<'w, 's>> for FilteredResources<'w, 's>
 
impl<'w, 's> From<FilteredResourcesMut<'w, 's>> for FilteredResources<'w, 's>
Source§fn from(resources: FilteredResourcesMut<'w, 's>) -> FilteredResources<'w, 's>
 
fn from(resources: FilteredResourcesMut<'w, 's>) -> FilteredResources<'w, 's>
Source§impl SystemParam for FilteredResourcesMut<'_, '_>
 
impl SystemParam for FilteredResourcesMut<'_, '_>
Source§type State = Access<ComponentId>
 
type State = Access<ComponentId>
Source§type Item<'world, 'state> = FilteredResourcesMut<'world, 'state>
 
type Item<'world, 'state> = FilteredResourcesMut<'world, 'state>
Self, instantiated with new lifetimes. Read moreSource§fn init_state(
    _world: &mut World,
    _system_meta: &mut SystemMeta,
) -> <FilteredResourcesMut<'_, '_> as SystemParam>::State
 
fn init_state( _world: &mut World, _system_meta: &mut SystemMeta, ) -> <FilteredResourcesMut<'_, '_> as SystemParam>::State
World access used by this SystemParam
and creates a new instance of this param’s State.Source§unsafe fn get_param<'world, 'state>(
    state: &'state mut <FilteredResourcesMut<'_, '_> as SystemParam>::State,
    system_meta: &SystemMeta,
    world: UnsafeWorldCell<'world>,
    change_tick: Tick,
) -> <FilteredResourcesMut<'_, '_> as SystemParam>::Item<'world, 'state>
 
unsafe fn get_param<'world, 'state>( state: &'state mut <FilteredResourcesMut<'_, '_> as SystemParam>::State, system_meta: &SystemMeta, world: UnsafeWorldCell<'world>, change_tick: Tick, ) -> <FilteredResourcesMut<'_, '_> as SystemParam>::Item<'world, 'state>
SystemParamFunction. Read moreSource§unsafe fn new_archetype(
    state: &mut Self::State,
    archetype: &Archetype,
    system_meta: &mut SystemMeta,
)
 
unsafe fn new_archetype( state: &mut Self::State, archetype: &Archetype, system_meta: &mut SystemMeta, )
Archetype, registers the components accessed by this SystemParam (if applicable).a Read moreSource§fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
 
fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
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<'_>, )
ApplyDeferred.Source§unsafe fn validate_param(
    state: &Self::State,
    system_meta: &SystemMeta,
    world: UnsafeWorldCell<'_>,
) -> Result<(), SystemParamValidationError>
 
unsafe fn validate_param( state: &Self::State, system_meta: &SystemMeta, world: UnsafeWorldCell<'_>, ) -> Result<(), SystemParamValidationError>
Source§impl<'w, 's, T> SystemParamBuilder<FilteredResourcesMut<'w, 's>> for FilteredResourcesMutParamBuilder<T>where
    T: FnOnce(&mut FilteredResourcesMutBuilder<'_>),
 
impl<'w, 's, T> SystemParamBuilder<FilteredResourcesMut<'w, 's>> for FilteredResourcesMutParamBuilder<T>where
    T: FnOnce(&mut FilteredResourcesMutBuilder<'_>),
Source§fn build(
    self,
    world: &mut World,
    meta: &mut SystemMeta,
) -> <FilteredResourcesMut<'w, 's> as SystemParam>::State
 
fn build( self, world: &mut World, meta: &mut SystemMeta, ) -> <FilteredResourcesMut<'w, 's> as SystemParam>::State
World access used by this SystemParam
and creates a new instance of this param’s State.Source§fn build_state(self, world: &mut World) -> SystemState<P>
 
fn build_state(self, world: &mut World) -> SystemState<P>
SystemState from a SystemParamBuilder.
To create a system, call SystemState::build_system on the result.Auto Trait Implementations§
impl<'w, 's> Freeze for FilteredResourcesMut<'w, 's>
impl<'w, 's> !RefUnwindSafe for FilteredResourcesMut<'w, 's>
impl<'w, 's> Send for FilteredResourcesMut<'w, 's>
impl<'w, 's> Sync for FilteredResourcesMut<'w, 's>
impl<'w, 's> Unpin for FilteredResourcesMut<'w, 's>
impl<'w, 's> !UnwindSafe for FilteredResourcesMut<'w, 's>
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