Struct bevy::reflect::utility::NonGenericTypeCell   
source · pub struct NonGenericTypeCell<T>(/* private fields */)
where
    T: TypedProperty;Expand description
A container for TypeInfo over non-generic types, allowing instances to be stored statically.
This is specifically meant for use with non-generic types. If your type is generic,
then use GenericTypeCell instead. Otherwise, it will not take into account all
monomorphizations of your type.
Non-generic TypePaths should be trivially generated with string literals and concat!.
§Example
use bevy_reflect::utility::NonGenericTypeInfoCell;
struct Foo {
    bar: i32
}
impl Typed for Foo {
    fn type_info() -> &'static TypeInfo {
        static CELL: NonGenericTypeInfoCell = NonGenericTypeInfoCell::new();
        CELL.get_or_set(|| {
            let fields = [NamedField::new::<i32>("bar")];
            let info = StructInfo::new::<Self>(&fields);
            TypeInfo::Struct(info)
        })
    }
}Implementations§
source§impl<T> NonGenericTypeCell<T>where
    T: TypedProperty,
 
impl<T> NonGenericTypeCell<T>where
    T: TypedProperty,
sourcepub const fn new() -> NonGenericTypeCell<T>
 
pub const fn new() -> NonGenericTypeCell<T>
Initialize a NonGenericTypeCell for non-generic types.
sourcepub fn get_or_set<F>(&self, f: F) -> &<T as TypedProperty>::Stored
 
pub fn get_or_set<F>(&self, f: F) -> &<T as TypedProperty>::Stored
Returns a reference to the TypedProperty stored in the cell.
If there is no entry found, a new one will be generated from the given function.
Trait Implementations§
source§impl<T> Default for NonGenericTypeCell<T>where
    T: TypedProperty,
 
impl<T> Default for NonGenericTypeCell<T>where
    T: TypedProperty,
source§fn default() -> NonGenericTypeCell<T>
 
fn default() -> NonGenericTypeCell<T>
Returns the “default value” for a type. Read more
Auto Trait Implementations§
impl<T> !Freeze for NonGenericTypeCell<T>
impl<T> RefUnwindSafe for NonGenericTypeCell<T>
impl<T> Send for NonGenericTypeCell<T>
impl<T> Sync for NonGenericTypeCell<T>
impl<T> Unpin for NonGenericTypeCell<T>
impl<T> UnwindSafe for NonGenericTypeCell<T>
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
Return the 
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
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>
Convert 
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<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>
Convert 
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> 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)
Convert 
&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)
Convert 
&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> DowncastSync for T
 
impl<T> DowncastSync for T
source§impl<S> FromSample<S> for S
 
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
source§impl<T> FromWorld for Twhere
    T: Default,
 
impl<T> FromWorld for Twhere
    T: Default,
source§fn from_world(_world: &mut World) -> T
 
fn from_world(_world: &mut World) -> T
Creates 
Self using data from the given World.