Struct specs::prelude::Write

source ·
pub struct Write<'a, T, F = DefaultProvider>where
    T: 'a,{ /* private fields */ }
Expand description

Allows to fetch a resource in a system mutably.

If the resource isn’t strictly required, you should use Option<Write<T>>.

Type parameters

  • T: The type of the resource
  • F: The setup handler (default: DefaultProvider)

Trait Implementations§

source§

impl<'a, T, F> Deref for Write<'a, T, F>where T: Resource,

§

type Target = T

The resulting type after dereferencing.
source§

fn deref(&self) -> &T

Dereferences the value.
source§

impl<'a, T, F> DerefMut for Write<'a, T, F>where T: Resource,

source§

fn deref_mut(&mut self) -> &mut T

Mutably dereferences the value.
source§

impl<'a, T, F> From<FetchMut<'a, T>> for Write<'a, T, F>

source§

fn from(inner: FetchMut<'a, T>) -> Write<'a, T, F>

Converts to this type from the input type.
source§

impl<'a, 'b, T> Join for &'a mut Write<'b, T>where &'a mut T: Join, T: Resource,

§

type Type = <&'a mut T as Join>::Type

Type of joined components.
§

type Value = <&'a mut T as Join>::Value

Type of joined storages.
§

type Mask = <&'a mut T as Join>::Mask

Type of joined bit mask.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get(v: &mut Self::Value, i: Index) -> Self::Type

Get a joined component value by a given index. Read more
source§

fn is_unconstrained() -> bool

If this Join typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinIter to go through all indices which is usually not what is wanted and will kill performance.
source§

fn join(self) -> JoinIter<Self> where Self: Sized,

Create a joined iterator over the contents.
source§

impl<'a, 'b, T> LendJoin for &'a mut Write<'b, T>where &'a mut T: LendJoin, T: Resource,

§

type Value = <&'a mut T as LendJoin>::Value

Type of joined storages.
§

type Mask = <&'a mut T as LendJoin>::Mask

Type of joined bit mask.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get<'next>( v: &'next mut Self::Value, i: Index ) -> <Self as LendJoinඞType<'next>>::T

Get a joined component value by a given index. Read more
source§

fn is_unconstrained() -> bool

If this LendJoin typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinLendIter to go through all indices which is usually not what is wanted and will kill performance.
source§

fn lend_join(self) -> JoinLendIter<Self>where Self: Sized,

Create a joined lending iterator over the contents.
source§

fn maybe(self) -> MaybeJoin<Self>where Self: Sized,

Returns a structure that implements Join/LendJoin/MaybeJoin if the contained T does and that yields all indices, returning None for all missing elements and Some(T) for found elements. Read more
source§

impl<'a, 'b, T> ParJoin for &'a mut Write<'b, T>where &'a mut T: ParJoin, T: Resource,

§

type Type = <&'a mut T as ParJoin>::Type

Type of joined components.
§

type Value = <&'a mut T as ParJoin>::Value

Type of joined storages.
§

type Mask = <&'a mut T as ParJoin>::Mask

Type of joined bit mask.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get(v: &Self::Value, i: Index) -> Self::Type

Get a joined component value by a given index. Read more
source§

fn is_unconstrained() -> bool

If this LendJoin typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinLendIter to go through all indices which is usually not what is wanted and will kill performance.
source§

fn par_join(self) -> JoinParIter<Self>where Self: Sized,

Create a joined parallel iterator over the contents.
source§

impl<'a, T, F> SystemData<'a> for Write<'a, T, F>where T: Resource, F: SetupHandler<T>,

source§

fn setup(world: &mut World)

Sets up the system data for fetching it from the World.
source§

fn fetch(world: &'a World) -> Write<'a, T, F>

Fetches the system data from World. Note that this is only specified for one concrete lifetime 'a, you need to implement the SystemData trait for every possible lifetime.
source§

fn reads() -> Vec<ResourceId, Global>

Returns all read dependencies as fetched from Self::fetch. Read more
source§

fn writes() -> Vec<ResourceId, Global>

Returns all write dependencies as fetched from Self::fetch. Read more
source§

impl<'a, 'b, T> RepeatableLendGet for &'a mut Write<'b, T>where &'a mut T: RepeatableLendGet, T: Resource,

Auto Trait Implementations§

§

impl<'a, T, F = DefaultProvider> !RefUnwindSafe for Write<'a, T, F>

§

impl<'a, T, F> Send for Write<'a, T, F>where F: Send, T: Send,

§

impl<'a, T, F> Sync for Write<'a, T, F>where F: Sync, T: Sync,

§

impl<'a, T, F> Unpin for Write<'a, T, F>where F: Unpin,

§

impl<'a, T, F = DefaultProvider> !UnwindSafe for Write<'a, T, F>

Blanket Implementations§

source§

impl<T> AccessMut for Twhere T: DerefMut + ?Sized,

source§

fn access_mut(&mut self) -> &mut <T as Deref>::Target

This may generate a mutation event for certain flagged storages.
source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<'a, T> DynamicSystemData<'a> for Twhere T: SystemData<'a>,

§

type Accessor = StaticAccessor<T>

The accessor of the SystemData, which specifies the read and write dependencies and does the fetching.
source§

fn setup(_: &StaticAccessor<T>, world: &mut World)

Sets up World for fetching this system data.
source§

fn fetch(_: &StaticAccessor<T>, world: &'a World) -> T

Creates a new resource bundle by fetching the required resources from the World struct. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> Event for Twhere T: Send + Sync + 'static,

source§

impl<T> Resource for Twhere T: Any + Send + Sync,