pub struct EntityRefExcept<'w, B>where
B: Bundle,{ /* private fields */ }
Expand description
Provides read-only access to a single entity and all its components, save for an explicitly-enumerated set.
Implementations§
Source§impl<'w, B> EntityRefExcept<'w, B>where
B: Bundle,
impl<'w, B> EntityRefExcept<'w, B>where
B: Bundle,
Sourcepub fn get<C>(&self) -> Option<&'w C>where
C: Component,
pub fn get<C>(&self) -> Option<&'w C>where
C: Component,
Gets access to the component of type C
for the current entity. Returns
None
if the component doesn’t have a component of that type or if the
type is one of the excluded components.
Sourcepub fn get_ref<C>(&self) -> Option<Ref<'w, C>>where
C: Component,
pub fn get_ref<C>(&self) -> Option<Ref<'w, C>>where
C: Component,
Gets access to the component of type C
for the current entity,
including change detection information. Returns None
if the component
doesn’t have a component of that type or if the type is one of the
excluded components.
Sourcepub fn spawned_by(&self) -> MaybeLocation
pub fn spawned_by(&self) -> MaybeLocation
Returns the source code location from which this entity has been spawned.
Sourcepub fn get_by_id(&self, component_id: ComponentId) -> Option<Ptr<'w>>
pub fn get_by_id(&self, component_id: ComponentId) -> Option<Ptr<'w>>
Gets the component of the given ComponentId
from the entity.
You should prefer to use the typed API Self::get
where possible and only
use this in cases where the actual component types are not known at
compile time.
Unlike EntityRefExcept::get
, this returns a raw pointer to the component,
which is only valid while the EntityRefExcept
is alive.
Sourcepub fn contains<T: Component>(&self) -> bool
pub fn contains<T: Component>(&self) -> bool
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
.
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
TypeId
but not itsComponentId
, consider usingSelf::contains_type_id
.
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
ComponentId
instead of aTypeId
, consider usingSelf::contains_id
.
Sourcepub fn get_change_ticks<T: Component>(&self) -> Option<ComponentTicks>
pub fn get_change_ticks<T: Component>(&self) -> Option<ComponentTicks>
Retrieves the change ticks for the given component. This can be useful for implementing change detection in custom runtimes.
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 Self::get_change_ticks
where possible and only
use this in cases where the actual component types are not known at
compile time.
Trait Implementations§
Source§impl<B: Bundle> Clone for EntityRefExcept<'_, B>
impl<B: Bundle> Clone for EntityRefExcept<'_, B>
Source§impl<B: Bundle> ContainsEntity for EntityRefExcept<'_, B>
impl<B: Bundle> ContainsEntity for EntityRefExcept<'_, B>
Source§impl<'a, B> From<&'a EntityMutExcept<'_, B>> for EntityRefExcept<'a, B>where
B: Bundle,
impl<'a, B> From<&'a EntityMutExcept<'_, B>> for EntityRefExcept<'a, B>where
B: Bundle,
Source§fn from(entity: &'a EntityMutExcept<'_, B>) -> Self
fn from(entity: &'a EntityMutExcept<'_, B>) -> Self
Source§impl<'a, B: Bundle> From<&'a EntityRefExcept<'_, B>> for FilteredEntityRef<'a>
impl<'a, B: Bundle> From<&'a EntityRefExcept<'_, B>> for FilteredEntityRef<'a>
Source§fn from(value: &'a EntityRefExcept<'_, B>) -> Self
fn from(value: &'a EntityRefExcept<'_, B>) -> Self
Source§impl<B: Bundle> Hash for EntityRefExcept<'_, B>
impl<B: Bundle> Hash for EntityRefExcept<'_, B>
Source§impl<B: Bundle> Ord for EntityRefExcept<'_, B>
impl<B: Bundle> Ord for EntityRefExcept<'_, B>
Source§impl<B: Bundle> PartialEq for EntityRefExcept<'_, B>
impl<B: Bundle> PartialEq for EntityRefExcept<'_, B>
Source§impl<B: Bundle> PartialOrd for EntityRefExcept<'_, B>
impl<B: Bundle> PartialOrd for EntityRefExcept<'_, B>
Source§fn partial_cmp(&self, other: &Self) -> Option<Ordering>
fn partial_cmp(&self, other: &Self) -> Option<Ordering>
EntityRefExcept
’s comparison trait implementations match the underlying Entity
,
and cannot discern between different worlds.
Source§impl<'a, B> QueryData for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: Self
is the same as Self::ReadOnly
.
impl<'a, B> QueryData for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: Self
is the same as Self::ReadOnly
.
Source§const IS_READ_ONLY: bool = true
const IS_READ_ONLY: bool = true
Source§type ReadOnly = EntityRefExcept<'a, B>
type ReadOnly = EntityRefExcept<'a, B>
QueryData
, which satisfies the ReadOnlyQueryData
trait.Source§type Item<'w> = EntityRefExcept<'w, B>
type Item<'w> = EntityRefExcept<'w, B>
WorldQuery
This will be the data retrieved by the query,
and is visible to the end user when calling e.g. Query<Self>::get
.Source§fn shrink<'wlong: 'wshort, 'wshort>(
item: Self::Item<'wlong>,
) -> Self::Item<'wshort>
fn shrink<'wlong: 'wshort, 'wshort>( item: Self::Item<'wlong>, ) -> Self::Item<'wshort>
Source§unsafe fn fetch<'w>(
world: &mut Self::Fetch<'w>,
entity: Entity,
_: TableRow,
) -> Self::Item<'w>
unsafe fn fetch<'w>( world: &mut Self::Fetch<'w>, entity: Entity, _: TableRow, ) -> Self::Item<'w>
Self::Item
for either the given entity
in the current Table
,
or for the given entity
in the current Archetype
. This must always be called after
WorldQuery::set_table
with a table_row
in the range of the current Table
or after
WorldQuery::set_archetype
with an entity
in the current archetype.
Accesses components registered in WorldQuery::update_component_access
. Read moreSource§impl<'a, B> WorldQuery for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: EntityRefExcept
guards access to all components in the bundle B
and populates Access
values so that queries that conflict with this access
are rejected.
impl<'a, B> WorldQuery for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: EntityRefExcept
guards access to all components in the bundle B
and populates Access
values so that queries that conflict with this access
are rejected.
Source§const IS_DENSE: bool = true
const IS_DENSE: bool = true
Source§type Fetch<'w> = UnsafeWorldCell<'w>
type Fetch<'w> = UnsafeWorldCell<'w>
WorldQuery
to compute Self::Item
for each entity.Source§type State = SmallVec<[ComponentId; 4]>
type State = SmallVec<[ComponentId; 4]>
Self::Fetch
. This will be cached inside QueryState
,
so it is best to move as much data / computation here as possible to reduce the cost of
constructing Self::Fetch
.Source§fn shrink_fetch<'wlong: 'wshort, 'wshort>(
fetch: Self::Fetch<'wlong>,
) -> Self::Fetch<'wshort>
fn shrink_fetch<'wlong: 'wshort, 'wshort>( fetch: Self::Fetch<'wlong>, ) -> Self::Fetch<'wshort>
Source§unsafe fn init_fetch<'w>(
world: UnsafeWorldCell<'w>,
_: &Self::State,
_: Tick,
_: Tick,
) -> Self::Fetch<'w>
unsafe fn init_fetch<'w>( world: UnsafeWorldCell<'w>, _: &Self::State, _: Tick, _: Tick, ) -> Self::Fetch<'w>
Self::Fetch
,
by combining data from the World
with the cached Self::State
.
Readonly accesses resources registered in WorldQuery::update_component_access
. Read moreSource§unsafe fn set_archetype<'w>(
_: &mut Self::Fetch<'w>,
_: &Self::State,
_: &'w Archetype,
_: &'w Table,
)
unsafe fn set_archetype<'w>( _: &mut Self::Fetch<'w>, _: &Self::State, _: &'w Archetype, _: &'w Table, )
Archetype
. This will always be called on
archetypes that match this WorldQuery
. Read moreSource§unsafe fn set_table<'w>(_: &mut Self::Fetch<'w>, _: &Self::State, _: &'w Table)
unsafe fn set_table<'w>(_: &mut Self::Fetch<'w>, _: &Self::State, _: &'w Table)
Table
. This will always be called on tables
that match this WorldQuery
. Read moreSource§fn update_component_access(
state: &Self::State,
filtered_access: &mut FilteredAccess<ComponentId>,
)
fn update_component_access( state: &Self::State, filtered_access: &mut FilteredAccess<ComponentId>, )
Source§fn init_state(world: &mut World) -> Self::State
fn init_state(world: &mut World) -> Self::State
State
for this WorldQuery
type.Source§fn matches_component_set(
_: &Self::State,
_: &impl Fn(ComponentId) -> bool,
) -> bool
fn matches_component_set( _: &Self::State, _: &impl Fn(ComponentId) -> bool, ) -> bool
Source§fn set_access(_state: &mut Self::State, _access: &FilteredAccess<ComponentId>)
fn set_access(_state: &mut Self::State, _access: &FilteredAccess<ComponentId>)
FilteredEntityRef
or FilteredEntityMut
. Read moreimpl<B: Bundle> Copy for EntityRefExcept<'_, B>
impl<B: Bundle> EntityEquivalent for EntityRefExcept<'_, B>
impl<B: Bundle> Eq for EntityRefExcept<'_, B>
impl<'a, B> ReadOnlyQueryData for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: EntityRefExcept
enforces read-only access to its contained
components.
Auto Trait Implementations§
impl<'w, B> Freeze for EntityRefExcept<'w, B>
impl<'w, B> !RefUnwindSafe for EntityRefExcept<'w, B>
impl<'w, B> Send for EntityRefExcept<'w, B>
impl<'w, B> Sync for EntityRefExcept<'w, B>
impl<'w, B> Unpin for EntityRefExcept<'w, B>where
B: Unpin,
impl<'w, B> !UnwindSafe for EntityRefExcept<'w, B>
Blanket Implementations§
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.