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§
Trait Implementations§
source§impl<'w, B> Clone for EntityRefExcept<'w, B>
impl<'w, B> Clone for EntityRefExcept<'w, B>
source§fn clone(&self) -> EntityRefExcept<'w, B>
fn clone(&self) -> EntityRefExcept<'w, B>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§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_mut: &'a EntityMutExcept<'_, B>) -> Self
fn from(entity_mut: &'a EntityMutExcept<'_, B>) -> Self
Converts to this type from the input type.
source§impl<'a, B> QueryData for EntityRefExcept<'a, B>where
B: Bundle,
impl<'a, B> QueryData for EntityRefExcept<'a, B>where
B: Bundle,
SAFETY: Self
is the same as Self::ReadOnly
.
source§type ReadOnly = EntityRefExcept<'a, B>
type ReadOnly = EntityRefExcept<'a, B>
The read-only variant of this
QueryData
, which satisfies the ReadOnlyQueryData
trait.source§impl<'a, B> WorldQuery for EntityRefExcept<'a, B>where
B: Bundle,
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
Returns true if (and only if) every table of every archetype matched by this fetch contains
all of the matched components. This is used to select a more efficient “table iterator”
for “dense” queries. If this returns true,
WorldQuery::set_table
must be used before
WorldQuery::fetch
can be called for iterators. If this returns false,
WorldQuery::set_archetype
must be used before WorldQuery::fetch
can be called for
iterators.source§type Fetch<'w> = UnsafeWorldCell<'w>
type Fetch<'w> = UnsafeWorldCell<'w>
Per archetype/table state used by this
WorldQuery
to fetch Self::Item
source§type Item<'w> = EntityRefExcept<'w, B>
type Item<'w> = EntityRefExcept<'w, B>
The item returned by this
WorldQuery
For QueryData
this will be the item returned by the query.
For QueryFilter
this will be either ()
, or a bool
indicating whether the entity should be included
or a tuple of such things.source§type State = SmallVec<[ComponentId; 4]>
type State = SmallVec<[ComponentId; 4]>
State used to construct a
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<'wlong: 'wshort, 'wshort>(
item: Self::Item<'wlong>,
) -> Self::Item<'wshort>
fn shrink<'wlong: 'wshort, 'wshort>( item: Self::Item<'wlong>, ) -> Self::Item<'wshort>
This function manually implements subtyping for the query items.
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>
This function manually implements subtyping for the query fetches.
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>
Creates a new instance of this fetch. Read more
source§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, )
Adjusts internal state to account for the next
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)
Adjusts internal state to account for the next
Table
. This will always be called on tables
that match this WorldQuery
. Read moresource§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>
Fetch
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 a entity
in the current archetype. 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
Creates and initializes a
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>)
Sets available accesses for implementors with dynamic access such as
FilteredEntityRef
or FilteredEntityMut
. Read moreimpl<'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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)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.