Struct ReflectReference

Source
#[non_exhaustive]
pub struct ReflectReference { pub base: ReflectBaseType, pub reflect_path: ParsedPath, }
Expand description

A reference to an arbitrary reflected instance.

The reference can point to either the ECS, or to the allocator.

References are composed of two parts:

  • The base kind, which specifies where the reference points to
  • The path, which specifies how to access the value from the base.

Bindings defined on this type, apply to ALL references.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§base: ReflectBaseType

The base type and id of the value we want to access

§reflect_path: ParsedPath

The path from the top level type to the actual value we want to access

Implementations§

Source§

impl ReflectReference

Source

pub fn variant_name( &self, world: WorldAccessGuard<'_>, ) -> Result<Option<String>, InteropError>

If this points to a variant of an enum, returns the name of the variant.

Source

pub fn into_iter_infinite(self) -> ReflectRefIter

Creates a new infinite iterator. This iterator will keep returning the next element reference forever.

Source

pub fn len( &self, world: WorldAccessGuard<'_>, ) -> Result<Option<usize>, InteropError>

If this is a reference to something with a length accessible via reflection, returns that length.

Source

pub fn new_allocated<T>( value: T, allocator: &mut ReflectAllocator, ) -> ReflectReference
where T: Reflect,

Create a new reference to a value by allocating it.

You can retrieve the allocator from the world using WorldGuard::allocator. Make sure to drop the allocator write guard before doing anything with the reference to prevent deadlocks.

Source

pub fn new_allocated_boxed_parial_reflect( value: Box<dyn PartialReflect>, allocator: &mut ReflectAllocator, ) -> Result<ReflectReference, InteropError>

Create a new reference to a value by allocating it.

Prefer using Self::new_allocated if you have a value that implements Reflect. Will fail if the value does not have represented type info with a specific type id.

Source

pub fn new_allocated_boxed( value: Box<dyn Reflect>, allocator: &mut ReflectAllocator, ) -> ReflectReference

Create a new reference to a value by allocating it.

Source

pub fn new_resource_ref<T>( world: WorldAccessGuard<'_>, ) -> Result<ReflectReference, InteropError>
where T: Resource,

Create a new reference to resource

Source

pub fn new_component_ref<T>( entity: Entity, world: WorldAccessGuard<'_>, ) -> Result<ReflectReference, InteropError>
where T: Component,

Create a new reference to component

Source

pub fn index_path<T>(&mut self, index: T)
where T: Into<ParsedPath>,

Indexes into the reflect path inside this reference. You can use [Self::reflect] and Self::reflect_mut to get the actual value.

Source

pub fn downcast<O>( &self, world: WorldAccessGuard<'_>, ) -> Result<O, InteropError>
where O: Clone + PartialReflect,

Tries to downcast to the specified type and cloning the value if successful.

Source

pub fn to_owned_value( &self, world: WorldAccessGuard<'_>, ) -> Result<Box<dyn PartialReflect>, InteropError>

Attempts to create a Box<dyn PartialReflect> from the reference. This is possible using a few strategies:

  • If the reference is to a world, a [WorldCallbackAccess] is created and boxed
  • If the reference is to an allocation with no reflection path and references to it, the value is taken as is.
  • If the reference has a bevy::reflect::ReflectFromReflect type data associated with it, the value is cloned using that impl.
  • If all above fails, bevy::reflect::PartialReflect::clone_value is used to clone the value.
Source

pub fn with_reflect<O, F>( &self, world: WorldAccessGuard<'_>, f: F, ) -> Result<O, InteropError>
where F: FnOnce(&(dyn PartialReflect + 'static)) -> O,

The way to access the value of the reference, that is the pointed-to value. This method is safe to use as it ensures no-one else has aliasing access to the value at the same time.

Source

pub fn with_reflect_mut<O, F>( &self, world: WorldAccessGuard<'_>, f: F, ) -> Result<O, InteropError>
where F: FnOnce(&mut (dyn PartialReflect + 'static)) -> O,

The way to access the value of the reference, that is the pointed-to value. This method is safe to use as it ensures no-one else has aliasing access to the value at the same time.

Source

pub fn tail_type_id( &self, world: WorldAccessGuard<'_>, ) -> Result<Option<TypeId>, InteropError>

Retrieves the type id of the value the reference points to.

Source

pub fn element_type_id( &self, world: WorldAccessGuard<'_>, ) -> Result<Option<TypeId>, InteropError>

Retrieves the type id of the elements in the value the reference points to.

Source

pub fn key_type_id( &self, world: WorldAccessGuard<'_>, ) -> Result<Option<TypeId>, InteropError>

Retrieves the type id of the keys in the value the reference points to.

Source

pub fn type_id_of( &self, source: TypeIdSource, world: WorldAccessGuard<'_>, ) -> Result<Option<TypeId>, InteropError>

Retrieves the type id of the value the reference points to based on the given source.

Source

pub unsafe fn reflect_unsafe<'w>( &self, world: WorldAccessGuard<'w>, ) -> Result<&'w (dyn PartialReflect + 'static), InteropError>

Retrieves a reference to the underlying dyn PartialReflect type valid for the ’w lifetime of the world cell

§Safety
  • The caller must ensure the cell has permission to access the underlying value
  • The caller must ensure no aliasing references to the same value exist at all at the same time

To do this safely you need to use [WorldAccessGuard::claim_read_access] or [WorldAccessGuard::claim_global_access] to ensure nobody else is currently accessing the value.

Source

pub unsafe fn reflect_mut_unsafe<'w>( &self, world: WorldAccessGuard<'w>, ) -> Result<&'w mut (dyn PartialReflect + 'static), InteropError>

Retrieves mutable reference to the underlying dyn PartialReflect type valid for the ’w lifetime of the world cell

§Safety
  • The caller must ensure the cell has permission to access the underlying value
  • The caller must ensure no other references to the same value exist at all at the same time (even if you have the correct access)

To do this safely you need to use [WorldAccessGuard::claim_write_access] or [WorldAccessGuard::claim_global_access] to ensure nobody else is currently accessing the value.

Trait Implementations§

Source§

impl ArgMeta for ReflectReference

Source§

fn default_value() -> Option<ScriptValue>

The default value for the argument. Used when the argument is not provided.
Source§

impl AsRef<ReflectReference> for LuaReflectReference

Source§

fn as_ref(&self) -> &ReflectReference

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<ReflectReference> for RhaiReflectReference

Source§

fn as_ref(&self) -> &ReflectReference

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Clone for ReflectReference

Source§

fn clone(&self) -> ReflectReference

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ReflectReference

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for ReflectReference

Source§

fn default() -> ReflectReference

Returns the “default value” for a type. Read more
Source§

impl DisplayWithWorld for ReflectReference

Source§

fn display_with_world(&self, world: WorldAccessGuard<'_>) -> String

Display the shallowest representation of the type using world access. For references this is the type path and the type of the value they are pointing to.
Source§

fn display_value_with_world(&self, world: WorldAccessGuard<'_>) -> String

Display the most literal representation of the type using world access. I.e. for references this would be the pointed to value itself.
Source§

fn display_without_world(&self) -> String

Warning Read more
Source§

impl From<LuaReflectReference> for ReflectReference

Source§

fn from(value: LuaReflectReference) -> ReflectReference

Converts to this type from the input type.
Source§

impl From<ReflectReference> for LuaReflectReference

Source§

fn from(value: ReflectReference) -> LuaReflectReference

Converts to this type from the input type.
Source§

impl From<ReflectReference> for RhaiReflectReference

Source§

fn from(value: ReflectReference) -> RhaiReflectReference

Converts to this type from the input type.
Source§

impl From<ReflectReference> for ScriptValue

Source§

fn from(value: ReflectReference) -> ScriptValue

Converts to this type from the input type.
Source§

impl From<RhaiReflectReference> for ReflectReference

Source§

fn from(value: RhaiReflectReference) -> ReflectReference

Converts to this type from the input type.
Source§

impl FromReflect for ReflectReference

Source§

fn from_reflect( reflect: &(dyn PartialReflect + 'static), ) -> Option<ReflectReference>

Constructs a concrete instance of Self from a reflected value.
Source§

fn take_from_reflect( reflect: Box<dyn PartialReflect>, ) -> Result<Self, Box<dyn PartialReflect>>

Attempts to downcast the given value to Self using, constructing the value using from_reflect if that fails. Read more
Source§

impl FromScript for ReflectReference

Source§

type This<'w> = ReflectReference

The type that is constructed from the script value.
Source§

fn from_script( value: ScriptValue, _world: WorldAccessGuard<'_>, ) -> Result<ReflectReference, InteropError>

Construct a value of type T from a ScriptValue.
Source§

impl GetTypeDependencies for ReflectReference

Source§

type Underlying = ReflectReference

In the majority of the implementations, this will be Self However some types might be facades for other types, in which case this will be the underlying type
Source§

fn register_type_dependencies(registry: &mut TypeRegistry)

Registers the type dependencies of the implementing type with the given TypeRegistry.
Source§

impl GetTypeRegistration for ReflectReference

Source§

fn get_type_registration() -> TypeRegistration

Returns the default TypeRegistration for this type.
Source§

fn register_type_dependencies(registry: &mut TypeRegistry)

Registers other types needed by this type. Read more
Source§

impl IntoScript for ReflectReference

Source§

fn into_script( self, _world: WorldAccessGuard<'_>, ) -> Result<ScriptValue, InteropError>

Convert this value into a ScriptValue.
Source§

fn into_script_inline_error(self, world: WorldAccessGuard<'_>) -> ScriptValue
where Self: Sized,

Convert this value into a ScriptValue, returning an error as a ScriptValue if an error occurs.
Source§

impl IntoScriptRef for ReflectReference

Source§

fn into_script_ref( self_: ReflectReference, world: WorldAccessGuard<'_>, ) -> Result<ScriptValue, InteropError>

Converts a value represented by a reference into a [crate::bindings::function::ScriptValue].
Source§

impl PartialEq for ReflectReference

Source§

fn eq(&self, other: &ReflectReference) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialReflect for ReflectReference

Source§

fn get_represented_type_info(&self) -> Option<&'static TypeInfo>

Returns the TypeInfo of the type represented by this value. Read more
Source§

fn clone_value(&self) -> Box<dyn PartialReflect>

Clones the value as a Reflect trait object. Read more
Source§

fn try_apply( &mut self, value: &(dyn PartialReflect + 'static), ) -> Result<(), ApplyError>

Tries to apply a reflected value to this value. Read more
Source§

fn reflect_kind(&self) -> ReflectKind

Returns a zero-sized enumeration of “kinds” of type. Read more
Source§

fn reflect_ref(&self) -> ReflectRef<'_>

Returns an immutable enumeration of “kinds” of type. Read more
Source§

fn reflect_mut(&mut self) -> ReflectMut<'_>

Returns a mutable enumeration of “kinds” of type. Read more
Source§

fn reflect_owned(self: Box<ReflectReference>) -> ReflectOwned

Returns an owned enumeration of “kinds” of type. Read more
Source§

fn try_into_reflect( self: Box<ReflectReference>, ) -> Result<Box<dyn Reflect>, Box<dyn PartialReflect>>

Attempts to cast this type to a boxed, fully-reflected value.
Source§

fn try_as_reflect(&self) -> Option<&(dyn Reflect + 'static)>

Attempts to cast this type to a fully-reflected value.
Source§

fn try_as_reflect_mut(&mut self) -> Option<&mut (dyn Reflect + 'static)>

Attempts to cast this type to a mutable, fully-reflected value.
Source§

fn into_partial_reflect(self: Box<ReflectReference>) -> Box<dyn PartialReflect>

Casts this type to a boxed, reflected value. Read more
Source§

fn as_partial_reflect(&self) -> &(dyn PartialReflect + 'static)

Casts this type to a reflected value. Read more
Source§

fn as_partial_reflect_mut(&mut self) -> &mut (dyn PartialReflect + 'static)

Casts this type to a mutable, reflected value. Read more
Source§

fn apply(&mut self, value: &(dyn PartialReflect + 'static))

Applies a reflected value to this value. Read more
Source§

fn reflect_hash(&self) -> Option<u64>

Returns a hash of the value (which includes the type). Read more
Source§

fn reflect_partial_eq( &self, _value: &(dyn PartialReflect + 'static), ) -> Option<bool>

Returns a “partial equality” comparison result. Read more
Source§

fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Debug formatter for the value. Read more
Source§

fn serializable(&self) -> Option<Serializable<'_>>

Returns a serializable version of the value. Read more
Source§

fn is_dynamic(&self) -> bool

Indicates whether or not this type is a dynamic type. Read more
Source§

impl Reflect for ReflectReference

Source§

fn into_any(self: Box<ReflectReference>) -> Box<dyn Any>

Returns the value as a Box<dyn Any>. Read more
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Returns the value as a &dyn Any. Read more
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Returns the value as a &mut dyn Any. Read more
Source§

fn into_reflect(self: Box<ReflectReference>) -> Box<dyn Reflect>

Casts this type to a boxed, fully-reflected value.
Source§

fn as_reflect(&self) -> &(dyn Reflect + 'static)

Casts this type to a fully-reflected value.
Source§

fn as_reflect_mut(&mut self) -> &mut (dyn Reflect + 'static)

Casts this type to a mutable, fully-reflected value.
Source§

fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>

Performs a type-checked assignment of a reflected value to this value. Read more
Source§

impl TypePath for ReflectReference

Source§

fn type_path() -> &'static str

Returns the fully qualified path of the underlying type. Read more
Source§

fn short_type_path() -> &'static str

Returns a short, pretty-print enabled path to the type. Read more
Source§

fn type_ident() -> Option<&'static str>

Returns the name of the type, or None if it is anonymous. Read more
Source§

fn crate_name() -> Option<&'static str>

Returns the name of the crate the type is in, or None if it is anonymous. Read more
Source§

fn module_path() -> Option<&'static str>

Returns the path to the module the type is in, or None if it is anonymous. Read more
Source§

impl Typed for ReflectReference

Source§

fn type_info() -> &'static TypeInfo

Returns the compile-time info for the underlying type.
Source§

impl TypedThrough for ReflectReference

Source§

impl Eq for ReflectReference

Source§

impl StructuralPartialEq for ReflectReference

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

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>

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)

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)

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
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DynEq for T
where T: Any + Eq,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Casts the type to dyn Any.
Source§

fn dyn_eq(&self, other: &(dyn DynEq + 'static)) -> bool

This method tests for self and other values to be equal. Read more
Source§

impl<T> DynamicTypePath for T
where T: TypePath,

Source§

impl<T> DynamicTyped for T
where T: Typed,

Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromWorld for T
where T: Default,

Source§

fn from_world(_world: &mut World) -> T

Creates Self using default().

Source§

impl<T> GetPath for T
where T: Reflect + ?Sized,

Source§

fn reflect_path<'p>( &self, path: impl ReflectPath<'p>, ) -> Result<&(dyn PartialReflect + 'static), ReflectPathError<'p>>

Returns a reference to the value specified by path. Read more
Source§

fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut (dyn PartialReflect + 'static), ReflectPathError<'p>>

Returns a mutable reference to the value specified by path. Read more
Source§

fn path<'p, T>( &self, path: impl ReflectPath<'p>, ) -> Result<&T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed reference to the value specified by path. Read more
Source§

fn path_mut<'p, T>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed mutable reference to the value specified by path. Read more
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where 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.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> IntoNamespace for T
where T: 'static + ?Sized,

Source§

fn into_namespace() -> Namespace

Converts this type into a Namespace
Source§

impl<T> PartialReflectExt for T
where T: PartialReflect + ?Sized,

Source§

fn from_reflect_or_clone( reflect: &(dyn PartialReflect + 'static), world: WorldAccessGuard<'_>, ) -> Box<dyn PartialReflect>

Try creating an owned partial reflect from a reference. Will try using ReflectFromReflect first, and if that fails, will clone the value using PartialReflect::clone_value.

Source§

fn is_type(&self, crate_name: Option<&str>, type_ident: &str) -> bool

Check if the represented type is from the given crate and has the given type identifier, returns false if not representing any type or if the type is not from the given crate or does not have the given type identifier.
Source§

fn expect_type( &self, crate_name: Option<&str>, type_ident: &str, ) -> Result<(), InteropError>

Equivalent to PartialReflectExt::is_type but returns an appropriate error if the type is not the expected one.
Source§

fn as_option( &self, ) -> Result<Option<&(dyn PartialReflect + 'static)>, InteropError>

If the type is an option, returns either the inner value or None if the option is None. Errors if the type is not an option.
Source§

fn as_option_mut( &mut self, ) -> Result<Option<&mut (dyn PartialReflect + 'static)>, InteropError>

Similar to PartialReflectExt::as_option but for mutable references.
Source§

fn as_list( &self, ) -> Result<impl Iterator<Item = &(dyn PartialReflect + 'static)>, InteropError>

If the type is an iterable list-like type, returns an iterator over the elements.
Source§

fn set_as_list<F>( &mut self, other: Box<dyn PartialReflect>, apply: F, ) -> Result<(), InteropError>
where F: Fn(&mut (dyn PartialReflect + 'static), &(dyn PartialReflect + 'static)) -> Result<(), InteropError>,

If the type is an iterable list-like type, sets the elements of the list to the elements of the other list-like type. This acts as a set operation, so the left list will have the same length as the right list after this operation.
Source§

fn as_usize(&self) -> Result<usize, InteropError>

If the type is a usize, returns the value as a usize otherwise throws a convenient error
Source§

fn try_insert_boxed( &mut self, key: Box<dyn PartialReflect>, value: Box<dyn PartialReflect>, ) -> Result<(), InteropError>

Inserts into the type at the given key, if the type supports inserting with the given key
Source§

fn try_push_boxed( &mut self, value: Box<dyn PartialReflect>, ) -> Result<(), InteropError>

Tries to insert the given value into the type, if the type is a container type. The insertion will happen at the natural end of the container. For lists, this is the length of the list. For sets, this will simply insert the value into the set. For maps, there is no natural end, so the push will error out
Source§

fn convert_to_0_indexed_key(&mut self)

Convert index keys to 0-indexed keys if this type is an index key.
Source§

fn try_clear(&mut self) -> Result<(), InteropError>

If the type is a container type, empties the contents
Source§

fn try_map_get( &self, key: &(dyn PartialReflect + 'static), ) -> Result<Option<&(dyn PartialReflect + 'static)>, InteropError>

Try to get a reference to the given key in an underyling map, if the type is a map.
Source§

fn try_pop_boxed(&mut self) -> Result<Box<dyn PartialReflect>, InteropError>

If the type has a natural last element to pop, pops the last element and returns it as a boxed value.
Source§

fn try_remove_boxed( &mut self, key: Box<dyn PartialReflect>, ) -> Result<Option<Box<dyn PartialReflect>>, InteropError>

Try to remove the value at the given key, if the type supports removing with the given key.
Source§

fn element_type_id(&self) -> Option<TypeId>

If the type is a container type, returns the type id of the elements in the container. For maps, this is the type id of the values.
Source§

fn key_type_id(&self) -> Option<TypeId>

If the type is a container type, returns the type id of the keys in the container. For lists and arrays, this is the type id of usize. For maps, this is the type id of the keys.
Source§

fn from_reflect( reflect: &(dyn PartialReflect + 'static), world: WorldAccessGuard<'_>, ) -> Result<Box<dyn Reflect>, InteropError>

Tries to construct the concrete underlying type from a possibly untyped reference
Source§

fn allocate( boxed: Box<dyn Reflect>, world: WorldAccessGuard<'_>, ) -> ReflectReference

Allocate a new boxed reflect reference from a boxed reflect.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

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 T
where U: TryFrom<T>,

Source§

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> TypeData for T
where T: 'static + Send + Sync + Clone,

Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ConditionalSend for T
where T: Send,

Source§

impl<T> Context for T
where T: 'static + Send,

Source§

impl<T> MaybeSend for T
where T: Send,

Source§

impl<T> Reflectable for T

Source§

impl<T> Runtime for T
where T: Default + 'static + Send + Sync,

Source§

impl<T> ScriptArgument for T

Source§

impl<T> ScriptReturn for T

Source§

impl<T> Settings for T
where T: 'static + Send + Sync,

Source§

impl<T> TypedScriptArgument for T

Source§

impl<T> TypedScriptReturn for T